mirror of
https://github.com/libretro/Mesen.git
synced 2025-02-12 12:18:52 +00:00
Mapper 228 support (Action 52, Cheetahmen 2)
This commit is contained in:
parent
115ccc0705
commit
a28ef85549
43
Core/ActionEnterprises.h
Normal file
43
Core/ActionEnterprises.h
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
#pragma once
|
||||||
|
#include "stdafx.h"
|
||||||
|
#include "BaseMapper.h"
|
||||||
|
|
||||||
|
class ActionEnterprises : public BaseMapper
|
||||||
|
{
|
||||||
|
protected:
|
||||||
|
virtual uint16_t GetPRGPageSize() { return 0x4000; }
|
||||||
|
virtual uint16_t GetCHRPageSize() { return 0x2000; }
|
||||||
|
|
||||||
|
void InitMapper()
|
||||||
|
{
|
||||||
|
WriteRegister(0x8000, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual void Reset(bool softReset)
|
||||||
|
{
|
||||||
|
WriteRegister(0x8000, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void WriteRegister(uint16_t addr, uint8_t value)
|
||||||
|
{
|
||||||
|
uint8_t chipSelect = (addr >> 11) & 0x03;
|
||||||
|
|
||||||
|
if(chipSelect == 3) {
|
||||||
|
chipSelect = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t prgPage = ((addr >> 6) & 0x1F) | (chipSelect << 5);
|
||||||
|
if(addr & 0x20) {
|
||||||
|
SelectPRGPage(0, prgPage);
|
||||||
|
SelectPRGPage(1, prgPage);
|
||||||
|
} else {
|
||||||
|
SelectPRGPage(0, prgPage & 0xFE);
|
||||||
|
SelectPRGPage(1, (prgPage & 0xFE) + 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
SelectCHRPage(0, ((addr & 0x0F) << 2) | (value & 0x03));
|
||||||
|
|
||||||
|
SetMirroringType(addr & 0x2000 ? MirroringType::Horizontal : MirroringType::Vertical);
|
||||||
|
}
|
||||||
|
};
|
@ -382,6 +382,7 @@
|
|||||||
</Link>
|
</Link>
|
||||||
</ItemDefinitionGroup>
|
</ItemDefinitionGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
<ClInclude Include="ActionEnterprises.h" />
|
||||||
<ClInclude Include="APU.h" />
|
<ClInclude Include="APU.h" />
|
||||||
<ClInclude Include="ArkanoidController.h" />
|
<ClInclude Include="ArkanoidController.h" />
|
||||||
<ClInclude Include="AutoRomTest.h" />
|
<ClInclude Include="AutoRomTest.h" />
|
||||||
|
@ -649,6 +649,9 @@
|
|||||||
<ClInclude Include="Sachen_143.h">
|
<ClInclude Include="Sachen_143.h">
|
||||||
<Filter>Nes\Mappers\Sachen</Filter>
|
<Filter>Nes\Mappers\Sachen</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
<ClInclude Include="ActionEnterprises.h">
|
||||||
|
<Filter>Nes\Mappers</Filter>
|
||||||
|
</ClInclude>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClCompile Include="stdafx.cpp">
|
<ClCompile Include="stdafx.cpp">
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
#include "MessageManager.h"
|
#include "MessageManager.h"
|
||||||
#include "MapperFactory.h"
|
#include "MapperFactory.h"
|
||||||
#include "RomLoader.h"
|
#include "RomLoader.h"
|
||||||
|
#include "ActionEnterprises.h"
|
||||||
#include "AXROM.h"
|
#include "AXROM.h"
|
||||||
#include "Bandai74161_7432.h"
|
#include "Bandai74161_7432.h"
|
||||||
#include "BandaiFcg.h"
|
#include "BandaiFcg.h"
|
||||||
@ -236,6 +237,7 @@ BaseMapper* MapperFactory::GetMapperFromID(RomData &romData)
|
|||||||
case 218: return new Mapper218();
|
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 228: return new ActionEnterprises();
|
||||||
case 230: return new Mapper230();
|
case 230: return new Mapper230();
|
||||||
case 231: return new Mapper231();
|
case 231: return new Mapper231();
|
||||||
case 232: return new BF9096();
|
case 232: return new BF9096();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user