UNIF: Added support for BMC-60311C boards
This commit is contained in:
parent
b5d460ffb3
commit
86231c94e3
6 changed files with 91 additions and 0 deletions
83
Core/Bmc60311C.h
Normal file
83
Core/Bmc60311C.h
Normal file
|
@ -0,0 +1,83 @@
|
||||||
|
#pragma once
|
||||||
|
#include "stdafx.h"
|
||||||
|
#include "BaseMapper.h"
|
||||||
|
|
||||||
|
class Bmc60311C : public BaseMapper
|
||||||
|
{
|
||||||
|
private:
|
||||||
|
uint8_t _innerPrg;
|
||||||
|
uint8_t _outerPrg;
|
||||||
|
uint8_t _mode;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
uint16_t GetPRGPageSize() override { return 0x4000; }
|
||||||
|
uint16_t GetCHRPageSize() override { return 0x2000; }
|
||||||
|
uint16_t RegisterStartAddress() override { return 0x6000; }
|
||||||
|
uint16_t RegisterEndAddress() override { return 0xFFFF; }
|
||||||
|
|
||||||
|
void InitMapper() override
|
||||||
|
{
|
||||||
|
_innerPrg = 0;
|
||||||
|
_outerPrg = 0;
|
||||||
|
_mode = 0;
|
||||||
|
|
||||||
|
UpdateState();
|
||||||
|
SelectCHRPage(0, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
void StreamState(bool saving) override
|
||||||
|
{
|
||||||
|
BaseMapper::StreamState(saving);
|
||||||
|
Stream(_innerPrg, _outerPrg, _mode);
|
||||||
|
}
|
||||||
|
|
||||||
|
void UpdateState()
|
||||||
|
{
|
||||||
|
uint8_t page = _outerPrg | ((_mode & 0x04) ? 0 : _innerPrg);
|
||||||
|
|
||||||
|
switch(_mode & 0x03) {
|
||||||
|
case 0:
|
||||||
|
//0: NROM-128: Same inner/outer 16 KiB bank at CPU $8000-$BFFF and $C000-$FFFF
|
||||||
|
SelectPRGPage(0, page);
|
||||||
|
SelectPRGPage(1, page);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 1:
|
||||||
|
//1: NROM-256: 32 kiB bank at CPU $8000-$FFFF (Selected inner/outer bank SHR 1)
|
||||||
|
SelectPrgPage2x(0, page & 0xFE);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 2:
|
||||||
|
//2: UNROM: Inner/outer bank at CPU $8000-BFFF, fixed inner bank 7 within outer bank at $C000-$FFFF
|
||||||
|
SelectPRGPage(0, page);
|
||||||
|
SelectPRGPage(1, _outerPrg | 7);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 3:
|
||||||
|
//Unknown
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
SetMirroringType(_mode & 0x08 ? MirroringType::Horizontal : MirroringType::Vertical);
|
||||||
|
}
|
||||||
|
|
||||||
|
void WriteRegister(uint16_t addr, uint8_t value) override
|
||||||
|
{
|
||||||
|
if(addr >= 0x8000) {
|
||||||
|
_innerPrg = value & 0x07;
|
||||||
|
UpdateState();
|
||||||
|
} else {
|
||||||
|
switch(addr & 0xE001) {
|
||||||
|
case 0x6000:
|
||||||
|
_mode = value & 0x0F;
|
||||||
|
UpdateState();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 0x6001:
|
||||||
|
_outerPrg = value;
|
||||||
|
UpdateState();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
|
@ -518,6 +518,7 @@
|
||||||
<ClInclude Include="BaseSoundManager.h" />
|
<ClInclude Include="BaseSoundManager.h" />
|
||||||
<ClInclude Include="BatteryManager.h" />
|
<ClInclude Include="BatteryManager.h" />
|
||||||
<ClInclude Include="BattleBox.h" />
|
<ClInclude Include="BattleBox.h" />
|
||||||
|
<ClInclude Include="Bmc60311C.h" />
|
||||||
<ClInclude Include="Bmc80013B.h" />
|
<ClInclude Include="Bmc80013B.h" />
|
||||||
<ClInclude Include="Bmc8157.h" />
|
<ClInclude Include="Bmc8157.h" />
|
||||||
<ClInclude Include="Bmc830118C.h" />
|
<ClInclude Include="Bmc830118C.h" />
|
||||||
|
|
|
@ -1453,6 +1453,9 @@
|
||||||
<ClInclude Include="IMemoryManager.h">
|
<ClInclude Include="IMemoryManager.h">
|
||||||
<Filter>Nes\MemoryManager</Filter>
|
<Filter>Nes\MemoryManager</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
<ClInclude Include="Bmc60311C.h">
|
||||||
|
<Filter>Nes\Mappers\Unif</Filter>
|
||||||
|
</ClInclude>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClCompile Include="stdafx.cpp">
|
<ClCompile Include="stdafx.cpp">
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
#include "Bmc190in1.h"
|
#include "Bmc190in1.h"
|
||||||
#include "Bmc235.h"
|
#include "Bmc235.h"
|
||||||
#include "Bmc255.h"
|
#include "Bmc255.h"
|
||||||
|
#include "Bmc60311C.h"
|
||||||
#include "Bmc8157.h"
|
#include "Bmc8157.h"
|
||||||
#include "Bmc80013B.h"
|
#include "Bmc80013B.h"
|
||||||
#include "Bmc810544CA1.h"
|
#include "Bmc810544CA1.h"
|
||||||
|
@ -544,6 +545,7 @@ BaseMapper* MapperFactory::GetMapperFromID(RomData &romData)
|
||||||
case UnifBoards::Bmc70in1: return new Bmc70in1();
|
case UnifBoards::Bmc70in1: return new Bmc70in1();
|
||||||
case UnifBoards::Bmc70in1B: return new Bmc70in1();
|
case UnifBoards::Bmc70in1B: return new Bmc70in1();
|
||||||
case UnifBoards::Bmc190in1: return new Bmc190in1();
|
case UnifBoards::Bmc190in1: return new Bmc190in1();
|
||||||
|
case UnifBoards::Bmc60311C: return new Bmc60311C();
|
||||||
case UnifBoards::Bmc810544CA1: return new Bmc810544CA1();
|
case UnifBoards::Bmc810544CA1: return new Bmc810544CA1();
|
||||||
case UnifBoards::Bmc830118C: return new Bmc830118C();
|
case UnifBoards::Bmc830118C: return new Bmc830118C();
|
||||||
case UnifBoards::Bmc80013B: return new Bmc80013B();
|
case UnifBoards::Bmc80013B: return new Bmc80013B();
|
||||||
|
|
|
@ -72,5 +72,6 @@ namespace UnifBoards {
|
||||||
BmcGn45,
|
BmcGn45,
|
||||||
UnlDripGame,
|
UnlDripGame,
|
||||||
SssNrom256,
|
SssNrom256,
|
||||||
|
Bmc60311C,
|
||||||
};
|
};
|
||||||
}
|
}
|
|
@ -161,4 +161,5 @@ std::unordered_map<string, int> UnifLoader::_boardMappings = std::unordered_map<
|
||||||
{ "HPxx", UnifBoards::BmcHpxx },
|
{ "HPxx", UnifBoards::BmcHpxx },
|
||||||
{ "GN-45", UnifBoards::BmcGn45 }, //Doesn't actually exist as a UNIF file (used to assign a mapper to GN-45 boards)
|
{ "GN-45", UnifBoards::BmcGn45 }, //Doesn't actually exist as a UNIF file (used to assign a mapper to GN-45 boards)
|
||||||
{ "DRIPGAME", UnifBoards::UnlDripGame },
|
{ "DRIPGAME", UnifBoards::UnlDripGame },
|
||||||
|
{ "60311C", UnifBoards::Bmc60311C },
|
||||||
};
|
};
|
Loading…
Add table
Reference in a new issue