git.ucc.asn.au
/
tpg
/
acess2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Kernel/x86-smp - Fixing SMP support
[tpg/acess2.git]
/
AcessNative
/
syscalls.h
diff --git
a/AcessNative/syscalls.h
b/AcessNative/syscalls.h
index
e298c94
..
21a9cb5
100644
(file)
--- a/
AcessNative/syscalls.h
+++ b/
AcessNative/syscalls.h
@@
-3,6
+3,8
@@
#ifndef _NATIVE_SYSCALLS_H_
#define _NATIVE_SYSCALLS_H_
#ifndef _NATIVE_SYSCALLS_H_
#define _NATIVE_SYSCALLS_H_
+#define SERVER_PORT 0xACE
+
/*
* Request format
*
/*
* Request format
*
@@
-12,31
+14,118
@@
* uint8_t paramData[SUM(params[].Lengh)];
*/
* uint8_t paramData[SUM(params[].Lengh)];
*/
+typedef struct {
+ uint32_t pid;
+ uint32_t key;
+} tRequestAuthHdr;
+
typedef struct sRequestValue {
/// \see eArgumentTypes
uint16_t Type;
typedef struct sRequestValue {
/// \see eArgumentTypes
uint16_t Type;
- uint16_t Length;
+ uint16_t Flags;
+ uint32_t Length;
} tRequestValue;
typedef struct sRequestHeader {
uint16_t ClientID;
uint16_t CallID; //!< \see eSyscalls
} tRequestValue;
typedef struct sRequestHeader {
uint16_t ClientID;
uint16_t CallID; //!< \see eSyscalls
+ uint32_t MessageLength;
uint16_t NParams;
uint16_t NParams;
- uint16_t NReturn;
tRequestValue Params[];
} tRequestHeader;
enum eSyscalls {
SYS_NULL,
tRequestValue Params[];
} tRequestHeader;
enum eSyscalls {
SYS_NULL,
- SYS_OPEN
+
+ SYS_EXIT,
+
+ SYS_OPEN,
+ SYS_CLOSE,
+ SYS_READ,
+ SYS_WRITE,
+ SYS_SEEK,
+ SYS_TELL,
+ SYS_IOCTL,
+ SYS_FINFO,
+ SYS_READDIR,
+ SYS_OPENCHILD,
+ SYS_GETACL,
+ SYS_MOUNT,
+ SYS_REOPEN,
+ SYS_CHDIR,
+
+ SYS_WAITTID,
+ SYS_SETUID,
+ SYS_SETGID,
+
+ SYS_GETTID,
+ SYS_GETPID,
+ SYS_GETUID,
+ SYS_GETGID,
+
+ // IPC
+ SYS_SLEEP,
+ SYS_AN_FORK,
+ SYS_AN_SPAWN,
+ SYS_SENDMSG,
+ SYS_GETMSG,
+ SYS_SELECT,
+ SYS_WAITEVENT,
+
+ N_SYSCALLS
};
};
+#ifndef DONT_INCLUDE_SYSCALL_NAMES
+static const char * casSYSCALL_NAMES[] = {
+ "SYS_NULL",
+
+ "SYS_EXIT",
+
+ "SYS_OPEN",
+ "SYS_CLOSE",
+ "SYS_READ",
+ "SYS_WRITE",
+ "SYS_SEEK",
+ "SYS_TELL",
+ "SYS_IOCTL",
+ "SYS_FINFO",
+ "SYS_READDIR",
+ "SYS_OPENCHILD",
+ "SYS_GETACL",
+ "SYS_MOUNT",
+ "SYS_REOPEN",
+ "SYS_CHDIR",
+
+ "SYS_WAITTID",
+ "SYS_SETUID",
+ "SYS_SETGID",
+
+ "SYS_GETTID",
+ "SYS_GETPID",
+ "SYS_GETUID",
+ "SYS_GETGID",
+
+ // IPC
+ "SYS_SLEEP",
+ "SYS_AN_FORK",
+ "SYS_SENDMSG",
+ "SYS_GETMSG",
+ "SYS_SELECT",
+ "SYS_WAITEVENT"
+};
+#endif
+
enum eArgumentTypes {
ARG_TYPE_VOID,
ARG_TYPE_INT32,
ARG_TYPE_INT64,
enum eArgumentTypes {
ARG_TYPE_VOID,
ARG_TYPE_INT32,
ARG_TYPE_INT64,
+ ARG_TYPE_STRING,
ARG_TYPE_DATA
};
ARG_TYPE_DATA
};
+enum eArgumentFlags {
+ ARG_FLAG_RETURN = 0x40, // Pass back in the return message
+ ARG_FLAG_ZEROED = 0x80 // Not present in the message, just fill with zero
+};
#endif
#endif
UCC
git Repository :: git.ucc.asn.au