forked from eden-emu/eden
		
	service: fetch objects from the client handle table
This commit is contained in:
		
							parent
							
								
									1a1af26031
								
							
						
					
					
						commit
						6bd1dfa8cc
					
				
					 12 changed files with 45 additions and 66 deletions
				
			
		|  | @ -1147,8 +1147,7 @@ Result KServerSession::ReceiveRequest(uintptr_t server_message, uintptr_t server | ||||||
|         *out_context = |         *out_context = | ||||||
|             std::make_shared<Service::HLERequestContext>(m_kernel, memory, this, client_thread); |             std::make_shared<Service::HLERequestContext>(m_kernel, memory, this, client_thread); | ||||||
|         (*out_context)->SetSessionRequestManager(manager); |         (*out_context)->SetSessionRequestManager(manager); | ||||||
|         (*out_context) |         (*out_context)->PopulateFromIncomingCommandBuffer(cmd_buf); | ||||||
|             ->PopulateFromIncomingCommandBuffer(*client_thread->GetOwnerProcess(), cmd_buf); |  | ||||||
|         // We succeeded.
 |         // We succeeded.
 | ||||||
|         R_SUCCEED(); |         R_SUCCEED(); | ||||||
|     } else { |     } else { | ||||||
|  |  | ||||||
|  | @ -1513,8 +1513,7 @@ void ILibraryAppletCreator::CreateTransferMemoryStorage(HLERequestContext& ctx) | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     auto transfer_mem = |     auto transfer_mem = ctx.GetObjectFromHandle<Kernel::KTransferMemory>(handle); | ||||||
|         system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(handle); |  | ||||||
| 
 | 
 | ||||||
|     if (transfer_mem.IsNull()) { |     if (transfer_mem.IsNull()) { | ||||||
|         LOG_ERROR(Service_AM, "transfer_mem is a nullptr for handle={:08X}", handle); |         LOG_ERROR(Service_AM, "transfer_mem is a nullptr for handle={:08X}", handle); | ||||||
|  | @ -1547,8 +1546,7 @@ void ILibraryAppletCreator::CreateHandleStorage(HLERequestContext& ctx) { | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     auto transfer_mem = |     auto transfer_mem = ctx.GetObjectFromHandle<Kernel::KTransferMemory>(handle); | ||||||
|         system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>(handle); |  | ||||||
| 
 | 
 | ||||||
|     if (transfer_mem.IsNull()) { |     if (transfer_mem.IsNull()) { | ||||||
|         LOG_ERROR(Service_AM, "transfer_mem is a nullptr for handle={:08X}", handle); |         LOG_ERROR(Service_AM, "transfer_mem is a nullptr for handle={:08X}", handle); | ||||||
|  |  | ||||||
|  | @ -454,10 +454,8 @@ void AudRenU::OpenAudioRenderer(HLERequestContext& ctx) { | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     const auto& handle_table{system.ApplicationProcess()->GetHandleTable()}; |     auto process{ctx.GetObjectFromHandle<Kernel::KProcess>(process_handle)}; | ||||||
|     auto process{handle_table.GetObject<Kernel::KProcess>(process_handle)}; |     auto transfer_memory{ctx.GetObjectFromHandle<Kernel::KTransferMemory>(transfer_memory_handle)}; | ||||||
|     auto transfer_memory{ |  | ||||||
|         process->GetHandleTable().GetObject<Kernel::KTransferMemory>(transfer_memory_handle)}; |  | ||||||
| 
 | 
 | ||||||
|     const auto session_id{impl->GetSessionId()}; |     const auto session_id{impl->GetSessionId()}; | ||||||
|     if (session_id == -1) { |     if (session_id == -1) { | ||||||
|  |  | ||||||
|  | @ -278,9 +278,7 @@ void HwOpus::OpenHardwareOpusDecoder(HLERequestContext& ctx) { | ||||||
|     auto params = rp.PopRaw<OpusParameters>(); |     auto params = rp.PopRaw<OpusParameters>(); | ||||||
|     auto transfer_memory_size{rp.Pop<u32>()}; |     auto transfer_memory_size{rp.Pop<u32>()}; | ||||||
|     auto transfer_memory_handle{ctx.GetCopyHandle(0)}; |     auto transfer_memory_handle{ctx.GetCopyHandle(0)}; | ||||||
|     auto transfer_memory{ |     auto transfer_memory{ctx.GetObjectFromHandle<Kernel::KTransferMemory>(transfer_memory_handle)}; | ||||||
|         system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>( |  | ||||||
|             transfer_memory_handle)}; |  | ||||||
| 
 | 
 | ||||||
|     LOG_DEBUG(Service_Audio, "sample_rate {} channel_count {} transfer_memory_size 0x{:X}", |     LOG_DEBUG(Service_Audio, "sample_rate {} channel_count {} transfer_memory_size 0x{:X}", | ||||||
|               params.sample_rate, params.channel_count, transfer_memory_size); |               params.sample_rate, params.channel_count, transfer_memory_size); | ||||||
|  | @ -323,9 +321,7 @@ void HwOpus::OpenHardwareOpusDecoderForMultiStream(HLERequestContext& ctx) { | ||||||
| 
 | 
 | ||||||
|     auto transfer_memory_size{rp.Pop<u32>()}; |     auto transfer_memory_size{rp.Pop<u32>()}; | ||||||
|     auto transfer_memory_handle{ctx.GetCopyHandle(0)}; |     auto transfer_memory_handle{ctx.GetCopyHandle(0)}; | ||||||
|     auto transfer_memory{ |     auto transfer_memory{ctx.GetObjectFromHandle<Kernel::KTransferMemory>(transfer_memory_handle)}; | ||||||
|         system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>( |  | ||||||
|             transfer_memory_handle)}; |  | ||||||
| 
 | 
 | ||||||
|     LOG_DEBUG(Service_Audio, |     LOG_DEBUG(Service_Audio, | ||||||
|               "sample_rate {} channel_count {} total_stream_count {} stereo_stream_count {} " |               "sample_rate {} channel_count {} total_stream_count {} stereo_stream_count {} " | ||||||
|  | @ -374,9 +370,7 @@ void HwOpus::OpenHardwareOpusDecoderEx(HLERequestContext& ctx) { | ||||||
|     auto params = rp.PopRaw<OpusParametersEx>(); |     auto params = rp.PopRaw<OpusParametersEx>(); | ||||||
|     auto transfer_memory_size{rp.Pop<u32>()}; |     auto transfer_memory_size{rp.Pop<u32>()}; | ||||||
|     auto transfer_memory_handle{ctx.GetCopyHandle(0)}; |     auto transfer_memory_handle{ctx.GetCopyHandle(0)}; | ||||||
|     auto transfer_memory{ |     auto transfer_memory{ctx.GetObjectFromHandle<Kernel::KTransferMemory>(transfer_memory_handle)}; | ||||||
|         system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>( |  | ||||||
|             transfer_memory_handle)}; |  | ||||||
| 
 | 
 | ||||||
|     LOG_DEBUG(Service_Audio, "sample_rate {} channel_count {} transfer_memory_size 0x{:X}", |     LOG_DEBUG(Service_Audio, "sample_rate {} channel_count {} transfer_memory_size 0x{:X}", | ||||||
|               params.sample_rate, params.channel_count, transfer_memory_size); |               params.sample_rate, params.channel_count, transfer_memory_size); | ||||||
|  | @ -414,9 +408,7 @@ void HwOpus::OpenHardwareOpusDecoderForMultiStreamEx(HLERequestContext& ctx) { | ||||||
| 
 | 
 | ||||||
|     auto transfer_memory_size{rp.Pop<u32>()}; |     auto transfer_memory_size{rp.Pop<u32>()}; | ||||||
|     auto transfer_memory_handle{ctx.GetCopyHandle(0)}; |     auto transfer_memory_handle{ctx.GetCopyHandle(0)}; | ||||||
|     auto transfer_memory{ |     auto transfer_memory{ctx.GetObjectFromHandle<Kernel::KTransferMemory>(transfer_memory_handle)}; | ||||||
|         system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>( |  | ||||||
|             transfer_memory_handle)}; |  | ||||||
| 
 | 
 | ||||||
|     LOG_DEBUG(Service_Audio, |     LOG_DEBUG(Service_Audio, | ||||||
|               "sample_rate {} channel_count {} total_stream_count {} stereo_stream_count {} " |               "sample_rate {} channel_count {} total_stream_count {} stereo_stream_count {} " | ||||||
|  |  | ||||||
|  | @ -1850,8 +1850,7 @@ void IHidServer::InitializeSevenSixAxisSensor(HLERequestContext& ctx) { | ||||||
|     ASSERT_MSG(t_mem_1_size == 0x1000, "t_mem_1_size is not 0x1000 bytes"); |     ASSERT_MSG(t_mem_1_size == 0x1000, "t_mem_1_size is not 0x1000 bytes"); | ||||||
|     ASSERT_MSG(t_mem_2_size == 0x7F000, "t_mem_2_size is not 0x7F000 bytes"); |     ASSERT_MSG(t_mem_2_size == 0x7F000, "t_mem_2_size is not 0x7F000 bytes"); | ||||||
| 
 | 
 | ||||||
|     auto t_mem_1 = system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>( |     auto t_mem_1 = ctx.GetObjectFromHandle<Kernel::KTransferMemory>(t_mem_1_handle); | ||||||
|         t_mem_1_handle); |  | ||||||
| 
 | 
 | ||||||
|     if (t_mem_1.IsNull()) { |     if (t_mem_1.IsNull()) { | ||||||
|         LOG_ERROR(Service_HID, "t_mem_1 is a nullptr for handle=0x{:08X}", t_mem_1_handle); |         LOG_ERROR(Service_HID, "t_mem_1 is a nullptr for handle=0x{:08X}", t_mem_1_handle); | ||||||
|  | @ -1860,8 +1859,7 @@ void IHidServer::InitializeSevenSixAxisSensor(HLERequestContext& ctx) { | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     auto t_mem_2 = system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>( |     auto t_mem_2 = ctx.GetObjectFromHandle<Kernel::KTransferMemory>(t_mem_2_handle); | ||||||
|         t_mem_2_handle); |  | ||||||
| 
 | 
 | ||||||
|     if (t_mem_2.IsNull()) { |     if (t_mem_2.IsNull()) { | ||||||
|         LOG_ERROR(Service_HID, "t_mem_2 is a nullptr for handle=0x{:08X}", t_mem_2_handle); |         LOG_ERROR(Service_HID, "t_mem_2 is a nullptr for handle=0x{:08X}", t_mem_2_handle); | ||||||
|  | @ -2142,8 +2140,7 @@ void IHidServer::WritePalmaWaveEntry(HLERequestContext& ctx) { | ||||||
| 
 | 
 | ||||||
|     ASSERT_MSG(t_mem_size == 0x3000, "t_mem_size is not 0x3000 bytes"); |     ASSERT_MSG(t_mem_size == 0x3000, "t_mem_size is not 0x3000 bytes"); | ||||||
| 
 | 
 | ||||||
|     auto t_mem = system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>( |     auto t_mem = ctx.GetObjectFromHandle<Kernel::KTransferMemory>(t_mem_handle); | ||||||
|         t_mem_handle); |  | ||||||
| 
 | 
 | ||||||
|     if (t_mem.IsNull()) { |     if (t_mem.IsNull()) { | ||||||
|         LOG_ERROR(Service_HID, "t_mem is a nullptr for handle=0x{:08X}", t_mem_handle); |         LOG_ERROR(Service_HID, "t_mem is a nullptr for handle=0x{:08X}", t_mem_handle); | ||||||
|  |  | ||||||
|  | @ -448,8 +448,7 @@ void HidBus::EnableJoyPollingReceiveMode(HLERequestContext& ctx) { | ||||||
| 
 | 
 | ||||||
|     ASSERT_MSG(t_mem_size == 0x1000, "t_mem_size is not 0x1000 bytes"); |     ASSERT_MSG(t_mem_size == 0x1000, "t_mem_size is not 0x1000 bytes"); | ||||||
| 
 | 
 | ||||||
|     auto t_mem = system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>( |     auto t_mem = ctx.GetObjectFromHandle<Kernel::KTransferMemory>(t_mem_handle); | ||||||
|         t_mem_handle); |  | ||||||
| 
 | 
 | ||||||
|     if (t_mem.IsNull()) { |     if (t_mem.IsNull()) { | ||||||
|         LOG_ERROR(Service_HID, "t_mem is a nullptr for handle=0x{:08X}", t_mem_handle); |         LOG_ERROR(Service_HID, "t_mem is a nullptr for handle=0x{:08X}", t_mem_handle); | ||||||
|  |  | ||||||
|  | @ -197,8 +197,7 @@ void IRS::RunImageTransferProcessor(HLERequestContext& ctx) { | ||||||
|     const auto parameters{rp.PopRaw<Parameters>()}; |     const auto parameters{rp.PopRaw<Parameters>()}; | ||||||
|     const auto t_mem_handle{ctx.GetCopyHandle(0)}; |     const auto t_mem_handle{ctx.GetCopyHandle(0)}; | ||||||
| 
 | 
 | ||||||
|     auto t_mem = system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>( |     auto t_mem = ctx.GetObjectFromHandle<Kernel::KTransferMemory>(t_mem_handle); | ||||||
|         t_mem_handle); |  | ||||||
| 
 | 
 | ||||||
|     if (t_mem.IsNull()) { |     if (t_mem.IsNull()) { | ||||||
|         LOG_ERROR(Service_IRS, "t_mem is a nullptr for handle=0x{:08X}", t_mem_handle); |         LOG_ERROR(Service_IRS, "t_mem is a nullptr for handle=0x{:08X}", t_mem_handle); | ||||||
|  | @ -444,8 +443,7 @@ void IRS::RunImageTransferExProcessor(HLERequestContext& ctx) { | ||||||
|     const auto parameters{rp.PopRaw<Parameters>()}; |     const auto parameters{rp.PopRaw<Parameters>()}; | ||||||
|     const auto t_mem_handle{ctx.GetCopyHandle(0)}; |     const auto t_mem_handle{ctx.GetCopyHandle(0)}; | ||||||
| 
 | 
 | ||||||
|     auto t_mem = system.ApplicationProcess()->GetHandleTable().GetObject<Kernel::KTransferMemory>( |     auto t_mem = ctx.GetObjectFromHandle<Kernel::KTransferMemory>(t_mem_handle); | ||||||
|         t_mem_handle); |  | ||||||
| 
 | 
 | ||||||
|     LOG_INFO(Service_IRS, |     LOG_INFO(Service_IRS, | ||||||
|              "called, npad_type={}, npad_id={}, transfer_memory_size={}, " |              "called, npad_type={}, npad_id={}, transfer_memory_size={}, " | ||||||
|  |  | ||||||
|  | @ -146,10 +146,7 @@ HLERequestContext::HLERequestContext(Kernel::KernelCore& kernel_, Core::Memory:: | ||||||
| 
 | 
 | ||||||
| HLERequestContext::~HLERequestContext() = default; | HLERequestContext::~HLERequestContext() = default; | ||||||
| 
 | 
 | ||||||
| void HLERequestContext::ParseCommandBuffer(Kernel::KProcess& process, u32_le* src_cmdbuf, | void HLERequestContext::ParseCommandBuffer(u32_le* src_cmdbuf, bool incoming) { | ||||||
|                                            bool incoming) { |  | ||||||
|     client_handle_table = &process.GetHandleTable(); |  | ||||||
| 
 |  | ||||||
|     IPC::RequestParser rp(src_cmdbuf); |     IPC::RequestParser rp(src_cmdbuf); | ||||||
|     command_header = rp.PopRaw<IPC::CommandHeader>(); |     command_header = rp.PopRaw<IPC::CommandHeader>(); | ||||||
| 
 | 
 | ||||||
|  | @ -162,7 +159,7 @@ void HLERequestContext::ParseCommandBuffer(Kernel::KProcess& process, u32_le* sr | ||||||
|     if (command_header->enable_handle_descriptor) { |     if (command_header->enable_handle_descriptor) { | ||||||
|         handle_descriptor_header = rp.PopRaw<IPC::HandleDescriptorHeader>(); |         handle_descriptor_header = rp.PopRaw<IPC::HandleDescriptorHeader>(); | ||||||
|         if (handle_descriptor_header->send_current_pid) { |         if (handle_descriptor_header->send_current_pid) { | ||||||
|             pid = process.GetProcessId(); |             pid = thread->GetOwnerProcess()->GetProcessId(); | ||||||
|             rp.Skip(2, false); |             rp.Skip(2, false); | ||||||
|         } |         } | ||||||
|         if (incoming) { |         if (incoming) { | ||||||
|  | @ -270,9 +267,10 @@ void HLERequestContext::ParseCommandBuffer(Kernel::KProcess& process, u32_le* sr | ||||||
|     rp.Skip(1, false); // The command is actually an u64, but we don't use the high part.
 |     rp.Skip(1, false); // The command is actually an u64, but we don't use the high part.
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Result HLERequestContext::PopulateFromIncomingCommandBuffer(Kernel::KProcess& process, | Result HLERequestContext::PopulateFromIncomingCommandBuffer(u32_le* src_cmdbuf) { | ||||||
|                                                             u32_le* src_cmdbuf) { |     client_handle_table = &thread->GetOwnerProcess()->GetHandleTable(); | ||||||
|     ParseCommandBuffer(process, src_cmdbuf, true); | 
 | ||||||
|  |     ParseCommandBuffer(src_cmdbuf, true); | ||||||
| 
 | 
 | ||||||
|     if (command_header->IsCloseCommand()) { |     if (command_header->IsCloseCommand()) { | ||||||
|         // Close does not populate the rest of the IPC header
 |         // Close does not populate the rest of the IPC header
 | ||||||
|  | @ -284,9 +282,9 @@ Result HLERequestContext::PopulateFromIncomingCommandBuffer(Kernel::KProcess& pr | ||||||
|     return ResultSuccess; |     return ResultSuccess; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Result HLERequestContext::WriteToOutgoingCommandBuffer(Kernel::KThread& requesting_thread) { | Result HLERequestContext::WriteToOutgoingCommandBuffer() { | ||||||
|     auto current_offset = handles_offset; |     auto current_offset = handles_offset; | ||||||
|     auto& owner_process = *requesting_thread.GetOwnerProcess(); |     auto& owner_process = *thread->GetOwnerProcess(); | ||||||
|     auto& handle_table = owner_process.GetHandleTable(); |     auto& handle_table = owner_process.GetHandleTable(); | ||||||
| 
 | 
 | ||||||
|     for (auto& object : outgoing_copy_objects) { |     for (auto& object : outgoing_copy_objects) { | ||||||
|  | @ -319,7 +317,7 @@ Result HLERequestContext::WriteToOutgoingCommandBuffer(Kernel::KThread& requesti | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Copy the translated command buffer back into the thread's command buffer area.
 |     // Copy the translated command buffer back into the thread's command buffer area.
 | ||||||
|     memory.WriteBlock(requesting_thread.GetTlsAddress(), cmd_buf.data(), write_size * sizeof(u32)); |     memory.WriteBlock(thread->GetTlsAddress(), cmd_buf.data(), write_size * sizeof(u32)); | ||||||
| 
 | 
 | ||||||
|     return ResultSuccess; |     return ResultSuccess; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -17,6 +17,7 @@ | ||||||
| #include "common/concepts.h" | #include "common/concepts.h" | ||||||
| #include "common/swap.h" | #include "common/swap.h" | ||||||
| #include "core/hle/ipc.h" | #include "core/hle/ipc.h" | ||||||
|  | #include "core/hle/kernel/k_handle_table.h" | ||||||
| #include "core/hle/kernel/svc_common.h" | #include "core/hle/kernel/svc_common.h" | ||||||
| 
 | 
 | ||||||
| union Result; | union Result; | ||||||
|  | @ -196,10 +197,10 @@ public: | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /// Populates this context with data from the requesting process/thread.
 |     /// Populates this context with data from the requesting process/thread.
 | ||||||
|     Result PopulateFromIncomingCommandBuffer(Kernel::KProcess& process, u32_le* src_cmdbuf); |     Result PopulateFromIncomingCommandBuffer(u32_le* src_cmdbuf); | ||||||
| 
 | 
 | ||||||
|     /// Writes data from this context back to the requesting process/thread.
 |     /// Writes data from this context back to the requesting process/thread.
 | ||||||
|     Result WriteToOutgoingCommandBuffer(Kernel::KThread& requesting_thread); |     Result WriteToOutgoingCommandBuffer(); | ||||||
| 
 | 
 | ||||||
|     [[nodiscard]] u32_le GetHipcCommand() const { |     [[nodiscard]] u32_le GetHipcCommand() const { | ||||||
|         return command; |         return command; | ||||||
|  | @ -359,8 +360,13 @@ public: | ||||||
|         return *thread; |         return *thread; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     Kernel::KHandleTable& GetClientHandleTable() { |     template <typename T> | ||||||
|         return *client_handle_table; |     Kernel::KScopedAutoObject<T> GetObjectFromHandle(u32 handle) { | ||||||
|  |         auto obj = client_handle_table->GetObjectForIpc(handle, thread); | ||||||
|  |         if (obj.IsNotNull()) { | ||||||
|  |             return obj->DynamicCast<T*>(); | ||||||
|  |         } | ||||||
|  |         return nullptr; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     [[nodiscard]] std::shared_ptr<SessionRequestManager> GetManager() const { |     [[nodiscard]] std::shared_ptr<SessionRequestManager> GetManager() const { | ||||||
|  | @ -378,7 +384,7 @@ public: | ||||||
| private: | private: | ||||||
|     friend class IPC::ResponseBuilder; |     friend class IPC::ResponseBuilder; | ||||||
| 
 | 
 | ||||||
|     void ParseCommandBuffer(Kernel::KProcess& process, u32_le* src_cmdbuf, bool incoming); |     void ParseCommandBuffer(u32_le* src_cmdbuf, bool incoming); | ||||||
| 
 | 
 | ||||||
|     std::array<u32, IPC::COMMAND_BUFFER_LENGTH> cmd_buf; |     std::array<u32, IPC::COMMAND_BUFFER_LENGTH> cmd_buf; | ||||||
|     Kernel::KServerSession* server_session{}; |     Kernel::KServerSession* server_session{}; | ||||||
|  |  | ||||||
|  | @ -188,7 +188,7 @@ public: | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         auto tmem{process->GetHandleTable().GetObject<Kernel::KTransferMemory>(tmem_handle)}; |         auto tmem{ctx.GetObjectFromHandle<Kernel::KTransferMemory>(tmem_handle)}; | ||||||
|         if (tmem.IsNull()) { |         if (tmem.IsNull()) { | ||||||
|             LOG_ERROR(Service_JIT, "attempted to load plugin with invalid transfer memory handle"); |             LOG_ERROR(Service_JIT, "attempted to load plugin with invalid transfer memory handle"); | ||||||
|             IPC::ResponseBuilder rb{ctx, 2}; |             IPC::ResponseBuilder rb{ctx, 2}; | ||||||
|  | @ -356,11 +356,7 @@ public: | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // Fetch using the handle table for the application process here,
 |         auto process{ctx.GetObjectFromHandle<Kernel::KProcess>(process_handle)}; | ||||||
|         // since we are not multiprocess yet.
 |  | ||||||
|         const auto& handle_table{system.ApplicationProcess()->GetHandleTable()}; |  | ||||||
| 
 |  | ||||||
|         auto process{handle_table.GetObject<Kernel::KProcess>(process_handle)}; |  | ||||||
|         if (process.IsNull()) { |         if (process.IsNull()) { | ||||||
|             LOG_ERROR(Service_JIT, "process is null for handle=0x{:08X}", process_handle); |             LOG_ERROR(Service_JIT, "process is null for handle=0x{:08X}", process_handle); | ||||||
|             IPC::ResponseBuilder rb{ctx, 2}; |             IPC::ResponseBuilder rb{ctx, 2}; | ||||||
|  | @ -368,7 +364,7 @@ public: | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         auto rx_mem{handle_table.GetObject<Kernel::KCodeMemory>(rx_mem_handle)}; |         auto rx_mem{ctx.GetObjectFromHandle<Kernel::KCodeMemory>(rx_mem_handle)}; | ||||||
|         if (rx_mem.IsNull()) { |         if (rx_mem.IsNull()) { | ||||||
|             LOG_ERROR(Service_JIT, "rx_mem is null for handle=0x{:08X}", rx_mem_handle); |             LOG_ERROR(Service_JIT, "rx_mem is null for handle=0x{:08X}", rx_mem_handle); | ||||||
|             IPC::ResponseBuilder rb{ctx, 2}; |             IPC::ResponseBuilder rb{ctx, 2}; | ||||||
|  | @ -376,7 +372,7 @@ public: | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         auto ro_mem{handle_table.GetObject<Kernel::KCodeMemory>(ro_mem_handle)}; |         auto ro_mem{ctx.GetObjectFromHandle<Kernel::KCodeMemory>(ro_mem_handle)}; | ||||||
|         if (ro_mem.IsNull()) { |         if (ro_mem.IsNull()) { | ||||||
|             LOG_ERROR(Service_JIT, "ro_mem is null for handle=0x{:08X}", ro_mem_handle); |             LOG_ERROR(Service_JIT, "ro_mem is null for handle=0x{:08X}", ro_mem_handle); | ||||||
|             IPC::ResponseBuilder rb{ctx, 2}; |             IPC::ResponseBuilder rb{ctx, 2}; | ||||||
|  |  | ||||||
|  | @ -651,10 +651,9 @@ private: | ||||||
|     void RegisterProcessHandle(HLERequestContext& ctx) { |     void RegisterProcessHandle(HLERequestContext& ctx) { | ||||||
|         LOG_DEBUG(Service_LDR, "(called)"); |         LOG_DEBUG(Service_LDR, "(called)"); | ||||||
| 
 | 
 | ||||||
|         auto process_h = ctx.GetClientHandleTable().GetObject(ctx.GetCopyHandle(0)); |         auto process = ctx.GetObjectFromHandle<Kernel::KProcess>(ctx.GetCopyHandle(0)); | ||||||
|         auto client_pid = ctx.GetPID(); |         auto client_pid = ctx.GetPID(); | ||||||
|         auto result = interface.RegisterProcessHandle(client_pid, |         auto result = interface.RegisterProcessHandle(client_pid, process.GetPointerUnsafe()); | ||||||
|                                                       process_h->DynamicCast<Kernel::KProcess*>()); |  | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2}; |         IPC::ResponseBuilder rb{ctx, 2}; | ||||||
|         rb.Push(result); |         rb.Push(result); | ||||||
|  | @ -671,12 +670,11 @@ private: | ||||||
| 
 | 
 | ||||||
|         IPC::RequestParser rp{ctx}; |         IPC::RequestParser rp{ctx}; | ||||||
|         auto params = rp.PopRaw<InputParameters>(); |         auto params = rp.PopRaw<InputParameters>(); | ||||||
|         auto process_h = ctx.GetClientHandleTable().GetObject(ctx.GetCopyHandle(0)); |         auto process = ctx.GetObjectFromHandle<Kernel::KProcess>(ctx.GetCopyHandle(0)); | ||||||
| 
 | 
 | ||||||
|         auto client_pid = ctx.GetPID(); |         auto client_pid = ctx.GetPID(); | ||||||
|         auto result = |         auto result = interface.RegisterProcessModuleInfo( | ||||||
|             interface.RegisterProcessModuleInfo(client_pid, params.nrr_address, params.nrr_size, |             client_pid, params.nrr_address, params.nrr_size, process.GetPointerUnsafe()); | ||||||
|                                                 process_h->DynamicCast<Kernel::KProcess*>()); |  | ||||||
| 
 | 
 | ||||||
|         IPC::ResponseBuilder rb{ctx, 2}; |         IPC::ResponseBuilder rb{ctx, 2}; | ||||||
|         rb.Push(result); |         rb.Push(result); | ||||||
|  |  | ||||||
|  | @ -203,7 +203,7 @@ Result ServiceFrameworkBase::HandleSyncRequest(Kernel::KServerSession& session, | ||||||
|     // If emulation was shutdown, we are closing service threads, do not write the response back to
 |     // If emulation was shutdown, we are closing service threads, do not write the response back to
 | ||||||
|     // memory that may be shutting down as well.
 |     // memory that may be shutting down as well.
 | ||||||
|     if (system.IsPoweredOn()) { |     if (system.IsPoweredOn()) { | ||||||
|         ctx.WriteToOutgoingCommandBuffer(ctx.GetThread()); |         ctx.WriteToOutgoingCommandBuffer(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     return result; |     return result; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Liam
						Liam