mirror of
				https://git.eden-emu.dev/eden-emu/eden.git
				synced 2025-10-25 00:17:48 +00:00 
			
		
		
		
	NVDRV: Further refactors and eliminate old code.
This commit is contained in:
		
							parent
							
								
									383f95a063
								
							
						
					
					
						commit
						43d8a8fb77
					
				
					 18 changed files with 12 additions and 242 deletions
				
			
		|  | @ -77,12 +77,9 @@ NvResult nvhost_ctrl::Ioctl3(DeviceFD fd, Ioctl command, const std::vector<u8>& | |||
|     return NvResult::NotImplemented; | ||||
| } | ||||
| 
 | ||||
| void nvhost_ctrl::OnOpen(DeviceFD fd) { | ||||
|     events_interface.RegisterForSignal(this); | ||||
| } | ||||
| void nvhost_ctrl::OnClose(DeviceFD fd) { | ||||
|     events_interface.UnregisterForSignal(this); | ||||
| } | ||||
| void nvhost_ctrl::OnOpen(DeviceFD fd) {} | ||||
| 
 | ||||
| void nvhost_ctrl::OnClose(DeviceFD fd) {} | ||||
| 
 | ||||
| NvResult nvhost_ctrl::NvOsGetConfigU32(const std::vector<u8>& input, std::vector<u8>& output) { | ||||
|     IocGetConfigParams params{}; | ||||
|  | @ -395,21 +392,4 @@ u32 nvhost_ctrl::FindFreeNvEvent(u32 syncpoint_id) { | |||
|     return 0; | ||||
| } | ||||
| 
 | ||||
| void nvhost_ctrl::SignalNvEvent(u32 syncpoint_id, u32 value) { | ||||
|     u64 signal_mask = events_mask; | ||||
|     while (signal_mask != 0) { | ||||
|         const u64 event_id = std::countr_zero(signal_mask); | ||||
|         signal_mask &= ~(1ULL << event_id); | ||||
|         auto& event = events[event_id]; | ||||
|         if (event.assigned_syncpt != syncpoint_id || event.assigned_value != value) { | ||||
|             continue; | ||||
|         } | ||||
|         if (event.status.exchange(EventState::Signalling, std::memory_order_acq_rel) == | ||||
|             EventState::Waiting) { | ||||
|             event.kevent->GetWritableEvent().Signal(); | ||||
|         } | ||||
|         event.status.store(EventState::Signalled, std::memory_order_release); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| } // namespace Service::Nvidia::Devices
 | ||||
|  |  | |||
|  | @ -56,8 +56,6 @@ public: | |||
|     }; | ||||
|     static_assert(sizeof(SyncpointEventValue) == sizeof(u32)); | ||||
| 
 | ||||
|     void SignalNvEvent(u32 syncpoint_id, u32 value); | ||||
| 
 | ||||
| private: | ||||
|     struct InternalEvent { | ||||
|         // Mask representing registered events
 | ||||
|  |  | |||
|  | @ -14,6 +14,7 @@ | |||
| #include "video_core/control/channel_state.h" | ||||
| #include "video_core/engines/puller.h" | ||||
| #include "video_core/gpu.h" | ||||
| #include "video_core/host1x/host1x.h" | ||||
| 
 | ||||
| namespace Service::Nvidia::Devices { | ||||
| namespace { | ||||
|  | @ -31,7 +32,8 @@ nvhost_gpu::nvhost_gpu(Core::System& system_, EventInterface& events_interface_, | |||
|       syncpoint_manager{core_.GetSyncpointManager()}, nvmap{core.GetNvMapFile()}, | ||||
|       channel_state{system.GPU().AllocateChannel()} { | ||||
|     channel_fence.id = syncpoint_manager.AllocateSyncpoint(); | ||||
|     channel_fence.value = system_.GPU().GetSyncpointValue(channel_fence.id); | ||||
|     channel_fence.value = | ||||
|         system_.Host1x().GetSyncpointManager().GetGuestSyncpointValue(channel_fence.id); | ||||
|     sm_exception_breakpoint_int_report_event = | ||||
|         events_interface.CreateEvent("GpuChannelSMExceptionBreakpointInt"); | ||||
|     sm_exception_breakpoint_pause_report_event = | ||||
|  | @ -189,7 +191,8 @@ NvResult nvhost_gpu::AllocGPFIFOEx2(const std::vector<u8>& input, std::vector<u8 | |||
|     } | ||||
| 
 | ||||
|     system.GPU().InitChannel(*channel_state); | ||||
|     channel_fence.value = system.GPU().GetSyncpointValue(channel_fence.id); | ||||
|     channel_fence.value = | ||||
|         system.Host1x().GetSyncpointManager().GetGuestSyncpointValue(channel_fence.id); | ||||
| 
 | ||||
|     params.fence_out = channel_fence; | ||||
| 
 | ||||
|  |  | |||
|  | @ -33,23 +33,6 @@ EventInterface::EventInterface(Module& module_) : module{module_}, guard{}, on_s | |||
| 
 | ||||
| EventInterface::~EventInterface() = default; | ||||
| 
 | ||||
| void EventInterface::RegisterForSignal(Devices::nvhost_ctrl* device) { | ||||
|     std::unique_lock<std::mutex> lk(guard); | ||||
|     on_signal.push_back(device); | ||||
| } | ||||
| 
 | ||||
| void EventInterface::UnregisterForSignal(Devices::nvhost_ctrl* device) { | ||||
|     std::unique_lock<std::mutex> lk(guard); | ||||
|     on_signal.remove(device); | ||||
| } | ||||
| 
 | ||||
| void EventInterface::Signal(u32 syncpoint_id, u32 value) { | ||||
|     std::unique_lock<std::mutex> lk(guard); | ||||
|     for (auto* device : on_signal) { | ||||
|         device->SignalNvEvent(syncpoint_id, value); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| Kernel::KEvent* EventInterface::CreateEvent(std::string name) { | ||||
|     Kernel::KEvent* new_event = module.service_context.CreateEvent(std::move(name)); | ||||
|     return new_event; | ||||
|  | @ -221,10 +204,6 @@ NvResult Module::Close(DeviceFD fd) { | |||
|     return NvResult::Success; | ||||
| } | ||||
| 
 | ||||
| void Module::SignalSyncpt(const u32 syncpoint_id, const u32 value) { | ||||
|     events_interface.Signal(syncpoint_id, value); | ||||
| } | ||||
| 
 | ||||
| NvResult Module::QueryEvent(DeviceFD fd, u32 event_id, Kernel::KEvent*& event) { | ||||
|     if (fd < 0) { | ||||
|         LOG_ERROR(Service_NVDRV, "Invalid DeviceFD={}!", fd); | ||||
|  |  | |||
|  | @ -49,11 +49,6 @@ public: | |||
|     EventInterface(Module& module_); | ||||
|     ~EventInterface(); | ||||
| 
 | ||||
|     void RegisterForSignal(Devices::nvhost_ctrl*); | ||||
|     void UnregisterForSignal(Devices::nvhost_ctrl*); | ||||
| 
 | ||||
|     void Signal(u32 syncpoint_id, u32 value); | ||||
| 
 | ||||
|     Kernel::KEvent* CreateEvent(std::string name); | ||||
| 
 | ||||
|     void FreeEvent(Kernel::KEvent* event); | ||||
|  | @ -96,8 +91,6 @@ public: | |||
|     /// Closes a device file descriptor and returns operation success.
 | ||||
|     NvResult Close(DeviceFD fd); | ||||
| 
 | ||||
|     void SignalSyncpt(const u32 syncpoint_id, const u32 value); | ||||
| 
 | ||||
|     NvResult QueryEvent(DeviceFD fd, u32 event_id, Kernel::KEvent*& event); | ||||
| 
 | ||||
| private: | ||||
|  |  | |||
|  | @ -15,10 +15,6 @@ | |||
| 
 | ||||
| namespace Service::Nvidia { | ||||
| 
 | ||||
| void NVDRV::SignalGPUInterruptSyncpt(const u32 syncpoint_id, const u32 value) { | ||||
|     nvdrv->SignalSyncpt(syncpoint_id, value); | ||||
| } | ||||
| 
 | ||||
| void NVDRV::Open(Kernel::HLERequestContext& ctx) { | ||||
|     LOG_DEBUG(Service_NVDRV, "called"); | ||||
|     IPC::ResponseBuilder rb{ctx, 4}; | ||||
|  |  | |||
|  | @ -18,8 +18,6 @@ public: | |||
|     explicit NVDRV(Core::System& system_, std::shared_ptr<Module> nvdrv_, const char* name); | ||||
|     ~NVDRV() override; | ||||
| 
 | ||||
|     void SignalGPUInterruptSyncpt(u32 syncpoint_id, u32 value); | ||||
| 
 | ||||
| private: | ||||
|     void Open(Kernel::HLERequestContext& ctx); | ||||
|     void Ioctl1(Kernel::HLERequestContext& ctx); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Fernando Sahmkow
						Fernando Sahmkow