📄 unistd.h
字号:
/* This file is lisenced under LGPL. * Copyright (C) 2002-2003, George Thanos <george.thanos@gdt.gr> * Yannis Mitsos <yannis.mitsos@gdt.gr> */#ifndef _BITS_UNISTD_H_#define _BITS_UNISTD_H_#include <bits/proto.h>#include <errno.h>#define __E1_COFF_GCC__/* The following macros have been provided by C.Baumhof * They can be inlined in contrast to the previous ones*/#define _syscall0(type, name) \type name(void) \{ \ register int par1 __asm__("L15"); \ register int par2 __asm__("L14"); \ par1 = -1; \ par2 = __NR_##name; \ __asm__ __volatile__( \ "trap 47" \ :"=l"(par1) \ :"0"(par1), "l"(par2) \ :"memory","L14","L15"); \ \ if( par1 < 0 ) { \ __set_errno( -par1 ); \ return -1; \ } else \ return (type)(par1); \}#define _syscall1(type, name,atype, a) \type name(atype a) \{ \ register int par1 __asm__("L15"); \ register int par2 __asm__("L14"); \ register int par3 __asm__("L13"); \ par1 = -1; \ par2 = __NR_##name; \ par3 = (int)a; \ __asm__ __volatile__( \ "trap 47" \ :"=l"(par1) \ :"0"(par1), "l"(par2), "l"(par3) \ :"memory","L13","L14","L15"); \ \ if( par1 < 0 ) { \ __set_errno( -par1 ); \ return -1; \ } else \ return (type)(par1); \}#define _syscall2(type, name,atype, a, btype, b) \type name(atype a, btype b) \{ \ register int par1 __asm__("L15"); \ register int par2 __asm__("L14"); \ register int par3 __asm__("L13"); \ register int par4 __asm__("L12"); \ par1 = -1; \ par2 = __NR_##name; \ par3 = (int)a; \ par4 = (int)b; \ __asm__ __volatile__( \ "trap 47" \ :"=l"(par1) \ :"0"(par1), "l"(par2), "l"(par3), "l"(par4) \ :"memory","L12","L13","L14","L15"); \ \ if( par1 < 0 ) { \ __set_errno( -par1 ); \ return -1; \ } else \ return (type)(par1); \}#define _syscall3(type, name,atype, a, btype, b, ctype, c) \type name(atype a, btype b, ctype c) \{ \ register int par1 __asm__("L15"); \ register int par2 __asm__("L14"); \ register int par3 __asm__("L13"); \ register int par4 __asm__("L12"); \ register int par5 __asm__("L11"); \ par1 = -1; \ par2 = __NR_##name; \ par3 = (int)a; \ par4 = (int)b; \ par5 = (int)c; \ __asm__ __volatile__( \ "trap 47" \ :"=l"(par1) \ :"0"(par1), "l"(par2), "l"(par3), "l"(par4), "l"(par5) \ :"memory","L11","L12","L13","L14","L15"); \ \ if( par1 < 0 ) { \ __set_errno( -par1 ); \ return -1; \ } else \ return (type)(par1); \}#define _syscall4(type, name,atype, a, btype, b, ctype, c, dtype, d) \type name(atype a, btype b, ctype c,dtype d) \{ \ register int par1 __asm__("L15"); \ register int par2 __asm__("L14"); \ register int par3 __asm__("L13"); \ register int par4 __asm__("L12"); \ register int par5 __asm__("L11"); \ register int par6 __asm__("L10"); \ par1 = -1; \ par2 = __NR_##name; \ par3 = (int)a; \ par4 = (int)b; \ par5 = (int)c; \ par6 = (int)d; \ __asm__ __volatile__( \ "trap 47" \ :"=l"(par1) \ :"0"(par1),"l"(par2),"l"(par3),"l"(par4),"l"(par5),"l"(par6) \ :"memory","L10","L11","L12","L13","L14","L15"); \ \ if( par1 < 0 ) { \ __set_errno( -par1 ); \ return -1; \ } else \ return (type)(par1); \}#define _syscall5(type, name,atype, a, btype, b, ctype, c, dtype, d, etype, e) \type name(atype a, btype b, ctype c,dtype d, etype e) \{ \ register int par1 __asm__("L15"); \ register int par2 __asm__("L14"); \ register int par3 __asm__("L13"); \ register int par4 __asm__("L12"); \ register int par5 __asm__("L11"); \ register int par6 __asm__("L10"); \ register int par7 __asm__("L9"); \ par1 = -1; \ par2 = __NR_##name; \ par3 = (int)a; \ par4 = (int)b; \ par5 = (int)c; \ par6 = (int)d; \ par7 = (int)e; \ __asm__ __volatile__( \ "trap 47" \ :"=l"(par1) \ :"0"(par1),"l"(par2),"l"(par3),"l"(par4),"l"(par5),"l"(par6),"l"(par7) \ :"memory","L9","L10","L11","L12","L13","L14","L15"); \ \ if( par1 < 0 ) { \ __set_errno( -par1 ); \ return -1; \ } else \ return (type)(par1); \ return (type)(par1); \}#define _syscall6(type, name,atype, a, btype, b, ctype, c, dtype, d, etype, e, ftype, f) \type name(atype a, btype b, ctype c,dtype d, etype e, ftype f) \{ \ register int par1 __asm__("L15"); \ register int par2 __asm__("L14"); \ register int par3 __asm__("L13"); \ register int par4 __asm__("L12"); \ register int par5 __asm__("L11"); \ register int par6 __asm__("L10"); \ register int par7 __asm__("L9"); \ register int par8 __asm__("L8"); \ int sys_retval; \ par1 = -1; \ par2 = __NR_##name; \ par3 = (int)a; \ par4 = (int)b; \ par5 = (int)c; \ par6 = (int)d; \ par7 = (int)e; \ par7 = (int)f; \ __asm__ __volatile__( \ "trap 47" \ :"=l"(par1) \ :"0"(par1),"l"(par2),"l"(par3),"l"(par4),"l"(par5),"l"(par6),"l"(par7),"l"(par8) \ :"memory","L8","L9","L10","L11","L12","L13","L14","L15"); \ \ if( par1 < 0 ) { \ __set_errno( -par1 ); \ return -1; \ } else \ return (type)(par1); \}#define __syscall0(type, name) \type name(...) \{ \ register int par1 __asm__("L15"); \ register int par2 __asm__("L14"); \ par1 = -1; \ par2 = __NR_##name; \ __asm__ __volatile__( \ "trap 47" \ :"=l"(par1) \ :"0"(par1), "l"(par2)\ :"memory","L14","L15"); \ \ if( par1 < 0 ) { \ __set_errno( -par1 ); \ return -1; \ } else \ return (type)(par1); \}#define __syscall1(type, name, atype, a) \type name(atype a, ...) \{ \ register int par1 __asm__("L15"); \ register int par2 __asm__("L14"); \ register int par3 __asm__("L13"); \ par1 = -1; \ par2 = __NR_##name; \ par3 = (int)a; \ __asm__ __volatile__( \ "trap 47" \ :"=l"(par1) \ :"0"(par1), "l"(par2), "l"(par3)\ :"memory","L13","L14","L15"); \ \
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -