mirror of
				https://git.suyu.dev/suyu/suyu.git
				synced 2025-10-31 06:46:40 +08:00 
			
		
		
		
	video_core: rasterizer_accelerated: Improve error handling & fix implicit conversion.
This commit is contained in:
		
							parent
							
								
									94da1e8a7e
								
							
						
					
					
						commit
						6ab839462c
					
				| @ -20,9 +20,15 @@ void RasterizerAccelerated::UpdatePagesCachedCount(VAddr addr, u64 size, int del | |||||||
|     for (auto page = addr >> Core::Memory::PAGE_BITS; page != page_end; ++page) { |     for (auto page = addr >> Core::Memory::PAGE_BITS; page != page_end; ++page) { | ||||||
|         auto& count = cached_pages.at(page >> 3).Count(page); |         auto& count = cached_pages.at(page >> 3).Count(page); | ||||||
| 
 | 
 | ||||||
|         ASSERT_MSG(count < UINT8_MAX, "Count may exceed UINT8_MAX!"); |         if (delta < 0) { | ||||||
|  |             ASSERT_MSG(count > 0, "Count may underflow!"); | ||||||
|  |         } else if (delta > 0) { | ||||||
|  |             ASSERT_MSG(count < UINT8_MAX, "Count may overflow!"); | ||||||
|  |         } else { | ||||||
|  |             ASSERT_MSG(true, "Delta must be non-zero!"); | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|         count += delta; |         count += static_cast<s8>(delta); | ||||||
| 
 | 
 | ||||||
|         // Assume delta is either -1 or 1
 |         // Assume delta is either -1 or 1
 | ||||||
|         if (count == 0) { |         if (count == 0) { | ||||||
| @ -31,8 +37,6 @@ void RasterizerAccelerated::UpdatePagesCachedCount(VAddr addr, u64 size, int del | |||||||
|         } else if (count == 1 && delta > 0) { |         } else if (count == 1 && delta > 0) { | ||||||
|             cpu_memory.RasterizerMarkRegionCached(page << Core::Memory::PAGE_BITS, |             cpu_memory.RasterizerMarkRegionCached(page << Core::Memory::PAGE_BITS, | ||||||
|                                                   Core::Memory::PAGE_SIZE, true); |                                                   Core::Memory::PAGE_SIZE, true); | ||||||
|         } else { |  | ||||||
|             ASSERT(count >= 0); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user