2013-04-18 03:09:55 +00:00
|
|
|
// Copyright 2013 Dolphin Emulator Project
|
|
|
|
// Licensed under GPLv2
|
|
|
|
// Refer to the license.txt file included.
|
2009-02-23 06:17:57 +00:00
|
|
|
|
2014-02-10 18:54:46 +00:00
|
|
|
#pragma once
|
2009-02-23 06:17:57 +00:00
|
|
|
|
2011-02-02 04:40:27 +00:00
|
|
|
#ifdef _WIN32
|
|
|
|
#define WIN32_LEAN_AND_MEAN
|
|
|
|
#include <windows.h>
|
|
|
|
#endif
|
|
|
|
|
2014-02-17 10:18:15 +00:00
|
|
|
#include "Common/Common.h"
|
|
|
|
#include "Common/MathUtil.h"
|
|
|
|
#include "VideoCommon/VideoBackendBase.h"
|
2009-02-23 06:17:57 +00:00
|
|
|
|
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,
|
|
|
|
};
|
|
|
|
|
2012-12-30 09:28:50 +00:00
|
|
|
// XFB width is decided by EFB copy operation. The VI can do horizontal
|
|
|
|
// scaling (TODO: emulate).
|
|
|
|
const u32 MAX_XFB_WIDTH = EFB_WIDTH;
|
2009-07-15 00:51:24 +00:00
|
|
|
|
2012-12-30 09:28:50 +00:00
|
|
|
// 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).
|
|
|
|
const u32 MAX_XFB_HEIGHT = 574;
|
2009-02-23 06:17:57 +00:00
|
|
|
|
2009-09-03 20:37:35 +00:00
|
|
|
// Logging
|
2009-09-08 16:07:13 +00:00
|
|
|
// ----------
|
2009-09-03 20:37:35 +00:00
|
|
|
void HandleGLError();
|
|
|
|
|
|
|
|
|
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.
|
2011-09-05 20:04:28 +00:00
|
|
|
typedef MathUtil::Rectangle<int> EFBRectangle;
|
2009-02-23 06:17:57 +00:00
|
|
|
|
2009-09-03 21:56:08 +00:00
|
|
|
// This structure should only be used to represent a rectangle in standard target
|
|
|
|
// coordinates, where the origin is at the lower left and the frame dimensions
|
|
|
|
// depend on the resolution settings. Use Renderer::ConvertEFBRectangle to
|
|
|
|
// convert an EFBRectangle to a TargetRectangle.
|
|
|
|
struct TargetRectangle : public MathUtil::Rectangle<int>
|
2009-09-13 08:21:35 +00:00
|
|
|
{
|
|
|
|
#ifdef _WIN32
|
2011-02-14 02:18:03 +00:00
|
|
|
// Only used by D3D backend.
|
2010-11-18 02:21:26 +00:00
|
|
|
const RECT *AsRECT() const
|
|
|
|
{
|
2009-09-13 08:21:35 +00:00
|
|
|
// The types are binary compatible so this works.
|
|
|
|
return (const RECT *)this;
|
|
|
|
}
|
2010-11-18 02:21:26 +00:00
|
|
|
RECT *AsRECT()
|
|
|
|
{
|
|
|
|
// The types are binary compatible so this works.
|
|
|
|
return (RECT *)this;
|
|
|
|
}
|
2009-09-13 08:21:35 +00:00
|
|
|
#endif
|
|
|
|
};
|
2009-02-23 06:17:57 +00:00
|
|
|
|
|
|
|
#ifdef _WIN32
|
2012-08-20 11:12:49 +00:00
|
|
|
#define PRIM_LOG(...) DEBUG_LOG(VIDEO, __VA_ARGS__)
|
2009-02-23 06:17:57 +00:00
|
|
|
#else
|
2012-08-20 11:12:49 +00:00
|
|
|
#define PRIM_LOG(...) DEBUG_LOG(VIDEO, ##__VA_ARGS__)
|
2009-02-23 06:17:57 +00:00
|
|
|
#endif
|
|
|
|
|
2013-02-21 10:45:29 +00:00
|
|
|
// warning: mapping buffer should be disabled to use this
|
2013-02-21 12:45:48 +00:00
|
|
|
// #define LOG_VTX() DEBUG_LOG(VIDEO, "vtx: %f %f %f, ", ((float*)VertexManager::s_pCurBufferPointer)[-3], ((float*)VertexManager::s_pCurBufferPointer)[-2], ((float*)VertexManager::s_pCurBufferPointer)[-1]);
|
2009-09-08 21:16:05 +00:00
|
|
|
|
|
|
|
#define LOG_VTX()
|
2009-02-23 06:17:57 +00:00
|
|
|
|
2010-06-14 14:36:01 +00:00
|
|
|
typedef enum
|
|
|
|
{
|
2011-06-10 19:16:09 +00:00
|
|
|
API_OPENGL = 1,
|
2014-02-09 21:03:16 +00:00
|
|
|
API_D3D = 2,
|
|
|
|
API_NONE = 3
|
2010-06-14 14:36:01 +00:00
|
|
|
} API_TYPE;
|
|
|
|
|
2010-12-27 03:09:11 +00:00
|
|
|
inline u32 RGBA8ToRGBA6ToRGBA8(u32 src)
|
|
|
|
{
|
|
|
|
u32 color = src;
|
|
|
|
color &= 0xFCFCFCFC;
|
|
|
|
color |= (color >> 6) & 0x03030303;
|
|
|
|
return color;
|
|
|
|
}
|
|
|
|
|
2010-12-27 18:09:03 +00:00
|
|
|
inline u32 RGBA8ToRGB565ToRGBA8(u32 src)
|
2010-12-27 03:09:11 +00:00
|
|
|
{
|
2011-01-29 04:31:56 +00:00
|
|
|
u32 color = (src & 0xF8FCF8);
|
|
|
|
color |= (color >> 5) & 0x070007;
|
|
|
|
color |= (color >> 6) & 0x000300;
|
|
|
|
color |= 0xFF000000;
|
2010-12-27 03:09:11 +00:00
|
|
|
return color;
|
|
|
|
}
|
|
|
|
|
2010-12-27 18:09:03 +00:00
|
|
|
inline u32 Z24ToZ16ToZ24(u32 src)
|
|
|
|
{
|
|
|
|
return (src & 0xFFFF00) | (src >> 16);
|
|
|
|
}
|
2010-12-27 03:09:11 +00:00
|
|
|
|
2011-01-03 14:35:07 +00:00
|
|
|
/* Returns the smallest power of 2 which is greater than or equal to num */
|
|
|
|
inline u32 MakePow2(u32 num)
|
|
|
|
{
|
|
|
|
--num;
|
|
|
|
num |= num >> 1;
|
|
|
|
num |= num >> 2;
|
|
|
|
num |= num >> 4;
|
|
|
|
num |= num >> 8;
|
|
|
|
num |= num >> 16;
|
|
|
|
++num;
|
|
|
|
return num;
|
|
|
|
}
|
|
|
|
|
2011-01-02 23:13:29 +00:00
|
|
|
// returns the exponent of the smallest power of two which is greater than val
|
2011-01-03 01:59:44 +00:00
|
|
|
inline unsigned int GetPow2(unsigned int val)
|
2011-01-02 23:13:29 +00:00
|
|
|
{
|
|
|
|
unsigned int ret = 0;
|
|
|
|
for (; val; val >>= 1)
|
|
|
|
++ret;
|
|
|
|
return ret;
|
|
|
|
}
|