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
Tools/udisetup - Switched back to udiprops_end instead of _size
[tpg/acess2.git]
/
AcessNative
/
syscalls.h
diff --git
a/AcessNative/syscalls.h
b/AcessNative/syscalls.h
index
5081a53
..
d2e8e91
100644
(file)
--- a/
AcessNative/syscalls.h
+++ b/
AcessNative/syscalls.h
@@
-3,6
+3,16
@@
#ifndef _NATIVE_SYSCALLS_H_
#define _NATIVE_SYSCALLS_H_
#ifndef _NATIVE_SYSCALLS_H_
#define _NATIVE_SYSCALLS_H_
+#define SERVER_PORT 0xACE
+
+#define SYSCALL_TRACE 1
+
+#if SYSCALL_TRACE
+#define SYSTRACE(str, x...) Debug(str, x)
+#else
+#define SYSTRACE(...) do{}while(0)
+#endif
+
/*
* Request format
*
/*
* Request format
*
@@
-12,38
+22,44
@@
* 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 {
} tRequestValue;
typedef struct sRequestHeader {
- uint16_t ClientID;
+ uint32_t ClientID;
+ uint32_t MessageLength;
uint16_t CallID; //!< \see eSyscalls
uint16_t NParams;
uint16_t CallID; //!< \see eSyscalls
uint16_t NParams;
- uint16_t NReturn;
tRequestValue Params[];
tRequestValue Params[];
-} tRequestHeader;
+} __attribute__((packed)) tRequestHeader;
+
enum eSyscalls {
enum eSyscalls {
- SYS_NULL,
- SYS_OPEN,
- SYS_CLOSE,
- SYS_READ,
- SYS_WRITE,
- SYS_SEEK,
- SYS_TELL,
- SYS_IOCTL,
- SYS_FINFO,
- SYS_READDIR,
- SYS_OPENCHILD,
- SYS_GETACL,
- SYS_MOUNT,
+ #define _(n) n
+ #include "syscalls_list.h"
+ #undef _
N_SYSCALLS
};
N_SYSCALLS
};
+#ifndef DONT_INCLUDE_SYSCALL_NAMES
+static const char * casSYSCALL_NAMES[] = {
+ #define _(n) #n
+ #include "syscalls_list.h"
+ #undef _
+ "-"
+};
+#endif
+
enum eArgumentTypes {
ARG_TYPE_VOID,
ARG_TYPE_INT32,
enum eArgumentTypes {
ARG_TYPE_VOID,
ARG_TYPE_INT32,
@@
-51,5
+67,9
@@
enum eArgumentTypes {
ARG_TYPE_STRING,
ARG_TYPE_DATA
};
ARG_TYPE_STRING,
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