2009-07-28 21:32:10 +00:00
|
|
|
|
// Copyright (C) 2003 Dolphin Project.
|
2009-02-23 06:17:57 +00:00
|
|
|
|
|
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
|
// the Free Software Foundation, version 2.0.
|
|
|
|
|
|
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
// GNU General Public License 2.0 for more details.
|
|
|
|
|
|
|
|
|
|
// A copy of the GPL 2.0 should have been included with the program.
|
|
|
|
|
// If not, see http://www.gnu.org/licenses/
|
|
|
|
|
|
|
|
|
|
// Official SVN repository and contact information can be found at
|
|
|
|
|
// http://code.google.com/p/dolphin-emu/
|
|
|
|
|
|
|
|
|
|
#ifndef _VIDEOCOMMON_H
|
|
|
|
|
#define _VIDEOCOMMON_H
|
|
|
|
|
|
|
|
|
|
#include "Common.h"
|
2009-07-15 00:51:24 +00:00
|
|
|
|
#include "MathUtil.h"
|
2009-02-23 06:17:57 +00:00
|
|
|
|
#include "pluginspecs_video.h"
|
|
|
|
|
|
|
|
|
|
#if defined(_MSC_VER) && !defined(__x86_64__) && !defined(_M_X64)
|
|
|
|
|
void * memcpy_amd(void *dest, const void *src, size_t n);
|
|
|
|
|
unsigned char memcmp_mmx(const void* src1, const void* src2, int cmpsize);
|
|
|
|
|
#define memcpy_gc memcpy_amd
|
|
|
|
|
#define memcmp_gc memcmp_mmx
|
|
|
|
|
#else
|
|
|
|
|
#define memcpy_gc memcpy
|
|
|
|
|
#define memcmp_gc memcmp
|
|
|
|
|
#endif
|
|
|
|
|
|
2009-02-28 19:02:37 +00:00
|
|
|
|
// These are accurate (disregarding AA modes).
|
|
|
|
|
enum
|
|
|
|
|
{
|
2009-02-23 06:17:57 +00:00
|
|
|
|
EFB_WIDTH = 640,
|
|
|
|
|
EFB_HEIGHT = 528,
|
|
|
|
|
};
|
|
|
|
|
|
2009-02-28 19:02:37 +00:00
|
|
|
|
enum
|
|
|
|
|
{
|
2009-07-15 00:51:24 +00:00
|
|
|
|
// XFB width is decided by EFB copy operation. The VI can do horizontal
|
|
|
|
|
// scaling (TODO: emulate).
|
|
|
|
|
MAX_XFB_WIDTH = EFB_WIDTH,
|
|
|
|
|
|
|
|
|
|
// Although EFB height is 528, 574-line XFB's can be created either with
|
|
|
|
|
// vertical scaling by the EFB copy operation or copying to multiple XFB's
|
|
|
|
|
// that are next to each other in memory (TODO: handle that situation).
|
|
|
|
|
MAX_XFB_HEIGHT = 574
|
2009-02-23 06:17:57 +00:00
|
|
|
|
};
|
|
|
|
|
|
2009-06-28 20:04:07 +00:00
|
|
|
|
// If this is enabled, bounding boxes will be computed for everything drawn.
|
|
|
|
|
// This can theoretically have a big speed hit in some geom heavy games. Needs more work.
|
|
|
|
|
// Helps some effects in Paper Mario (but they aren't quite right yet).
|
|
|
|
|
// May help Super Mario Galaxy?
|
|
|
|
|
// Do testing to figure out if the speed hit is bad?
|
|
|
|
|
// #define BBOX_SUPPORT
|
|
|
|
|
|
2009-02-23 06:17:57 +00:00
|
|
|
|
extern SVideoInitialize g_VideoInitialize;
|
2009-06-28 20:04:07 +00:00
|
|
|
|
|
2009-09-02 21:00:45 +00:00
|
|
|
|
|
2009-02-23 06:17:57 +00:00
|
|
|
|
inline u8 *Memory_GetPtr(u32 _uAddress)
|
|
|
|
|
{
|
2009-02-28 19:02:37 +00:00
|
|
|
|
return g_VideoInitialize.pGetMemoryPointer(_uAddress);
|
2009-02-23 06:17:57 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
inline u8 Memory_Read_U8(u32 _uAddress)
|
|
|
|
|
{
|
2009-02-28 19:02:37 +00:00
|
|
|
|
return *(u8*)g_VideoInitialize.pGetMemoryPointer(_uAddress);
|
2009-02-23 06:17:57 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
inline u16 Memory_Read_U16(u32 _uAddress)
|
|
|
|
|
{
|
|
|
|
|
return Common::swap16(*(u16*)g_VideoInitialize.pGetMemoryPointer(_uAddress));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
inline u32 Memory_Read_U32(u32 _uAddress)
|
|
|
|
|
{
|
|
|
|
|
return Common::swap32(*(u32*)g_VideoInitialize.pGetMemoryPointer(_uAddress));
|
|
|
|
|
}
|
2009-09-02 21:00:45 +00:00
|
|
|
|
|
2009-02-23 06:17:57 +00:00
|
|
|
|
inline u8* Memory_Read_U8_Ptr(u32 _uAddress)
|
|
|
|
|
{
|
2009-02-28 19:02:37 +00:00
|
|
|
|
return (u8*)g_VideoInitialize.pGetMemoryPointer(_uAddress);
|
2009-02-23 06:17:57 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
inline u16* Memory_Read_U16_Unswapped_Ptr(u32 _uAddress)
|
|
|
|
|
{
|
|
|
|
|
return (u16*)g_VideoInitialize.pGetMemoryPointer(_uAddress);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
inline u32* Memory_Read_U32_Unswapped_Ptr(u32 _uAddress)
|
|
|
|
|
{
|
|
|
|
|
return (u32*)g_VideoInitialize.pGetMemoryPointer(_uAddress);
|
|
|
|
|
}
|
2009-09-02 21:00:45 +00:00
|
|
|
|
|
2009-02-23 06:17:57 +00:00
|
|
|
|
|
|
|
|
|
inline float Memory_Read_Float(u32 _uAddress)
|
|
|
|
|
{
|
|
|
|
|
union {u32 i; float f;} temp;
|
|
|
|
|
temp.i = Memory_Read_U32(_uAddress);
|
|
|
|
|
return temp.f;
|
|
|
|
|
}
|
|
|
|
|
|
2009-07-15 00:51:24 +00:00
|
|
|
|
// This structure should only be used to represent a rectangle in EFB
|
|
|
|
|
// coordinates, where the origin is at the upper left and the frame dimensions
|
|
|
|
|
// are 640 x 528.
|
|
|
|
|
struct EFBRectangle : public MathUtil::Rectangle<int>
|
|
|
|
|
{};
|
2009-02-23 06:17:57 +00:00
|
|
|
|
|
|
|
|
|
// Logging
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
void HandleGLError();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef _WIN32
|
2009-03-02 01:49:16 +00:00
|
|
|
|
#define PRIM_LOG(...) {DEBUG_LOG(VIDEO, __VA_ARGS__)}
|
2009-02-23 06:17:57 +00:00
|
|
|
|
#else
|
2009-03-02 01:49:16 +00:00
|
|
|
|
#define PRIM_LOG(...) {DEBUG_LOG(VIDEO, ##__VA_ARGS__)}
|
2009-02-23 06:17:57 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
2009-03-04 22:29:03 +00:00
|
|
|
|
#define LOG_VTX() DEBUG_LOG(VIDEO, "vtx: %f %f %f, ", ((float*)VertexManager::s_pCurBufferPointer)[0], ((float*)VertexManager::s_pCurBufferPointer)[1], ((float*)VertexManager::s_pCurBufferPointer)[2]);
|
|
|
|
|
|
2009-02-23 06:17:57 +00:00
|
|
|
|
|
|
|
|
|
#endif // _VIDEOCOMMON_H
|