Add support for misc rom area

This commit is contained in:
negative 2024-01-07 21:59:25 +08:00
parent b53d087fca
commit 647c08e1e6
No known key found for this signature in database
2 changed files with 19 additions and 1 deletions

View File

@ -49,6 +49,7 @@ extern SFORMAT FCEUVSUNI_STATEINFO[];
uint8 *trainerpoo = NULL; uint8 *trainerpoo = NULL;
uint8 *ROM = NULL; uint8 *ROM = NULL;
uint8 *VROM = NULL; uint8 *VROM = NULL;
uint8 *MiscROM = NULL;
uint8 *ExtraNTARAM = NULL; uint8 *ExtraNTARAM = NULL;
iNES_HEADER head; iNES_HEADER head;
@ -58,6 +59,7 @@ uint8 Mirroring = 0;
uint8 MirroringAs2bits = 0; uint8 MirroringAs2bits = 0;
uint32 ROM_size = 0; uint32 ROM_size = 0;
uint32 VROM_size = 0; uint32 VROM_size = 0;
uint32 MiscROM_size = 0;
char LoadedRomFName[4096]; //mbg merge 7/17/06 added char LoadedRomFName[4096]; //mbg merge 7/17/06 added
char LoadedRomFNamePatchToUse[4096]; char LoadedRomFNamePatchToUse[4096];
@ -806,9 +808,12 @@ int iNESLoad(const char *name, FCEUFILE *fp, int OverwriteVidMode) {
struct md5_context md5; struct md5_context md5;
uint64 partialmd5 = 0; uint64 partialmd5 = 0;
const char* mappername = "Not Listed"; const char* mappername = "Not Listed";
size_t filesize = FCEU_fgetsize(fp);
if (FCEU_fread(&head, 1, 16, fp) != 16 || memcmp(&head, "NES\x1A", 4)) if (FCEU_fread(&head, 1, 16, fp) != 16 || memcmp(&head, "NES\x1A", 4))
return LOADER_INVALID_FORMAT; return LOADER_INVALID_FORMAT;
// Remove header size from filesize
filesize -= 16;
head.cleanup(); head.cleanup();
@ -946,6 +951,7 @@ int iNESLoad(const char *name, FCEUFILE *fp, int OverwriteVidMode) {
if (head.ROM_type & 4) { /* Trainer */ if (head.ROM_type & 4) { /* Trainer */
trainerpoo = (uint8*)FCEU_gmalloc(512); trainerpoo = (uint8*)FCEU_gmalloc(512);
FCEU_fread(trainerpoo, 512, 1, fp); FCEU_fread(trainerpoo, 512, 1, fp);
filesize -= 512;
} }
ResetCartMapping(); ResetCartMapping();
@ -958,6 +964,15 @@ int iNESLoad(const char *name, FCEUFILE *fp, int OverwriteVidMode) {
if (vrom_size_bytes) if (vrom_size_bytes)
FCEU_fread(VROM, 1, vrom_size_bytes, fp); FCEU_fread(VROM, 1, vrom_size_bytes, fp);
// Misc ROMS
if ((head.misc_roms & 0x03) && !(head.ROM_type & 4)) {
MiscROM_size = filesize - rom_size_bytes - vrom_size_bytes;
MiscROM = (uint8 *)FCEU_malloc(MiscROM_size);
memset(MiscROM, 0xFF, MiscROM_size);
FCEU_fread(MiscROM, 1, MiscROM_size, fp);
FCEU_printf(" Misc ROM size : %d\n", MiscROM_size);
}
md5_starts(&md5); md5_starts(&md5);
md5_update(&md5, ROM, rom_size_bytes); md5_update(&md5, ROM, rom_size_bytes);
@ -1008,6 +1023,7 @@ int iNESLoad(const char *name, FCEUFILE *fp, int OverwriteVidMode) {
FCEU_printf(" WRAM backed by battery: %d KiB\n", iNESCart.battery_wram_size / 1024); FCEU_printf(" WRAM backed by battery: %d KiB\n", iNESCart.battery_wram_size / 1024);
FCEU_printf(" VRAM backed by battery: %d KiB\n", iNESCart.battery_vram_size / 1024); FCEU_printf(" VRAM backed by battery: %d KiB\n", iNESCart.battery_vram_size / 1024);
} }
if (head.misc_roms & 0x03) FCEU_printf(" Misc ROM: %d KiB\n", MiscROM_size / 1024);
} }
SetInput(); SetInput();

View File

@ -42,8 +42,10 @@ public:
//mbg merge 6/29/06 //mbg merge 6/29/06
extern uint8 *ROM; extern uint8 *ROM;
extern uint8 *VROM; extern uint8 *VROM;
extern uint8 *MiscROM;
extern uint32 VROM_size; extern uint32 VROM_size;
extern uint32 ROM_size; extern uint32 ROM_size;
extern uint32 MiscROM_size;
extern uint8 *ExtraNTARAM; extern uint8 *ExtraNTARAM;
extern uint8 **VPageR; extern uint8 **VPageR;
extern int iNesSave(void); //bbit Edited: line added extern int iNesSave(void); //bbit Edited: line added