| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279 | {    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.    Old linux calling convention is still kept.    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 ATT}Procedure fpc_geteipasebx;[external name 'fpc_geteipasebx'];function FpSysCall(sysnr:TSysParam):TSysResult; assembler; oldfpccall;[public,alias:'FPC_SYSCALL0'];asm{ load the registers... }  movl  sysnr,%eax  int   $0x80  cmpl  $-4095,%eax  jb   .LSyscOK  negl  %eax{$ifdef FPC_PIC}  call  fpc_geteipasebx  addl  $_GLOBAL_OFFSET_TABLE_,%ebx  movl  fpc_threadvar_relocate_proc@GOT(%ebx),%ecx  movl  (%ecx),%ecx  movl  Errno@GOT(%ebx),%edi{$else FPC_PIC}  leal  Errno,%edi  movl  fpc_threadvar_relocate_proc,%ecx{$endif FPC_PIC}  testl %ecx,%ecx  jne   .LThread  movl  %eax,4(%edi)  jmp   .LNoThread.LThread:  movl  %eax,%ebx  movl  (%edi),%eax  call  *%ecx  movl  %ebx,(%eax).LNoThread:  movl  $-1,%eax.LSyscOK:end;function FpSysCall(sysnr,param1 : TSysParam):TSysResult; assembler; oldfpccall;[public,alias:'FPC_SYSCALL1'];asm{ load the registers... }  movl sysnr,%eax  movl param1,%ebx  int $0x80  cmpl  $-4095,%eax  jb   .LSyscOK  negl  %eax{$ifdef FPC_PIC}  call  fpc_geteipasebx  addl  $_GLOBAL_OFFSET_TABLE_,%ebx  movl  fpc_threadvar_relocate_proc@GOT(%ebx),%ecx  movl  (%ecx),%ecx  movl  Errno@GOT(%ebx),%edi{$else FPC_PIC}  leal  Errno,%edi  movl  fpc_threadvar_relocate_proc,%ecx{$endif FPC_PIC}  testl %ecx,%ecx  jne   .LThread  movl  %eax,4(%edi)  jmp   .LNoThread.LThread:  movl  %eax,%ebx  movl  (%edi),%eax  call  *%ecx  movl  %ebx,(%eax).LNoThread:  movl  $-1,%eax.LSyscOK:end;function FpSysCall(sysnr,param1,param2 : TSysParam):TSysResult; assembler; oldfpccall; [public,alias:'FPC_SYSCALL2'];asm{ load the registers... }  movl sysnr,%eax  movl param1,%ebx  movl param2,%ecx  int $0x80  cmpl  $-4095,%eax  jb   .LSyscOK  negl  %eax{$ifdef FPC_PIC}  call  fpc_geteipasebx  addl  $_GLOBAL_OFFSET_TABLE_,%ebx  movl  fpc_threadvar_relocate_proc@GOT(%ebx),%ecx  movl  (%ecx),%ecx  movl  Errno@GOT(%ebx),%edi{$else FPC_PIC}  leal  Errno,%edi  movl  fpc_threadvar_relocate_proc,%ecx{$endif FPC_PIC}  testl %ecx,%ecx  jne   .LThread  movl  %eax,4(%edi)  jmp   .LNoThread.LThread:  movl  %eax,%ebx  movl (%edi),%eax  call  *%ecx  movl  %ebx,(%eax).LNoThread:  movl  $-1,%eax.LSyscOK:end;function FpSysCall(sysnr,param1,param2,param3:TSysParam):TSysResult; assembler; oldfpccall; [public,alias:'FPC_SYSCALL3'];asm{ load the registers... }  movl sysnr,%eax  movl param1,%ebx  movl param2,%ecx  movl param3,%edx  int $0x80  cmpl  $-4095,%eax  jb   .LSyscOK  negl  %eax{$ifdef FPC_PIC}  call  fpc_geteipasebx  addl  $_GLOBAL_OFFSET_TABLE_,%ebx  movl  fpc_threadvar_relocate_proc@GOT(%ebx),%ecx  movl  (%ecx),%ecx  movl  Errno@GOT(%ebx),%edi{$else FPC_PIC}  leal  Errno,%edi  movl  fpc_threadvar_relocate_proc,%ecx{$endif FPC_PIC}  testl %ecx,%ecx  jne   .LThread  movl  %eax,4(%edi)  jmp   .LNoThread.LThread:  movl  %eax,%ebx  movl  (%edi),%eax  call  *%ecx  movl  %ebx,(%eax).LNoThread:  movl  $-1,%eax.LSyscOK:end;function FpSysCall(sysnr,param1,param2,param3,param4:TSysParam):TSysResult; assembler; oldfpccall; [public,alias:'FPC_SYSCALL4'];asm{ load the registers... }  movl sysnr,%eax  movl param1,%ebx  movl param2,%ecx  movl param3,%edx  movl param4,%esi  int $0x80  cmpl  $-4095,%eax  jb   .LSyscOK  negl  %eax{$ifdef FPC_PIC}  call  fpc_geteipasebx  addl  $_GLOBAL_OFFSET_TABLE_,%ebx  movl  fpc_threadvar_relocate_proc@GOT(%ebx),%ecx  movl  (%ecx),%ecx  movl  Errno@GOT(%ebx),%edi{$else FPC_PIC}  leal  Errno,%edi  movl  fpc_threadvar_relocate_proc,%ecx{$endif FPC_PIC}  testl %ecx,%ecx  jne   .LThread  movl  %eax,4(%edi)  jmp   .LNoThread.LThread:  movl  %eax,%ebx  movl  (%edi),%eax  call  *%ecx  movl  %ebx,(%eax).LNoThread:  movl  $-1,%eax.LSyscOK:end;function FpSysCall(sysnr,param1,param2,param3,param4,param5 : TSysParam):TSysResult; assembler; oldfpccall;[public,alias:'FPC_SYSCALL5'];asm{ load the registers... }  movl sysnr,%eax  movl param1,%ebx  movl param2,%ecx  movl param3,%edx  movl param4,%esi  movl param5,%edi  int $0x80  cmpl  $-4095,%eax  jb   .LSyscOK  negl  %eax{$ifdef FPC_PIC}  call  fpc_geteipasebx  addl  $_GLOBAL_OFFSET_TABLE_,%ebx  movl  fpc_threadvar_relocate_proc@GOT(%ebx),%ecx  movl  (%ecx),%ecx  movl  Errno@GOT(%ebx),%edi{$else FPC_PIC}  leal  Errno,%edi  movl  fpc_threadvar_relocate_proc,%ecx{$endif FPC_PIC}  testl %ecx,%ecx  jne   .LThread  movl  %eax,4(%edi)  jmp   .LNoThread.LThread:  movl  %eax,%ebx  movl  (%edi),%eax  call  *%ecx  movl  %ebx,(%eax).LNoThread:  movl  $-1,%eax.LSyscOK:end;{$ifdef notsupported}{ Only 5 params are pushed, so it'll not work as expected (PFV) }function FpSysCall(sysnr,param1,param2,param3,param4,param5,param6 : TSysParam):TSysResult; assembler; oldfpccall;[public,alias:'FPC_SYSCALL6'];asm{ load the registers... }  movl sysnr,%eax  movl param1,%ebx  movl param2,%ecx  movl param3,%edx  movl param4,%esi  movl param5,%edi  int $0x80  cmpl  $-4095,%eax  jb   .LSyscOK  negl  %eax{$ifdef FPC_PIC}  call  fpc_geteipasebx  addl  $_GLOBAL_OFFSET_TABLE_,%ebx  movl  fpc_threadvar_relocate_proc@GOT(%ebx),%ecx  movl  (%ecx),%ecx  movl  Errno@GOT(%ebx),%edi{$else FPC_PIC}  leal  Errno,%edi  movl  fpc_threadvar_relocate_proc,%ecx{$endif FPC_PIC}  testl %ecx,%ecx  jne   .LThread  movl  %eax,4(%edi)  jmp   .LNoThread.LThread:  movl  %eax,%ebx  movl  (%edi),%eax  call  *%ecx  movl  %ebx,(%eax).LNoThread:  movl  $-1,%eax.LSyscOK:end;{$endif notsupported}{No debugging for syslinux include !}{$IFDEF SYS_LINUX}  {$UNDEF SYSCALL_DEBUG}{$ENDIF SYS_LINUX}
 |