forked from eden-emu/eden
		
	Address feedback, add CR notice, etc
This commit is contained in:
		
							parent
							
								
									dffc48b942
								
							
						
					
					
						commit
						134c14f089
					
				
					 5 changed files with 18 additions and 10 deletions
				
			
		|  | @ -20,7 +20,6 @@ | |||
| #include "video_core/gpu.h" | ||||
| #include "video_core/rasterizer_download_area.h" | ||||
| 
 | ||||
| 
 | ||||
| namespace Core::Memory { | ||||
| 
 | ||||
| // Implementation class used to keep the specifics of the memory subsystem hidden
 | ||||
|  | @ -465,7 +464,8 @@ struct Memory::Impl { | |||
|         } | ||||
| 
 | ||||
|         if (Settings::IsFastmemEnabled()) { | ||||
|             const bool is_read_enable = !Settings::values.use_reactive_flushing.GetValue() || !cached; | ||||
|             const bool is_read_enable = | ||||
|                 !Settings::values.use_reactive_flushing.GetValue() || !cached; | ||||
|             system.DeviceMemory().buffer.Protect(vaddr, size, is_read_enable, !cached); | ||||
|         } | ||||
| 
 | ||||
|  | @ -654,9 +654,7 @@ struct Memory::Impl { | |||
|                 LOG_ERROR(HW_Memory, "Unmapped Read{} @ 0x{:016X}", sizeof(T) * 8, | ||||
|                           GetInteger(vaddr)); | ||||
|             }, | ||||
|             [&]() { | ||||
|                 HandleRasterizerDownload(GetInteger(vaddr), sizeof(T)); | ||||
|             }); | ||||
|             [&]() { HandleRasterizerDownload(GetInteger(vaddr), sizeof(T)); }); | ||||
|         if (ptr) { | ||||
|             std::memcpy(&result, ptr, sizeof(T)); | ||||
|         } | ||||
|  | @ -721,7 +719,8 @@ struct Memory::Impl { | |||
|         const size_t core = system.GetCurrentHostThreadID(); | ||||
|         auto& current_area = rasterizer_areas[core]; | ||||
|         const VAddr end_address = address + size; | ||||
|         if (current_area.start_address <= address && end_address <= current_area.end_address) [[likely]] { | ||||
|         if (current_area.start_address <= address && end_address <= current_area.end_address) | ||||
|             [[likely]] { | ||||
|             return; | ||||
|         } | ||||
|         current_area = system.GPU().OnCPURead(address, size); | ||||
|  |  | |||
|  | @ -55,6 +55,11 @@ public: | |||
| 
 | ||||
|     // Unlike other fences, this one doesn't
 | ||||
|     void SignalOrdering() { | ||||
|         std::scoped_lock lock{buffer_cache.mutex}; | ||||
|         buffer_cache.AccumulateFlushes(); | ||||
|     } | ||||
| 
 | ||||
|     void SignalReference() { | ||||
|         std::function<void()> do_nothing([] {}); | ||||
|         SignalFence(std::move(do_nothing)); | ||||
|     } | ||||
|  |  | |||
|  | @ -1,3 +1,6 @@ | |||
| // SPDX-FileCopyrightText: Copyright 2023 yuzu Emulator Project
 | ||||
| // SPDX-License-Identifier: GPL-3.0-or-later
 | ||||
| 
 | ||||
| #pragma once | ||||
| 
 | ||||
| #include "common/common_types.h" | ||||
|  |  | |||
|  | @ -621,7 +621,7 @@ void RasterizerVulkan::SignalSyncPoint(u32 value) { | |||
| } | ||||
| 
 | ||||
| void RasterizerVulkan::SignalReference() { | ||||
|     fence_manager.SignalOrdering(); | ||||
|     fence_manager.SignalReference(); | ||||
| } | ||||
| 
 | ||||
| void RasterizerVulkan::ReleaseFences() { | ||||
|  | @ -654,7 +654,7 @@ void RasterizerVulkan::WaitForIdle() { | |||
|         cmdbuf.SetEvent(event, flags); | ||||
|         cmdbuf.WaitEvents(event, flags, VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT, {}, {}, {}); | ||||
|     }); | ||||
|     SignalReference(); | ||||
|     fence_manager.SignalOrdering(); | ||||
| } | ||||
| 
 | ||||
| void RasterizerVulkan::FragmentBarrier() { | ||||
|  |  | |||
|  | @ -26,7 +26,8 @@ ImageViewBase::ImageViewBase(const ImageViewInfo& info, const ImageInfo& image_i | |||
|     ASSERT_MSG(VideoCore::Surface::IsViewCompatible(image_info.format, info.format, false, true), | ||||
|                "Image view format {} is incompatible with image format {}", info.format, | ||||
|                image_info.format); | ||||
|     const bool preemptive = !Settings::values.use_reactive_flushing.GetValue() && image_info.type == ImageType::Linear; | ||||
|     const bool preemptive = | ||||
|         !Settings::values.use_reactive_flushing.GetValue() && image_info.type == ImageType::Linear; | ||||
|     if (image_info.forced_flushed || preemptive) { | ||||
|         flags |= ImageViewFlagBits::PreemtiveDownload; | ||||
|     } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Fernando Sahmkow
						Fernando Sahmkow