diff options
| author | Yuri Kunde Schlesner <yuriks@yuriks.net> | 2015-06-23 12:40:32 -0700 |
|---|---|---|
| committer | Yuri Kunde Schlesner <yuriks@yuriks.net> | 2015-06-23 12:40:32 -0700 |
| commit | 76dfafc906ffd2094464703ae706dac778734d43 (patch) | |
| tree | 8976d65e22f4ad7ca2319b20a5e9c6223c3b1eef /src/core/hle/service/apt/apt.cpp | |
| parent | a9fd93347dff482a83d45d92c23e46fd6337089c (diff) | |
| parent | 81488d7a6ab09ff980a9325901113449800f5146 (diff) | |
Merge pull request #877 from yuriks/ipc-headers
Add helpers to create IPC command buffer headers and descriptors
Diffstat (limited to 'src/core/hle/service/apt/apt.cpp')
| -rw-r--r-- | src/core/hle/service/apt/apt.cpp | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/src/core/hle/service/apt/apt.cpp b/src/core/hle/service/apt/apt.cpp index 5d14f393d..b454a2709 100644 --- a/src/core/hle/service/apt/apt.cpp +++ b/src/core/hle/service/apt/apt.cpp @@ -45,7 +45,7 @@ void Initialize(Service::Interface* self) { u32 app_id = cmd_buff[1]; u32 flags = cmd_buff[2]; - cmd_buff[2] = 0x04000000; // According to 3dbrew, this value should be 0x04000000 + cmd_buff[2] = IPC::MoveHandleDesc(2); cmd_buff[3] = Kernel::g_handle_table.Create(notification_event).MoveFrom(); cmd_buff[4] = Kernel::g_handle_table.Create(start_event).MoveFrom(); @@ -70,11 +70,13 @@ void GetSharedFont(Service::Interface* self) { // an easy way to do this, but the copy should be sufficient for now. memcpy(Memory::GetPointer(SHARED_FONT_VADDR), shared_font.data(), shared_font.size()); - cmd_buff[0] = 0x00440082; + cmd_buff[0] = IPC::MakeHeader(0x44, 2, 2); cmd_buff[1] = RESULT_SUCCESS.raw; // No error cmd_buff[2] = SHARED_FONT_VADDR; + cmd_buff[3] = IPC::MoveHandleDesc(); cmd_buff[4] = Kernel::g_handle_table.Create(shared_font_mem).MoveFrom(); } else { + cmd_buff[0] = IPC::MakeHeader(0x44, 1, 0); cmd_buff[1] = -1; // Generic error (not really possible to verify this on hardware) LOG_ERROR(Kernel_SVC, "called, but %s has not been loaded!", SHARED_FONT); } |
