| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237 | {    This file is part of the Free Pascal run time library.    Copyright (c) 1999-2000 by Michael Van Canneyt,    member of the Free Pascal development team.    The syscalls for the new RTL, moved to platform dependant dir.    See the file COPYING.FPC, included in this distribution,    for details about the copyright.    This program is distributed in the hope that it will be useful,    but WITHOUT ANY WARRANTY; without even the implied warranty of    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. **********************************************************************}{$ASMMODE GAS}{$ifdef FPC_PROFILE}procedure mcount; external name 'mcount';{$endif FPC_PROFILE}function FpSysCall(sysnr:TSysParam):TSysResult; assembler; nostackframe; [public,alias:'FPC_SYSCALL0'];asm  pushq %rax              { keep stack aligned }{$ifdef FPC_PROFILE}  pushq sysnr  call mcount  popq sysnr{$endif FPC_PROFILE}  movq sysnr, %rax        { Syscall number -> rax.  }  syscall                 { Do the system call. }  cmpq $-4095, %rax       { Check %rax for error.  }  jnae .LSyscOK           { Jump to error handler if error.  }  negq  %rax  movq  %rax,%rdi  call  seterrno@PLT  movq  $-1,%rax.LSyscOK:  popq %rcx               { remove alignment }end;function FpSysCall(sysnr,param1 : TSysParam):TSysResult; assembler; nostackframe; [public,alias:'FPC_SYSCALL1'];asm  pushq %rax              { keep stack aligned }{$ifdef FPC_PROFILE}  pushq sysnr  pushq param1  call mcount  popq param1  popq sysnr{$endif FPC_PROFILE}  movq sysnr, %rax        { Syscall number -> rax.  }  movq param1, %rdi         { shift arg1 - arg5. }  syscall                 { Do the system call. }  cmpq $-4095, %rax       { Check %rax for error.  }  jnae .LSyscOK           { Jump to error handler if error.  }  negq  %rax  movq  %rax,%rdi  call  seterrno@PLT  movq  $-1,%rax.LSyscOK:  popq %rcx               { remove alignment }end;function FpSysCall(sysnr,param1,param2 : TSysParam):TSysResult; assembler; nostackframe; [public,alias:'FPC_SYSCALL2'];asm  pushq %rax              { keep stack aligned }{$ifdef FPC_PROFILE}  pushq sysnr  pushq param1  pushq param2  call mcount  popq param2  popq param1  popq sysnr{$endif FPC_PROFILE}  movq sysnr, %rax        { Syscall number -> rax.  }  movq param1, %rdi         { shift arg1 - arg5. }  movq param2, %rsi  syscall                 { Do the system call. }  cmpq $-4095, %rax       { Check %rax for error.  }  jnae .LSyscOK           { Jump to error handler if error.  }  negq  %rax  movq  %rax,%rdi  call  seterrno@PLT  movq  $-1,%rax.LSyscOK:  popq %rcx               { remove alignment }end;function FpSysCall(sysnr,param1,param2,param3:TSysParam):TSysResult; assembler; nostackframe; [public,alias:'FPC_SYSCALL3'];asm  pushq %rax              { keep stack aligned }{$ifdef FPC_PROFILE}  pushq sysnr  pushq param1  pushq param2  pushq param3  call mcount  popq param3  popq param2  popq param1  popq sysnr{$endif FPC_PROFILE}  movq sysnr, %rax        { Syscall number -> rax.  }  movq param1, %rdi         { shift arg1 - arg5. }  movq param2, %rsi  movq param3, %rdx  syscall                 { Do the system call. }  cmpq $-4095, %rax       { Check %rax for error.  }  jnae .LSyscOK           { Jump to error handler if error.  }  negq  %rax  movq  %rax,%rdi  call  seterrno@PLT  movq  $-1,%rax.LSyscOK:  popq %rcx               { remove alignment }end;function FpSysCall(sysnr,param1,param2,param3,param4:TSysParam):TSysResult; assembler; nostackframe; [public,alias:'FPC_SYSCALL4'];asm  pushq %rax              { keep stack aligned }{$ifdef FPC_PROFILE}  pushq sysnr  pushq param1  pushq param2  pushq param3  pushq param4  call mcount  popq param4  popq param3  popq param2  popq param1  popq sysnr{$endif FPC_PROFILE}  movq sysnr, %rax        { Syscall number -> rax.  }  movq param1, %rdi         { shift arg1 - arg5. }  movq param2, %rsi  movq param3, %rdx  movq param4, %r10  syscall                 { Do the system call. }  cmpq $-4095, %rax       { Check %rax for error.  }  jnae .LSyscOK           { Jump to error handler if error.  }  negq  %rax  movq  %rax,%rdi  call  seterrno@PLT  movq  $-1,%rax.LSyscOK:  popq %rcx               { remove alignment }end;function FpSysCall(sysnr,param1,param2,param3,param4,param5 : TSysParam):TSysResult; assembler; nostackframe; [public,alias:'FPC_SYSCALL5'];asm  pushq %rax              { keep stack aligned }{$ifdef FPC_PROFILE}  pushq sysnr  pushq param1  pushq param2  pushq param3  pushq param4  pushq param5  call mcount  popq param5  popq param4  popq param3  popq param2  popq param1  popq sysnr{$endif FPC_PROFILE}  movq sysnr, %rax        { Syscall number -> rax.  }  movq param1, %rdi         { shift arg1 - arg5. }  movq param2, %rsi  movq param3, %rdx  movq param4, %r10  movq param5, %r8  syscall                 { Do the system call. }  cmpq $-4095, %rax       { Check %rax for error.  }  jnae .LSyscOK           { Jump to error handler if error.  }  negq  %rax  movq  %rax,%rdi  call  seterrno@PLT  movq  $-1,%rax.LSyscOK:  popq %rcx               { remove alignment }end;function FpSysCall(sysnr,param1,param2,param3,param4,param5,param6 : TSysParam):TSysResult; assembler;[public,alias:'FPC_SYSCALL6'];asm{$ifdef FPC_PROFILE}  pushq sysnr  pushq param1  pushq param2  pushq param3  pushq param4  pushq param5  pushq param6  call mcount  popq param6  popq param5  popq param4  popq param3  popq param2  popq param1  popq sysnr{$endif FPC_PROFILE}  movq sysnr, %rax        { Syscall number -> rax.  }  movq param1, %rdi         { shift arg1 - arg5. }  movq param2, %rsi  movq param3, %rdx  movq param4, %r10  movq param5, %r8  movq param6, %r9  syscall                 { Do the system call. }  cmpq $-4095, %rax       { Check %rax for error.  }  jnae .LSyscOK           { Jump to error handler if error.  }  negq  %rax  movq  %rax,%rdi  call  seterrno@PLT  movq  $-1,%rax.LSyscOK:end;{No debugging for system include !}{$IFDEF SYS_LINUX}  {$UNDEF SYSCALL_DEBUG}{$ENDIF SYS_LINUX}
 |