forked from eden-emu/eden
		
	Fix GCC undefined behavior sanitizer.
* Wrong alignment in u64 LOG_DEBUG -> memcpy. * Huge shift exponent in stride calculation for linear buffer, unused result -> skipped. * Large shift in buffer cache if word = 0, skip checking for set bits. Non of those were critical, so this should not change any behavior. At least with the assumption, that the last one used masking behavior, which always yield continuous_bits = 0.
This commit is contained in:
		
							parent
							
								
									fa8a0065ca
								
							
						
					
					
						commit
						6755025310
					
				
					 3 changed files with 9 additions and 1 deletions
				
			
		|  | @ -150,7 +150,9 @@ void ProgramMetadata::Print() const { | |||
|     LOG_DEBUG(Service_FS, " > Is Retail:           {}", acid_header.is_retail ? "YES" : "NO"); | ||||
|     LOG_DEBUG(Service_FS, "Title ID Min:           0x{:016X}", acid_header.title_id_min); | ||||
|     LOG_DEBUG(Service_FS, "Title ID Max:           0x{:016X}", acid_header.title_id_max); | ||||
|     LOG_DEBUG(Service_FS, "Filesystem Access:      0x{:016X}\n", acid_file_access.permissions); | ||||
|     u64_le permissions_l; // local copy to fix alignment error
 | ||||
|     std::memcpy(&permissions_l, &acid_file_access.permissions, sizeof(permissions_l)); | ||||
|     LOG_DEBUG(Service_FS, "Filesystem Access:      0x{:016X}\n", permissions_l); | ||||
| 
 | ||||
|     // Begin ACI0 printing (actual perms, unsigned)
 | ||||
|     LOG_DEBUG(Service_FS, "Magic:                  {:.4}", aci_header.magic.data()); | ||||
|  |  | |||
|  | @ -476,6 +476,9 @@ private: | |||
|                     current_size = 0; | ||||
|                     on_going = false; | ||||
|                 } | ||||
|                 if (empty_bits == PAGES_PER_WORD) { | ||||
|                     break; | ||||
|                 } | ||||
|                 page += empty_bits; | ||||
| 
 | ||||
|                 const int continuous_bits = std::countr_one(word >> page); | ||||
|  |  | |||
|  | @ -647,6 +647,9 @@ u32 CalculateLayerSize(const ImageInfo& info) noexcept { | |||
| } | ||||
| 
 | ||||
| LevelArray CalculateMipLevelOffsets(const ImageInfo& info) noexcept { | ||||
|     if (info.type == ImageType::Linear) { | ||||
|         return {}; | ||||
|     } | ||||
|     ASSERT(info.resources.levels <= static_cast<s32>(MAX_MIP_LEVELS)); | ||||
|     const LevelInfo level_info = MakeLevelInfo(info); | ||||
|     LevelArray offsets{}; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Markus Wick
						Markus Wick