mirror of
https://github.com/libretro/Mesen.git
synced 2024-11-24 01:29:41 +00:00
Mapper 227 support
This commit is contained in:
parent
a9517ccd29
commit
7d4ab35ff5
@ -424,6 +424,7 @@
|
|||||||
<ClInclude Include="Mapper218.h" />
|
<ClInclude Include="Mapper218.h" />
|
||||||
<ClInclude Include="Mapper225.h" />
|
<ClInclude Include="Mapper225.h" />
|
||||||
<ClInclude Include="Mapper226.h" />
|
<ClInclude Include="Mapper226.h" />
|
||||||
|
<ClInclude Include="Mapper227.h" />
|
||||||
<ClInclude Include="Mapper230.h" />
|
<ClInclude Include="Mapper230.h" />
|
||||||
<ClInclude Include="Mapper241.h" />
|
<ClInclude Include="Mapper241.h" />
|
||||||
<ClInclude Include="Mapper60.h" />
|
<ClInclude Include="Mapper60.h" />
|
||||||
|
@ -661,6 +661,9 @@
|
|||||||
<ClInclude Include="Waixing176.h">
|
<ClInclude Include="Waixing176.h">
|
||||||
<Filter>Nes\Mappers</Filter>
|
<Filter>Nes\Mappers</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
<ClInclude Include="Mapper227.h">
|
||||||
|
<Filter>Nes\Mappers\Unnamed</Filter>
|
||||||
|
</ClInclude>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClCompile Include="stdafx.cpp">
|
<ClCompile Include="stdafx.cpp">
|
||||||
|
51
Core/Mapper227.h
Normal file
51
Core/Mapper227.h
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
#pragma once
|
||||||
|
#include "BaseMapper.h"
|
||||||
|
|
||||||
|
class Mapper227 : public BaseMapper
|
||||||
|
{
|
||||||
|
protected:
|
||||||
|
uint16_t GetPRGPageSize() { return 0x4000; }
|
||||||
|
uint16_t GetCHRPageSize() { return 0x2000; }
|
||||||
|
|
||||||
|
void InitMapper()
|
||||||
|
{
|
||||||
|
WriteRegister(0x8000, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
void WriteRegister(uint16_t addr, uint8_t value)
|
||||||
|
{
|
||||||
|
uint16_t prgBank = ((addr >> 2) & 0x1F) | ((addr & 0x100) >> 3);
|
||||||
|
bool sFlag = (addr & 0x01) == 0x01;
|
||||||
|
bool lFlag = ((addr >> 9) & 0x01) == 0x01;
|
||||||
|
bool prgMode = ((addr >> 7) & 0x01) == 0x01;
|
||||||
|
|
||||||
|
if(prgMode) {
|
||||||
|
if(sFlag) {
|
||||||
|
SelectPrgPage2x(0, prgBank & 0xFE);
|
||||||
|
} else {
|
||||||
|
SelectPRGPage(0, prgBank);
|
||||||
|
SelectPRGPage(1, prgBank);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if(sFlag){
|
||||||
|
if(lFlag) {
|
||||||
|
SelectPRGPage(0, prgBank & 0x3E);
|
||||||
|
SelectPRGPage(1, prgBank | 0x07);
|
||||||
|
} else {
|
||||||
|
SelectPRGPage(0, prgBank & 0x3E);
|
||||||
|
SelectPRGPage(1, prgBank & 0x38);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if(lFlag) {
|
||||||
|
SelectPRGPage(0, prgBank);
|
||||||
|
SelectPRGPage(1, prgBank | 0x07);
|
||||||
|
} else {
|
||||||
|
SelectPRGPage(0, prgBank);
|
||||||
|
SelectPRGPage(1, prgBank & 0x38);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
SetMirroringType((addr & 0x02) == 0x02 ? MirroringType::Horizontal : MirroringType::Vertical);
|
||||||
|
}
|
||||||
|
};
|
@ -42,6 +42,7 @@
|
|||||||
#include "Mapper218.h"
|
#include "Mapper218.h"
|
||||||
#include "Mapper225.h"
|
#include "Mapper225.h"
|
||||||
#include "Mapper226.h"
|
#include "Mapper226.h"
|
||||||
|
#include "Mapper227.h"
|
||||||
#include "Mapper230.h"
|
#include "Mapper230.h"
|
||||||
#include "Mapper231.h"
|
#include "Mapper231.h"
|
||||||
#include "Mapper240.h"
|
#include "Mapper240.h"
|
||||||
@ -242,6 +243,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 227: return new Mapper227();
|
||||||
case 228: return new ActionEnterprises();
|
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();
|
||||||
|
Loading…
Reference in New Issue
Block a user