Mapper 218 support
This commit is contained in:
parent
184be6b1f8
commit
bef12d69a8
8 changed files with 74 additions and 27 deletions
|
@ -341,6 +341,8 @@ void BaseMapper::Initialize(RomData &romData)
|
||||||
memset(_isWriteRegisterAddr, 0, sizeof(_isWriteRegisterAddr));
|
memset(_isWriteRegisterAddr, 0, sizeof(_isWriteRegisterAddr));
|
||||||
AddRegisterRange(RegisterStartAddress(), RegisterEndAddress(), MemoryOperation::Any);
|
AddRegisterRange(RegisterStartAddress(), RegisterEndAddress(), MemoryOperation::Any);
|
||||||
|
|
||||||
|
_nesHeader = romData.NesHeader;
|
||||||
|
|
||||||
_mirroringType = romData.MirroringType;
|
_mirroringType = romData.MirroringType;
|
||||||
|
|
||||||
_prgSize = (uint32_t)romData.PrgRom.size();
|
_prgSize = (uint32_t)romData.PrgRom.size();
|
||||||
|
|
|
@ -75,6 +75,7 @@ private:
|
||||||
vector<uint8_t> _originalPrgRom;
|
vector<uint8_t> _originalPrgRom;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
NESHeader _nesHeader;
|
||||||
uint16_t _mapperID;
|
uint16_t _mapperID;
|
||||||
uint8_t _subMapperID;
|
uint8_t _subMapperID;
|
||||||
|
|
||||||
|
@ -168,7 +169,7 @@ public:
|
||||||
|
|
||||||
void ApplyCheats();
|
void ApplyCheats();
|
||||||
|
|
||||||
void SetDefaultNametables(uint8_t* nametableA, uint8_t* nametableB);
|
virtual void SetDefaultNametables(uint8_t* nametableA, uint8_t* nametableB);
|
||||||
|
|
||||||
GameSystem GetGameSystem();
|
GameSystem GetGameSystem();
|
||||||
uint32_t GetCrc32();
|
uint32_t GetCrc32();
|
||||||
|
|
|
@ -420,6 +420,7 @@
|
||||||
<ClInclude Include="Mapper201.h" />
|
<ClInclude Include="Mapper201.h" />
|
||||||
<ClInclude Include="Mapper202.h" />
|
<ClInclude Include="Mapper202.h" />
|
||||||
<ClInclude Include="Mapper203.h" />
|
<ClInclude Include="Mapper203.h" />
|
||||||
|
<ClInclude Include="Mapper218.h" />
|
||||||
<ClInclude Include="Mapper225.h" />
|
<ClInclude Include="Mapper225.h" />
|
||||||
<ClInclude Include="Mapper226.h" />
|
<ClInclude Include="Mapper226.h" />
|
||||||
<ClInclude Include="Mapper230.h" />
|
<ClInclude Include="Mapper230.h" />
|
||||||
|
|
|
@ -640,6 +640,9 @@
|
||||||
<ClInclude Include="MMC1_155.h">
|
<ClInclude Include="MMC1_155.h">
|
||||||
<Filter>Nes\Mappers\MMC</Filter>
|
<Filter>Nes\Mappers\MMC</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
<ClInclude Include="Mapper218.h">
|
||||||
|
<Filter>Nes\Mappers\Unnamed</Filter>
|
||||||
|
</ClInclude>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClCompile Include="stdafx.cpp">
|
<ClCompile Include="stdafx.cpp">
|
||||||
|
|
35
Core/Mapper218.h
Normal file
35
Core/Mapper218.h
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
#pragma once
|
||||||
|
#include "BaseMapper.h"
|
||||||
|
|
||||||
|
class Mapper218 : public BaseMapper
|
||||||
|
{
|
||||||
|
protected:
|
||||||
|
uint16_t GetPRGPageSize() { return 0x8000; }
|
||||||
|
uint16_t GetCHRPageSize() { return 0x2000; }
|
||||||
|
|
||||||
|
void InitMapper()
|
||||||
|
{
|
||||||
|
SelectPRGPage(0, 0);
|
||||||
|
|
||||||
|
if(GetMirroringType() == MirroringType::FourScreens) {
|
||||||
|
SetMirroringType(_nesHeader.Byte6 & 0x01 ? MirroringType::ScreenBOnly : MirroringType::ScreenAOnly);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetDefaultNametables(uint8_t* nametableA, uint8_t* nametableB)
|
||||||
|
{
|
||||||
|
BaseMapper::SetDefaultNametables(nametableA, nametableB);
|
||||||
|
|
||||||
|
uint16_t mask = 0;
|
||||||
|
switch(GetMirroringType()) {
|
||||||
|
case MirroringType::Vertical: mask = 0x400; break;
|
||||||
|
case MirroringType::Horizontal: mask = 0x800; break;
|
||||||
|
case MirroringType::ScreenAOnly: mask = 0x1000; break;
|
||||||
|
case MirroringType::ScreenBOnly: mask = 0x2000; break;
|
||||||
|
}
|
||||||
|
|
||||||
|
for(int i = 0; i < 8; i++) {
|
||||||
|
SetPpuMemoryMapping(i * 0x400, i * 0x400 + 0x3FF, (i * 0x400) & mask ? GetNametable(1) : GetNametable(0));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
|
@ -38,6 +38,7 @@
|
||||||
#include "Mapper201.h"
|
#include "Mapper201.h"
|
||||||
#include "Mapper202.h"
|
#include "Mapper202.h"
|
||||||
#include "Mapper203.h"
|
#include "Mapper203.h"
|
||||||
|
#include "Mapper218.h"
|
||||||
#include "Mapper225.h"
|
#include "Mapper225.h"
|
||||||
#include "Mapper226.h"
|
#include "Mapper226.h"
|
||||||
#include "Mapper230.h"
|
#include "Mapper230.h"
|
||||||
|
@ -225,6 +226,7 @@ BaseMapper* MapperFactory::GetMapperFromID(RomData &romData)
|
||||||
case 206: return new Namco108();
|
case 206: return new Namco108();
|
||||||
case 207: return new TaitoX1005(true);
|
case 207: return new TaitoX1005(true);
|
||||||
case 210: return new Namco163();
|
case 210: return new Namco163();
|
||||||
|
case 218: return new Mapper218();
|
||||||
case 225: return new Mapper225();
|
case 225: return new Mapper225();
|
||||||
case 226: return new Mapper226();
|
case 226: return new Mapper226();
|
||||||
case 230: return new Mapper230();
|
case 230: return new Mapper230();
|
||||||
|
|
|
@ -29,32 +29,6 @@ enum class GameSystem
|
||||||
Unknown,
|
Unknown,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct RomData
|
|
||||||
{
|
|
||||||
string RomName;
|
|
||||||
string Filename;
|
|
||||||
|
|
||||||
uint16_t MapperID;
|
|
||||||
uint8_t SubMapperID = 0;
|
|
||||||
GameSystem System = GameSystem::Unknown;
|
|
||||||
bool HasBattery = false;
|
|
||||||
bool HasTrainer = false;
|
|
||||||
MirroringType MirroringType;
|
|
||||||
int32_t ChrRamSize = -1;
|
|
||||||
|
|
||||||
bool IsNes20Header = false;
|
|
||||||
|
|
||||||
vector<uint8_t> PrgRom;
|
|
||||||
vector<uint8_t> ChrRom;
|
|
||||||
vector<uint8_t> TrainerData;
|
|
||||||
vector<vector<uint8_t>> FdsDiskData;
|
|
||||||
|
|
||||||
vector<uint8_t> RawData;
|
|
||||||
uint32_t Crc32;
|
|
||||||
|
|
||||||
bool Error = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct NESHeader
|
struct NESHeader
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
|
@ -220,4 +194,32 @@ struct NESHeader
|
||||||
calculatedLength = sizeof(NESHeader) + 0x4000 * PrgCount + 0x2000 * ChrCount;
|
calculatedLength = sizeof(NESHeader) + 0x4000 * PrgCount + 0x2000 * ChrCount;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
struct RomData
|
||||||
|
{
|
||||||
|
string RomName;
|
||||||
|
string Filename;
|
||||||
|
|
||||||
|
uint16_t MapperID;
|
||||||
|
uint8_t SubMapperID = 0;
|
||||||
|
GameSystem System = GameSystem::Unknown;
|
||||||
|
bool HasBattery = false;
|
||||||
|
bool HasTrainer = false;
|
||||||
|
MirroringType MirroringType;
|
||||||
|
int32_t ChrRamSize = -1;
|
||||||
|
|
||||||
|
bool IsNes20Header = false;
|
||||||
|
|
||||||
|
vector<uint8_t> PrgRom;
|
||||||
|
vector<uint8_t> ChrRom;
|
||||||
|
vector<uint8_t> TrainerData;
|
||||||
|
vector<vector<uint8_t>> FdsDiskData;
|
||||||
|
|
||||||
|
vector<uint8_t> RawData;
|
||||||
|
uint32_t Crc32;
|
||||||
|
|
||||||
|
bool Error = false;
|
||||||
|
|
||||||
|
NESHeader NesHeader;
|
||||||
};
|
};
|
|
@ -29,6 +29,7 @@ RomData iNesLoader::LoadRom(vector<uint8_t>& romFile)
|
||||||
}
|
}
|
||||||
romData.HasTrainer = header.HasTrainer();
|
romData.HasTrainer = header.HasTrainer();
|
||||||
romData.ChrRamSize = header.GetChrRamSize();
|
romData.ChrRamSize = header.GetChrRamSize();
|
||||||
|
romData.NesHeader = header;
|
||||||
|
|
||||||
if(romData.HasTrainer) {
|
if(romData.HasTrainer) {
|
||||||
//512-byte trainer at $7000-$71FF (stored before PRG data)
|
//512-byte trainer at $7000-$71FF (stored before PRG data)
|
||||||
|
|
Loading…
Add table
Reference in a new issue