2013-04-17 23:29:41 -04:00
|
|
|
// Copyright 2013 Dolphin Emulator Project
|
|
|
|
// Licensed under GPLv2
|
|
|
|
// Refer to the license.txt file included.
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2014-02-10 13:54:46 -05:00
|
|
|
#pragma once
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2014-02-17 05:18:15 -05:00
|
|
|
#include "VideoCommon/VideoCommon.h"
|
2010-06-09 01:37:08 +00:00
|
|
|
|
|
|
|
namespace EfbInterface
|
|
|
|
{
|
2013-04-13 23:54:02 -04:00
|
|
|
const int DEPTH_BUFFER_START = EFB_WIDTH * EFB_HEIGHT * 3;
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2013-08-23 00:07:21 +12:00
|
|
|
// xfb color format - packed so the compiler doesn't mess with alignment
|
2013-08-21 00:56:19 +12:00
|
|
|
#pragma pack(push,1)
|
2014-07-23 20:26:54 -04:00
|
|
|
struct yuv422_packed
|
|
|
|
{
|
2013-08-20 23:51:39 +12:00
|
|
|
u8 Y;
|
|
|
|
u8 UV;
|
2014-07-23 20:26:54 -04:00
|
|
|
};
|
2013-08-21 00:56:19 +12:00
|
|
|
#pragma pack(pop)
|
2013-08-20 23:51:39 +12:00
|
|
|
|
2013-08-21 00:56:19 +12:00
|
|
|
// But this struct is only used internally, so we could optimise alignment
|
2014-07-23 20:26:54 -04:00
|
|
|
struct yuv444
|
|
|
|
{
|
2013-08-20 23:51:39 +12:00
|
|
|
u8 Y;
|
|
|
|
s8 U;
|
|
|
|
s8 V;
|
2014-07-23 20:26:54 -04:00
|
|
|
};
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2014-08-10 21:18:38 -04:00
|
|
|
enum
|
|
|
|
{
|
|
|
|
ALP_C,
|
|
|
|
BLU_C,
|
|
|
|
GRN_C,
|
|
|
|
RED_C
|
|
|
|
};
|
2013-08-23 00:07:21 +12:00
|
|
|
|
|
|
|
// color order is ABGR in order to emulate RGBA on little-endian hardware
|
|
|
|
|
2013-04-13 23:54:02 -04:00
|
|
|
// does full blending of an incoming pixel
|
|
|
|
void BlendTev(u16 x, u16 y, u8 *color);
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2013-04-13 23:54:02 -04:00
|
|
|
// compare z at location x,y
|
|
|
|
// writes it if it passes
|
|
|
|
// returns result of compare.
|
|
|
|
bool ZCompare(u16 x, u16 y, u32 z);
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2013-04-13 23:54:02 -04:00
|
|
|
// sets the color and alpha
|
|
|
|
void SetColor(u16 x, u16 y, u8 *color);
|
|
|
|
void SetDepth(u16 x, u16 y, u32 depth);
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2013-04-13 23:54:02 -04:00
|
|
|
void GetColor(u16 x, u16 y, u8 *color);
|
2013-08-20 23:51:39 +12:00
|
|
|
void GetColorYUV(u16 x, u16 y, yuv444 *color);
|
2013-04-13 23:54:02 -04:00
|
|
|
u32 GetDepth(u16 x, u16 y);
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2013-04-13 23:54:02 -04:00
|
|
|
u8* GetPixelPointer(u16 x, u16 y, bool depth);
|
2010-06-09 01:37:08 +00:00
|
|
|
|
2013-08-20 23:51:39 +12:00
|
|
|
void CopyToXFB(yuv422_packed* xfb_in_ram, u32 fbWidth, u32 fbHeight, const EFBRectangle& sourceRc, float Gamma);
|
2013-11-23 20:04:37 +13:00
|
|
|
void BypassXFB(u8* texture, u32 fbWidth, u32 fbHeight, const EFBRectangle& sourceRc, float Gamma);
|
2013-08-20 23:51:39 +12:00
|
|
|
|
2013-02-25 20:05:02 -05:00
|
|
|
void DoState(PointerWrap &p);
|
2014-03-28 19:22:15 -07:00
|
|
|
|
|
|
|
extern u32 perf_values[PQ_NUM_MEMBERS];
|
2014-04-05 13:08:00 -07:00
|
|
|
inline void IncPerfCounterQuadCount(PerfQueryType type)
|
|
|
|
{
|
2014-03-28 19:22:15 -07:00
|
|
|
// NOTE: hardware doesn't process individual pixels but quads instead.
|
|
|
|
// Current software renderer architecture works on pixels though, so
|
|
|
|
// we have this "quad" hack here to only increment the registers on
|
|
|
|
// every fourth rendered pixel
|
|
|
|
static u32 quad[PQ_NUM_MEMBERS];
|
|
|
|
if (++quad[type] != 3)
|
|
|
|
return;
|
|
|
|
quad[type] = 0;
|
|
|
|
++perf_values[type];
|
|
|
|
}
|
2010-06-09 01:37:08 +00:00
|
|
|
}
|