aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/core/hle/kernel
diff options
context:
space:
mode:
authorGravatar Yuri Kunde Schlesner <yuriks@yuriks.net>2015-06-23 12:40:32 -0700
committerGravatar Yuri Kunde Schlesner <yuriks@yuriks.net>2015-06-23 12:40:32 -0700
commit76dfafc906ffd2094464703ae706dac778734d43 (patch)
tree8976d65e22f4ad7ca2319b20a5e9c6223c3b1eef /src/core/hle/kernel
parenta9fd93347dff482a83d45d92c23e46fd6337089c (diff)
parent81488d7a6ab09ff980a9325901113449800f5146 (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/kernel')
-rw-r--r--src/core/hle/kernel/session.h34
1 files changed, 34 insertions, 0 deletions
diff --git a/src/core/hle/kernel/session.h b/src/core/hle/kernel/session.h
index 54a06297..257da910 100644
--- a/src/core/hle/kernel/session.h
+++ b/src/core/hle/kernel/session.h
@@ -8,6 +8,40 @@
#include "core/hle/kernel/thread.h"
#include "core/memory.h"
+namespace IPC {
+
+inline u32 MakeHeader(u16 command_id, unsigned int regular_params, unsigned int translate_params) {
+ return ((u32)command_id << 16) | (((u32)regular_params & 0x3F) << 6) | (((u32)translate_params & 0x3F) << 0);
+}
+
+inline u32 MoveHandleDesc(unsigned int num_handles = 1) {
+ return 0x0 | ((num_handles - 1) << 26);
+}
+
+inline u32 CopyHandleDesc(unsigned int num_handles = 1) {
+ return 0x10 | ((num_handles - 1) << 26);
+}
+
+inline u32 CallingPidDesc() {
+ return 0x20;
+}
+
+inline u32 StaticBufferDesc(u32 size, unsigned int buffer_id) {
+ return 0x2 | (size << 14) | ((buffer_id & 0xF) << 10);
+}
+
+enum MappedBufferPermissions {
+ R = 2,
+ W = 4,
+ RW = R | W,
+};
+
+inline u32 MappedBufferDesc(u32 size, MappedBufferPermissions perms) {
+ return 0x8 | (size << 4) | (u32)perms;
+}
+
+}
+
namespace Kernel {
static const int kCommandHeaderOffset = 0x80; ///< Offset into command buffer of header