mirror of
				https://github.com/RetroDECK/Duckstation.git
				synced 2025-04-10 19:15:14 +00:00 
			
		
		
		
	System: Use exe hash plus pvd hash for image hash code
This commit is contained in:
		
							parent
							
								
									a8a0a50af7
								
							
						
					
					
						commit
						14eecae680
					
				|  | @ -72,6 +72,7 @@ static bool SetExpansionROM(const char* filename); | ||||||
| /// Opens CD image, preloading if needed.
 | /// Opens CD image, preloading if needed.
 | ||||||
| static std::unique_ptr<CDImage> OpenCDImage(const char* path, Common::Error* error, bool force_preload, | static std::unique_ptr<CDImage> OpenCDImage(const char* path, Common::Error* error, bool force_preload, | ||||||
|                                             bool check_for_patches); |                                             bool check_for_patches); | ||||||
|  | static bool ReadExecutableFromImage(ISOReader& iso, std::string* out_executable_name, std::vector<u8>* out_executable_data); | ||||||
| static bool ShouldCheckForImagePatches(); | static bool ShouldCheckForImagePatches(); | ||||||
| 
 | 
 | ||||||
| static bool DoLoadState(ByteStream* stream, bool force_software_renderer, bool update_display); | static bool DoLoadState(ByteStream* stream, bool force_software_renderer, bool update_display); | ||||||
|  | @ -369,15 +370,23 @@ std::string GetGameCodeForImage(CDImage* cdi, bool fallback_to_hash) | ||||||
| 
 | 
 | ||||||
| std::string GetGameHashCodeForImage(CDImage* cdi) | std::string GetGameHashCodeForImage(CDImage* cdi) | ||||||
| { | { | ||||||
|  |   ISOReader iso; | ||||||
|  |   if (!iso.Open(cdi, 1)) | ||||||
|  |     return {}; | ||||||
|  | 
 | ||||||
|   std::string exe_name; |   std::string exe_name; | ||||||
|   std::vector<u8> exe_buffer; |   std::vector<u8> exe_buffer; | ||||||
|   if (!ReadExecutableFromImage(cdi, &exe_name, &exe_buffer)) |   if (!ReadExecutableFromImage(cdi, &exe_name, &exe_buffer)) | ||||||
|     return {}; |     return {}; | ||||||
| 
 | 
 | ||||||
|  |   const u32 track_1_length = cdi->GetTrackLength(1); | ||||||
|  | 
 | ||||||
|   XXH64_state_t* state = XXH64_createState(); |   XXH64_state_t* state = XXH64_createState(); | ||||||
|   XXH64_reset(state, 0x4242D00C); |   XXH64_reset(state, 0x4242D00C); | ||||||
|   XXH64_update(state, exe_name.c_str(), exe_name.size()); |   XXH64_update(state, exe_name.c_str(), exe_name.size()); | ||||||
|   XXH64_update(state, exe_buffer.data(), exe_buffer.size()); |   XXH64_update(state, exe_buffer.data(), exe_buffer.size()); | ||||||
|  |   XXH64_update(state, &iso.GetPVD(), sizeof(ISOReader::ISOPrimaryVolumeDescriptor)); | ||||||
|  |   XXH64_update(state, &track_1_length, sizeof(track_1_length)); | ||||||
|   const u64 hash = XXH64_digest(state); |   const u64 hash = XXH64_digest(state); | ||||||
|   XXH64_freeState(state); |   XXH64_freeState(state); | ||||||
| 
 | 
 | ||||||
|  | @ -385,7 +394,7 @@ std::string GetGameHashCodeForImage(CDImage* cdi) | ||||||
|   return StringUtil::StdStringFromFormat("HASH-%" PRIX64, hash); |   return StringUtil::StdStringFromFormat("HASH-%" PRIX64, hash); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static std::string GetExecutableNameForImage(CDImage* cdi, ISOReader& iso, bool strip_subdirectories) | static std::string GetExecutableNameForImage(ISOReader& iso, bool strip_subdirectories) | ||||||
| { | { | ||||||
|   // Read SYSTEM.CNF
 |   // Read SYSTEM.CNF
 | ||||||
|   std::vector<u8> system_cnf_data; |   std::vector<u8> system_cnf_data; | ||||||
|  | @ -478,18 +487,14 @@ std::string GetExecutableNameForImage(CDImage* cdi) | ||||||
|   if (!iso.Open(cdi, 1)) |   if (!iso.Open(cdi, 1)) | ||||||
|     return {}; |     return {}; | ||||||
| 
 | 
 | ||||||
|   return GetExecutableNameForImage(cdi, iso, true); |   return GetExecutableNameForImage(iso, true); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool ReadExecutableFromImage(CDImage* cdi, std::string* out_executable_name, std::vector<u8>* out_executable_data) | bool ReadExecutableFromImage(ISOReader& iso, std::string* out_executable_name, std::vector<u8>* out_executable_data) | ||||||
| { | { | ||||||
|   ISOReader iso; |  | ||||||
|   if (!iso.Open(cdi, 1)) |  | ||||||
|     return false; |  | ||||||
| 
 |  | ||||||
|   bool result = false; |   bool result = false; | ||||||
| 
 | 
 | ||||||
|   std::string executable_path(GetExecutableNameForImage(cdi, iso, false)); |   std::string executable_path(GetExecutableNameForImage(iso, false)); | ||||||
|   Log_DevPrintf("Executable path: '%s'", executable_path.c_str()); |   Log_DevPrintf("Executable path: '%s'", executable_path.c_str()); | ||||||
|   if (!executable_path.empty()) |   if (!executable_path.empty()) | ||||||
|   { |   { | ||||||
|  | @ -516,6 +521,15 @@ bool ReadExecutableFromImage(CDImage* cdi, std::string* out_executable_name, std | ||||||
|   return true; |   return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | bool ReadExecutableFromImage(CDImage* cdi, std::string* out_executable_name, std::vector<u8>* out_executable_data) | ||||||
|  | { | ||||||
|  |   ISOReader iso; | ||||||
|  |   if (!iso.Open(cdi, 1)) | ||||||
|  |     return false; | ||||||
|  | 
 | ||||||
|  |   return ReadExecutableFromImage(iso, out_executable_name, out_executable_data); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| DiscRegion GetRegionForCode(std::string_view code) | DiscRegion GetRegionForCode(std::string_view code) | ||||||
| { | { | ||||||
|   std::string prefix; |   std::string prefix; | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Connor McLaughlin
						Connor McLaughlin