Mesen-SX/Core/Ppu.h

93 lines
2 KiB
C
Raw Normal View History

#pragma once
#include "stdafx.h"
#include "PpuTypes.h"
2019-02-13 18:44:39 -05:00
class Console;
class InternalRegisters;
2019-02-13 18:44:39 -05:00
class Ppu
{
2019-02-15 21:33:13 -05:00
public:
constexpr static uint32_t SpriteRamSize = 544;
constexpr static uint32_t CgRamSize = 512;
constexpr static uint32_t VideoRamSize = 0x10000;
private:
constexpr static const uint8_t _oamSizes[8][2][2] = {
{ { 1, 1 }, { 2, 2 } }, //8x8 + 16x16
{ { 1, 1 }, { 4, 4 } }, //8x8 + 32x32
{ { 1, 1 }, { 8, 8 } }, //8x8 + 64x64
{ { 2, 2 }, { 4, 4 } }, //16x16 + 32x32
{ { 2, 2 }, { 8, 8 } }, //16x16 + 64x64
{ { 4, 4 }, { 8, 8 } }, //32x32 + 64x64
{ { 2, 4 }, { 4, 8 } }, //16x32 + 32x64
{ { 2, 4 }, { 4, 4 } } //16x32 + 32x32
};
2019-02-13 18:44:39 -05:00
shared_ptr<Console> _console;
shared_ptr<InternalRegisters> _regs;
2019-02-13 18:44:39 -05:00
uint16_t _cycle = 0;
uint16_t _scanline = 0;
uint32_t _frameCount = 0;
uint8_t _bgMode = 0;
uint8_t _mainScreenLayers = 0;
LayerConfig _layerConfig[4];
2019-02-13 18:44:39 -05:00
uint8_t *_vram;
uint16_t _vramAddress;
uint8_t _vramIncrementValue;
uint8_t _vramAddressRemapping;
bool _vramAddrIncrementOnSecondReg;
uint16_t _cgramAddress;
2019-02-15 21:33:13 -05:00
uint8_t _cgram[Ppu::CgRamSize];
2019-02-13 18:44:39 -05:00
uint16_t *_outputBuffers[2];
uint16_t *_currentBuffer;
2019-02-17 21:09:33 -05:00
uint8_t _oamMode = 0;
uint16_t _oamBaseAddress = 0;
uint16_t _oamAddressOffset = 0;
2019-02-17 21:09:33 -05:00
uint8_t _oamRam[Ppu::SpriteRamSize];
uint16_t _oamRamAddress = 0;
bool _enableOamPriority = false;
uint16_t _internalOamAddress = 0;
uint8_t _oamWriteBuffer = 0;
2019-02-18 22:27:22 -05:00
bool _directColorMode = false;
uint8_t _colorMathClipMode = 0;
uint8_t _colorMathPreventMode = 0;
bool _colorMathAddSubscreen = false;
uint8_t _colorMathEnabled = 0;
bool _colorMathSubstractMode = false;
bool _colorMathHalveResult = false;
void RenderTilemap(uint8_t layerIndex, uint8_t bpp);
void DrawSprites();
2019-02-13 18:44:39 -05:00
public:
Ppu(shared_ptr<Console> console);
2019-02-16 01:16:57 -05:00
~Ppu();
2019-02-17 19:54:29 -05:00
uint32_t GetFrameCount();
2019-02-13 18:44:39 -05:00
PpuState GetState();
2019-02-13 18:44:39 -05:00
void Exec();
2019-02-18 22:27:22 -05:00
void RenderScanline();
2019-02-13 18:44:39 -05:00
void SendFrame();
2019-02-15 21:33:13 -05:00
uint8_t* GetVideoRam();
uint8_t* GetCgRam();
uint8_t* GetSpriteRam();
2019-02-13 18:44:39 -05:00
uint8_t Read(uint16_t addr);
void Write(uint32_t addr, uint8_t value);
};