forked from eden-emu/eden
		
	rasterizer_cache: Reintroduce method for flushing.
This commit is contained in:
		
							parent
							
								
									5ec58fa78f
								
							
						
					
					
						commit
						a8c8207341
					
				
					 3 changed files with 23 additions and 0 deletions
				
			
		|  | @ -17,6 +17,22 @@ | |||
| template <class T> | ||||
| class RasterizerCache : NonCopyable { | ||||
| public: | ||||
|     /// Write any cached resources overlapping the region back to memory (if dirty)
 | ||||
|     void FlushRegion(Tegra::GPUVAddr addr, size_t size) { | ||||
|         if (size == 0) | ||||
|             return; | ||||
| 
 | ||||
|         const ObjectInterval interval{addr, addr + size}; | ||||
|         for (auto& pair : boost::make_iterator_range(object_cache.equal_range(interval))) { | ||||
|             for (auto& cached_object : pair.second) { | ||||
|                 if (!cached_object) | ||||
|                     continue; | ||||
| 
 | ||||
|                 cached_object->Flush(); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     /// Mark the specified region as being invalidated
 | ||||
|     void InvalidateRegion(VAddr addr, u64 size) { | ||||
|         if (size == 0) | ||||
|  | @ -71,6 +87,7 @@ protected: | |||
|     void Unregister(const T& object) { | ||||
|         auto& rasterizer = Core::System::GetInstance().Renderer().Rasterizer(); | ||||
|         rasterizer.UpdatePagesCachedCount(object->GetAddr(), object->GetSizeInBytes(), -1); | ||||
|         object->Flush(); | ||||
|         object_cache.subtract({GetInterval(object), ObjectSet{object}}); | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -24,6 +24,9 @@ struct CachedBufferEntry final { | |||
|         return size; | ||||
|     } | ||||
| 
 | ||||
|     // We do not have to flush this cache as things in it are never modified by us.
 | ||||
|     void Flush() {} | ||||
| 
 | ||||
|     VAddr addr; | ||||
|     std::size_t size; | ||||
|     GLintptr offset; | ||||
|  |  | |||
|  | @ -33,6 +33,9 @@ public: | |||
|         return GLShader::MAX_PROGRAM_CODE_LENGTH * sizeof(u64); | ||||
|     } | ||||
| 
 | ||||
|     // We do not have to flush this cache as things in it are never modified by us.
 | ||||
|     void Flush() {} | ||||
| 
 | ||||
|     /// Gets the shader entries for the shader
 | ||||
|     const GLShader::ShaderEntries& GetShaderEntries() const { | ||||
|         return entries; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei