Cocoa Port:

- Fix crash when loading invalid ROM header data.
This commit is contained in:
rogerman 2015-11-15 06:08:32 +00:00
parent 4d32f051ab
commit a738364416
4 changed files with 86 additions and 23 deletions

View File

@ -26,6 +26,7 @@
#include "utils/decrypt/decrypt.h" #include "utils/decrypt/decrypt.h"
#include "utils/decrypt/crc.h" #include "utils/decrypt/crc.h"
#include "utils/decrypt/header.h"
#include "utils/advanscene.h" #include "utils/advanscene.h"
#include "utils/task.h" #include "utils/task.h"
@ -308,6 +309,50 @@ const RomBanner& GameInfo::getRomBanner()
return banner; return banner;
} }
bool GameInfo::ValidateHeader()
{
bool isRomValid = false;
// Validate the ROM type.
int detectedRomType = DetectRomType(*(Header *)&header, (char *)secureArea);
if (detectedRomType == ROMTYPE_INVALID)
{
printf("ROM Validation: Invalid ROM type detected.\n");
return isRomValid;
}
// Ensure that the game title and game code are both clean ASCII, but also
// make an exception for homebrew ROMs, which may not always have clean
// headers to begin with.
if (detectedRomType != ROMTYPE_HOMEBREW)
{
for (size_t i = 0; i < 12; i++)
{
char c = (char)header.gameTile[i];
if (c < 0 || (c > 0 && c < 32) || c == 127)
{
printf("ROM Validation: Invalid character detected in ROM Title.\n");
printf(" charIndex = %d, charValue = %d\n", (int)i, c);
return isRomValid;
}
}
for (size_t i = 0; i < 4; i++)
{
char c = (char)header.gameCode[i];
if (c < 0 || (c > 0 && c < 32) || c == 127)
{
printf("ROM Validation: Invalid character detected in ROM Game Code.\n");
printf(" charIndex = %d, charValue = %d\n", (int)i, c);
return isRomValid;
}
}
}
isRomValid = true;
return isRomValid;
}
void GameInfo::populate() void GameInfo::populate()
{ {
const char regions_index[] = "JPFSEODIRKHXVWUC"; const char regions_index[] = "JPFSEODIRKHXVWUC";
@ -657,17 +702,14 @@ int NDS_LoadROM(const char *filename, const char *physicalName, const char *logi
cheatSearch->close(); cheatSearch->close();
FCEUI_StopMovie(); FCEUI_StopMovie();
if (!gameInfo.ValidateHeader())
//check whether this rom is any kind of valid
if(!CheckValidRom((u8*)&gameInfo.header, gameInfo.secureArea))
{ {
printf("Specified file is not a valid rom\n"); ret = -1;
return -1; return ret;
} }
gameInfo.populate(); gameInfo.populate();
if (CommonSettings.loadToMemory) if (CommonSettings.loadToMemory)
gameInfo.crc = crc32(0, (u8*)gameInfo.romdata, gameInfo.romsize); gameInfo.crc = crc32(0, (u8*)gameInfo.romdata, gameInfo.romsize);
else else

View File

@ -353,6 +353,7 @@ struct GameInfo
bool loadROM(std::string fname, u32 type = ROM_NDS); bool loadROM(std::string fname, u32 type = ROM_NDS);
void closeROM(); void closeROM();
u32 readROM(u32 pos); u32 readROM(u32 pos);
bool ValidateHeader();
void populate(); void populate();
bool isDSiEnhanced(); bool isDSiEnhanced();
bool isHomebrew(); bool isHomebrew();

View File

@ -46,7 +46,7 @@
- (id) initWithURL:(NSURL *)theURL; - (id) initWithURL:(NSURL *)theURL;
- (id) initWithURL:(NSURL *)theURL saveType:(NSInteger)saveTypeID; - (id) initWithURL:(NSURL *)theURL saveType:(NSInteger)saveTypeID;
- (id) initWithURL:(NSURL *)theURL saveType:(NSInteger)saveTypeID streamLoadData:(BOOL)willStreamLoad; - (id) initWithURL:(NSURL *)theURL saveType:(NSInteger)saveTypeID streamLoadData:(BOOL)willStreamLoad;
- (void) initHeader; - (BOOL) initHeader;
- (BOOL) loadData:(NSURL *)theURL; - (BOOL) loadData:(NSURL *)theURL;
- (void) loadDataOnThread:(id)object; - (void) loadDataOnThread:(id)object;
- (NSString *) title; - (NSString *) title;

View File

@ -141,14 +141,16 @@ static NSMutableDictionary *saveTypeValues = nil;
return (gameInfo.romdata != NULL); return (gameInfo.romdata != NULL);
} }
- (void) initHeader - (BOOL) initHeader
{ {
BOOL result = NO;
const NDS_header *ndsRomHeader = NDS_getROMHeader(); const NDS_header *ndsRomHeader = NDS_getROMHeader();
const RomBanner &ndsRomBanner = gameInfo.getRomBanner(); const RomBanner &ndsRomBanner = gameInfo.getRomBanner();
if(self.header == nil || self.bindings == nil) if (self.header == nil || self.bindings == nil)
{ {
return; return result;
} }
[self.header setValue:[self banner:ndsRomBanner.titles[0]] forKey:@"bannerJapanese"]; [self.header setValue:[self banner:ndsRomBanner.titles[0]] forKey:@"bannerJapanese"];
@ -218,12 +220,21 @@ static NSMutableDictionary *saveTypeValues = nil;
NSImage *iconImage = [self icon]; NSImage *iconImage = [self icon];
if (iconImage != nil) if (iconImage != nil)
{ {
[header setObject:iconImage forKey:@"iconImage"]; [self.header setObject:iconImage forKey:@"iconImage"];
[self.bindings setObject:(NSImage *)[self.header objectForKey:@"iconImage"] forKey:@"iconImage"]; [self.bindings setObject:(NSImage *)[self.header objectForKey:@"iconImage"] forKey:@"iconImage"];
} }
[self.header setValue:[self internalName] forKey:@"romInternalName"]; NSString *internalNameString = [self internalName];
[self.header setValue:[self serial] forKey:@"romSerial"]; NSString *serialString = [self serial];
if (internalNameString == nil || serialString == nil)
{
return result;
}
else
{
[self.header setValue:internalNameString forKey:@"romInternalName"];
[self.header setValue:serialString forKey:@"romSerial"];
[self.bindings setValue:[self.header objectForKey:@"romInternalName"] forKey:@"romInternalName"]; [self.bindings setValue:[self.header objectForKey:@"romInternalName"] forKey:@"romInternalName"];
[self.bindings setValue:[self.header objectForKey:@"romSerial"] forKey:@"romSerial"]; [self.bindings setValue:[self.header objectForKey:@"romSerial"] forKey:@"romSerial"];
@ -232,6 +243,10 @@ static NSMutableDictionary *saveTypeValues = nil;
romNameAndSerialInfoString = [romNameAndSerialInfoString stringByAppendingString:[self.header objectForKey:@"romInternalName"]]; romNameAndSerialInfoString = [romNameAndSerialInfoString stringByAppendingString:[self.header objectForKey:@"romInternalName"]];
romNameAndSerialInfoString = [[romNameAndSerialInfoString stringByAppendingString:@"\nSerial: "] stringByAppendingString:[self.header objectForKey:@"romSerial"]]; romNameAndSerialInfoString = [[romNameAndSerialInfoString stringByAppendingString:@"\nSerial: "] stringByAppendingString:[self.header objectForKey:@"romSerial"]];
[self.bindings setValue:romNameAndSerialInfoString forKey:@"romNameAndSerialInfo"]; [self.bindings setValue:romNameAndSerialInfoString forKey:@"romNameAndSerialInfo"];
}
result = YES;
return result;
} }
- (BOOL) loadData:(NSURL *)theURL - (BOOL) loadData:(NSURL *)theURL
@ -239,6 +254,12 @@ static NSMutableDictionary *saveTypeValues = nil;
[CocoaDSRom changeRomSaveType:saveType]; [CocoaDSRom changeRomSaveType:saveType];
BOOL result = [CocoaDSFile loadRom:theURL]; BOOL result = [CocoaDSFile loadRom:theURL];
if (result)
{
result = [self initHeader];
}
if (!result) if (!result)
{ {
NSDictionary *userInfo = [[NSDictionary alloc] initWithObjectsAndKeys:[NSNumber numberWithBool:NO], @"DidLoad", nil]; NSDictionary *userInfo = [[NSDictionary alloc] initWithObjectsAndKeys:[NSNumber numberWithBool:NO], @"DidLoad", nil];
@ -248,7 +269,6 @@ static NSMutableDictionary *saveTypeValues = nil;
} }
fileURL = [theURL copy]; fileURL = [theURL copy];
[self initHeader];
NSString *advscDBPath = [[NSUserDefaults standardUserDefaults] stringForKey:@"Advanscene_DatabasePath"]; NSString *advscDBPath = [[NSUserDefaults standardUserDefaults] stringForKey:@"Advanscene_DatabasePath"];
if (advscDBPath != nil) if (advscDBPath != nil)