movie.cpp:

- Fix a buffer overrun bug by disabling reading the ROM checksum in .dsm files for now. (Reading the checksum doesn't work correctly anyways, and nothing currently uses it in practice.)
This commit is contained in:
rogerman 2012-08-24 23:09:08 +00:00
parent 58faffaa26
commit 6e9a041176
1 changed files with 10 additions and 2 deletions

View File

@ -224,8 +224,16 @@ void MovieData::installValue(std::string& key, std::string& val)
installInt(val,rerecordCount); installInt(val,rerecordCount);
else if(key == "romFilename") else if(key == "romFilename")
romFilename = val; romFilename = val;
else if(key == "romChecksum") else if(key == "romChecksum") {
StringToBytes(val,&romChecksum,MD5DATA::size); // TODO: The current implementation of reading the checksum doesn't work correctly, and can
// cause crashes when the MovieData object is deallocated. (This is caused by StringToBytes()
// overrunning romChecksum into romSerial, making romSerial undefined.) Set romChecksum to
// some dummy value for now to prevent crashing. This is okay, since romChecksum isn't actually
// used in practice at this time. - rogerman, 2012/08/24
//StringToBytes(val,&romChecksum,MD5DATA::size);
romChecksum = 0;
}
else if(key == "romSerial") else if(key == "romSerial")
romSerial = val; romSerial = val;
else if(key == "guid") else if(key == "guid")