X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=Usermode%2Finclude%2Facess%2Fsys.h;h=35f582d87f3a1abc3c4642e2f153a4d8a0dab4cf;hb=954abc650a400e5d8798ed3565a02645a9eeec55;hp=7fec475ffc63c1f6cbe1cd2d9777719d33e262ff;hpb=adc88116d41b2d869f67bbafe42413b31679845e;p=tpg%2Facess2.git diff --git a/Usermode/include/acess/sys.h b/Usermode/include/acess/sys.h index 7fec475f..35f582d8 100644 --- a/Usermode/include/acess/sys.h +++ b/Usermode/include/acess/sys.h @@ -1,20 +1,29 @@ /* * Acess2 System Interface Header */ -#ifndef _SYS_SYS_H_ -#define _SYS_SYS_H_ +#ifndef _ACESS_SYS_H_ +#define _ACESS_SYS_H_ #include +#include // === CONSTANTS === +#ifndef NULL +# define NULL ((void*)0) +#endif + #define OPENFLAG_EXEC 0x01 #define OPENFLAG_READ 0x02 #define OPENFLAG_WRITE 0x04 #define OPENFLAG_NOLINK 0x40 -#define SEEK_SET 1 -#define SEEK_CUR 0 -#define SEEK_END -1 +#define OPENFLAG_CREATE 0x80 +#ifndef SEEK_CUR +# define SEEK_SET 1 +# define SEEK_CUR 0 +# define SEEK_END -1 +#endif #define CLONE_VM 0x10 +#define GETMSG_IGNORE ((void*)-1) #define FILEFLAG_DIRECTORY 0x10 #define FILEFLAG_SYMLINK 0x20 @@ -48,26 +57,52 @@ struct s_sysFInfo { typedef struct s_sysFInfo t_sysFInfo; typedef struct s_sysACL t_sysACL; +// === VARIABLES === +extern int _errno; + // === FUNCTIONS === -void _SysDebug(char *str, ...); +extern void _SysDebug(const char *format, ...); // --- Proc --- -void sleep(); -void wait(int miliseconds); - int waittid(int id, int *status); - int clone(int flags, void *stack); - int execve(char *path, char **argv, char **envp); +extern void _exit(int status) __attribute__((noreturn)); +extern void sleep(); +extern void yield(); +extern int kill(int pid, int sig); +extern void wait(int miliseconds); +extern int waittid(int id, int *status); +extern int clone(int flags, void *stack); +extern int execve(char *path, char **argv, char **envp); +extern int gettid(); +extern int getpid(); +extern int _SysSetFaultHandler(int (*Handler)(int)); +extern void SysSetName(const char *Name); +//extern int SysGetName(const char *Name); + +// --- Permissions --- +extern int getuid(); +extern int getgid(); +extern void setuid(int id); +extern void setgid(int id); + // --- VFS --- - int chdir(char *dir); - int open(char *path, int flags); - int reopen(int fd, char *path, int flags); -void close(int fd); -uint64_t read(int fd, uint64_t length, void *buffer); -uint64_t write(int fd, uint64_t length, void *buffer); - int seek(int fd, uint64_t offset, int whence); - int ioctl(int fd, int id, void *data); - int finfo(int fd, t_sysFInfo *info, int maxacls); - int readdir(int fd, char *dest); - int _SysGetACL(int fd, t_sysACL *dest); +extern int chdir(const char *dir); +extern int open(const char *path, int flags); +extern int reopen(int fd, const char *path, int flags); +extern void close(int fd); +extern uint read(int fd, uint length, void *buffer); +extern uint write(int fd, uint length, void *buffer); +extern int seek(int fd, int64_t offset, int whence); +extern uint64_t tell(int fd); +extern int ioctl(int fd, int id, void *data); +extern int finfo(int fd, t_sysFInfo *info, int maxacls); +extern int readdir(int fd, char *dest); +extern int _SysOpenChild(int fd, char *name, int flags); +extern int _SysGetACL(int fd, t_sysACL *dest); +extern int _SysMount(const char *Device, const char *Directory, const char *Type, const char *Options); +extern int select(int nfds, fd_set *readfds, fd_set *writefds, fd_set *errfds, time_t *timeout); + +// --- IPC --- +extern int SysSendMessage(pid_t dest, uint length, void *Data); +extern int SysGetMessage(pid_t *src, void *Data); // --- MEMORY --- uint64_t _SysGetPhys(uint vaddr);