Add 3DS firmware handling
This commit is contained in:
parent
739c35c174
commit
41ee99999a
|
@ -166,7 +166,20 @@ namespace BizHawk.Emulation.Common
|
|||
FirmwareAndOption(SHA1Checksum.Dummy, 251658240 + 64, "NDS", "NAND (KOR)", "DSi_Nand_KOR.bin", "DSi NAND (Korea)");
|
||||
|
||||
FirmwareAndOption("5A3D3D6DF4743E6B50AFE0FC717FA8A12BC888E6", 65536, "3DS", "boot9", "3DS_Boot9.bin", "ARM9 BIOS");
|
||||
// TODO: need to add more 3DS crap...
|
||||
FirmwareAndOption("B9CFA84916A930D272250130D67CEB822141177D", 512, "3DS", "sector0x96", "sector0x96.bin", "Secret Section");
|
||||
// bleh, undefined hash AND size...
|
||||
FirmwareAndOption(SHA1Checksum.Dummy, 0, "3DS", "seeddb", "seeddb.bin", "SEEDDB");
|
||||
|
||||
Firmware("3DS", "NATIVE_FIRM", "3DS Native Firmware");
|
||||
// TODO: add the other 26 native firmware versions!!!
|
||||
var o3ds_nf_v27476 = File("4DBEB23726B1516FE7B4691BA8DB5602FE49CDA0", 984320, "0004013800000002.cia", "3DS Native Firmware (11.3.0-36)");
|
||||
Option("3DS", "NATIVE_FIRM", in o3ds_nf_v27476, FirmwareOptionStatus.Ideal);
|
||||
Firmware("3DS", "SAFE_MODE_FIRM", "3DS Safe Mode Firmware");
|
||||
var o3ds_smf_v432 = File("58732AA986BCC7570AC63A1BB2B6865CC6DE215E", 861440, "0004013800000003.cia", "3DS Safe Mode Firmware (1.0.0-0)");
|
||||
var o3ds_smf_v5632 = File("0FD265D5CF251E70EAC455C91DAD39447EDEEA57", 861440, "0004013800000003.cia", "3DS Safe Mode Firmware (3.0.0-5)");
|
||||
Option("3DS", "SAFE_MODE_FIRM", in o3ds_smf_v432);
|
||||
Option("3DS", "SAFE_MODE_FIRM", in o3ds_smf_v5632, FirmwareOptionStatus.Ideal);
|
||||
FirmwareAndOption("2C25467FA2FADB73EB3A137072643C65033B0483", 1012992, "3DS", "N3DS_SAFE_MODE_FIRM", "0004013820000003.cia", "New 3DS Safe Mode Firmware");
|
||||
|
||||
FirmwareAndOption("E4ED47FAE31693E016B081C6BDA48DA5B70D7CCB", 512, "Lynx", "Boot", "LYNX_boot.img", "Boot Rom");
|
||||
|
||||
|
|
|
@ -14,7 +14,7 @@ namespace BizHawk.Emulation.Cores.Consoles.Nintendo._3DS
|
|||
{
|
||||
private CitraSettings _settings;
|
||||
private CitraSyncSettings _syncSettings;
|
||||
private string _userPath;
|
||||
private readonly string _userPath;
|
||||
|
||||
private bool GetBooleanSettingCallback(string label) => label switch
|
||||
{
|
||||
|
@ -189,8 +189,6 @@ namespace BizHawk.Emulation.Cores.Consoles.Nintendo._3DS
|
|||
LargeScreen,
|
||||
SideScreen,
|
||||
HybridScreen = 5,
|
||||
MobilePortrait,
|
||||
MobileLandscape,
|
||||
}
|
||||
|
||||
[DisplayName("Layout Option")]
|
||||
|
|
|
@ -10,7 +10,7 @@ using BizHawk.Emulation.Common;
|
|||
|
||||
namespace BizHawk.Emulation.Cores.Consoles.Nintendo._3DS
|
||||
{
|
||||
[PortedCore(CoreNames.Citra, "Citra Emulator Project", "nightly-1943", "https://citra-emu.org", singleInstance: true, isReleased: false)]
|
||||
[PortedCore(CoreNames.Citra, "Citra Emulator Project", "nightly-1953", "https://citra-emu.org", singleInstance: true, isReleased: false)]
|
||||
[ServiceNotApplicable(new[] { typeof(IDriveLight), typeof(IRegionable) })]
|
||||
public partial class Citra
|
||||
{
|
||||
|
@ -94,6 +94,41 @@ namespace BizHawk.Emulation.Cores.Consoles.Nintendo._3DS
|
|||
File.WriteAllBytes(Path.Combine(_userPath, "sysdata", "boot9.bin"), boot9);
|
||||
}
|
||||
|
||||
var sector0x96 = lp.Comm.CoreFileProvider.GetFirmware(new("3DS", "sector0x96"));
|
||||
if (sector0x96 is not null)
|
||||
{
|
||||
File.WriteAllBytes(Path.Combine(_userPath, "sysdata", "sector0x96.bin"), sector0x96);
|
||||
}
|
||||
|
||||
var seeddb = lp.Comm.CoreFileProvider.GetFirmware(new("3DS", "seeddb"));
|
||||
if (seeddb is not null)
|
||||
{
|
||||
File.WriteAllBytes(Path.Combine(_userPath, "sysdata", "seeddb.bin"), seeddb);
|
||||
}
|
||||
|
||||
void InstallFirmCia(string firmName)
|
||||
{
|
||||
var firm = lp.Comm.CoreFileProvider.GetFirmware(new("3DS", firmName));
|
||||
if (firm is not null)
|
||||
{
|
||||
var firmCia = TempFileManager.GetTempFilename(firmName, ".cia", false);
|
||||
try
|
||||
{
|
||||
File.WriteAllBytes(firmCia, firm);
|
||||
var message = new byte[1024];
|
||||
_core.Citra_InstallCIA(_context, firmCia, true, message, message.Length);
|
||||
}
|
||||
finally
|
||||
{
|
||||
TempFileManager.RenameTempFilenameForDelete(firmCia);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
InstallFirmCia("NATIVE_FIRM");
|
||||
InstallFirmCia("SAFE_MODE_FIRM");
|
||||
InstallFirmCia("N3DS_SAFE_MODE_FIRM");
|
||||
|
||||
var romPath = lp.Roms[0].RomPath;
|
||||
if (lp.Roms[0].Extension.ToLowerInvariant() == ".cia")
|
||||
{
|
||||
|
|
Loading…
Reference in New Issue