|
@@ -1,140 +1,207 @@
|
|
|
{
|
|
|
$Id$
|
|
|
- Copyright (c) 2002 by Marco van de Voort
|
|
|
+ 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.
|
|
|
|
|
|
- Syscall functions for i386 *BSD.
|
|
|
-
|
|
|
- This program is free software; you can redistribute it and/or modify
|
|
|
- it under the terms of the GNU General Public License as published by
|
|
|
- the Free Software Foundation; either version 2 of the License, or
|
|
|
- (at your option) any later version.
|
|
|
+ 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. See the
|
|
|
- GNU General Public License for more details.
|
|
|
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
+
|
|
|
+ **********************************************************************}
|
|
|
|
|
|
- You should have received a copy of the GNU General Public License
|
|
|
- along with this program; if not, write to the Free Software
|
|
|
- Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
+{No debugging for syslinux include !}
|
|
|
+{$IFDEF SYS_LINUX}
|
|
|
+ {$UNDEF SYSCALL_DEBUG}
|
|
|
+{$ENDIF SYS_LINUX}
|
|
|
|
|
|
- ****************************************************************************
|
|
|
|
|
|
-procedure actualsyscall; assembler;
|
|
|
+{*****************************************************************************
|
|
|
+ --- Main:The System Call Self ---
|
|
|
+*****************************************************************************}
|
|
|
|
|
|
+function FpSysCall(sysnr:TSysParam):TSysResult; assembler;[public,alias:'FPC_SYSCALL0'];
|
|
|
+{
|
|
|
+ This function puts the registers in place, does the call, and then
|
|
|
+ copies back the registers as they are after the SysCall.
|
|
|
+}
|
|
|
asm
|
|
|
+ mr r0,r3
|
|
|
sc
|
|
|
- b LSyscallError
|
|
|
blr
|
|
|
-LSyscallError:
|
|
|
- stw r3,errno
|
|
|
+ neg r3, r3
|
|
|
+ lis r4,(Errno+4)@ha
|
|
|
+ stw r3,(Errno+4)@l(r4)
|
|
|
+ li r3,-1
|
|
|
end;
|
|
|
|
|
|
-
|
|
|
-function Do_SysCall(sysnr:LONGINT):longint; assembler; [public,alias:'FPC_DOSYS0'];
|
|
|
-
|
|
|
+function FpSysCall(sysnr,param1:TSysParam):TSysResult; assembler;[public,alias:'FPC_SYSCALL1'];
|
|
|
+{
|
|
|
+ This function puts the registers in place, does the call, and then
|
|
|
+ copies back the registers as they are after the SysCall.
|
|
|
+}
|
|
|
asm
|
|
|
- mr r0,r3
|
|
|
- b actualsyscall
|
|
|
-end;
|
|
|
-
|
|
|
-
|
|
|
-function Do_SysCall(sysnr,param1:longint):longint; assembler;[public,alias:'FPC_DOSYS1'];
|
|
|
-
|
|
|
- asm
|
|
|
mr r0,r3
|
|
|
mr r3,r4
|
|
|
- b actualsyscall
|
|
|
- end;
|
|
|
-
|
|
|
-
|
|
|
-function Do_SysCall(sysnr,param1:integer):longint; assembler;[public,alias:'FPC_DOSYS1w'];
|
|
|
-
|
|
|
- asm
|
|
|
- rlwinm r0,r3,0,0,15
|
|
|
- extsh r3,r4
|
|
|
- b actualsyscall
|
|
|
- end;
|
|
|
-
|
|
|
+ sc
|
|
|
+ blr
|
|
|
+ neg r3, r3
|
|
|
+ lis r4,(Errno+4)@ha
|
|
|
+ stw r3,(Errno+4)@l(r4)
|
|
|
+ li r3,-1
|
|
|
+end;
|
|
|
|
|
|
-function Do_SysCall(sysnr,param1,param2:LONGINT):longint; assembler; [public,alias:'FPC_DOSYS2'];
|
|
|
|
|
|
- asm
|
|
|
+function FpSysCall(sysnr,param1,param2:TSysParam):TSysResult; assembler;[public,alias:'FPC_SYSCALL2'];
|
|
|
+{
|
|
|
+ This function puts the registers in place, does the call, and then
|
|
|
+ copies back the registers as they are after the SysCall.
|
|
|
+}
|
|
|
+asm
|
|
|
mr r0,r3
|
|
|
mr r3,r4
|
|
|
mr r4,r5
|
|
|
- b actualsyscall
|
|
|
- end;
|
|
|
-
|
|
|
-
|
|
|
-function Do_SysCall(sysnr,param1,param2,param3:LONGINT):longint; assembler;[public,alias:'FPC_DOSYS3'];
|
|
|
+ sc
|
|
|
+ blr
|
|
|
+ neg r3, r3
|
|
|
+ lis r4,(Errno+4)@ha
|
|
|
+ stw r3,(Errno+4)@l(r4)
|
|
|
+ li r3,-1
|
|
|
+end;
|
|
|
|
|
|
- asm
|
|
|
+function FpSysCall(sysnr,param1,param2,param3:TSysParam):TSysResult; assembler;[public,alias:'FPC_SYSCALL3'];
|
|
|
+{
|
|
|
+ This function puts the registers in place, does the call, and then
|
|
|
+ copies back the registers as they are after the SysCall.
|
|
|
+}
|
|
|
+asm
|
|
|
mr r0,r3
|
|
|
mr r3,r4
|
|
|
mr r4,r5
|
|
|
mr r5,r6
|
|
|
- b actualsyscall
|
|
|
+ sc
|
|
|
+ blr
|
|
|
+ neg r3, r3
|
|
|
+ lis r4,(Errno+4)@ha
|
|
|
+ stw r3,(Errno+4)@l(r4)
|
|
|
+ li r3,-1
|
|
|
end;
|
|
|
|
|
|
|
|
|
-function Do_SysCall(sysnr,param1,param2,param3,param4:LONGINT):longint; assembler;[public,alias:'FPC_DOSYS4'];
|
|
|
-
|
|
|
+function FpSysCall(sysnr,param1,param2,param3,param4:TSysParam):TSysResult; assembler;[public,alias:'FPC_SYSCALL4'];
|
|
|
+{
|
|
|
+ This function puts the registers in place, does the call, and then
|
|
|
+ copies back the registers as they are after the SysCall.
|
|
|
+}
|
|
|
asm
|
|
|
mr r0,r3
|
|
|
- mr r3,r4
|
|
|
+ mr r3,r4
|
|
|
mr r4,r5
|
|
|
mr r5,r6
|
|
|
mr r6,r7
|
|
|
- b actualsyscall
|
|
|
+ sc
|
|
|
+ blr
|
|
|
+ neg r3, r3
|
|
|
+ lis r4,(Errno+4)@ha
|
|
|
+ stw r3,(Errno+4)@l(r4)
|
|
|
+ li r3,-1
|
|
|
end;
|
|
|
|
|
|
-
|
|
|
-function Do_SysCall(sysnr,param1,param2,param3,param4,param5:LONGINT):longint; assembler;[public,alias:'FPC_DOSYS5'];
|
|
|
-
|
|
|
- asm
|
|
|
+function FpSysCall(sysnr,param1,param2,param3,param4,param5:TSysParam):TSysResult; assembler;[public,alias:'FPC_SYSCALL5'];
|
|
|
+{
|
|
|
+ This function puts the registers in place, does the call, and then
|
|
|
+ copies back the registers as they are after the SysCall.
|
|
|
+}
|
|
|
+asm
|
|
|
mr r0,r3
|
|
|
mr r3,r4
|
|
|
mr r4,r5
|
|
|
- mr r5,r6
|
|
|
+ mr r5,r6
|
|
|
mr r6,r7
|
|
|
mr r7,r8
|
|
|
- b actualsyscall
|
|
|
+ sc
|
|
|
+ blr
|
|
|
+ neg r3, r3
|
|
|
+ lis r4,(Errno+4)@ha
|
|
|
+ stw r3,(Errno+4)@l(r4)
|
|
|
+ li r3,-1
|
|
|
end;
|
|
|
|
|
|
|
|
|
-function Do_SysCall(sysnr,param1,param2,param3,param4,param5,param6:LONGINT):int64; assembler;[public,alias:'FPC_DOSYS6'];
|
|
|
-
|
|
|
+function FpSysCall(sysnr,param1,param2,param3,param4,param5,param6:TSysParam):TSysResult; assembler;[public,alias:'FPC_SYSCALL6'];
|
|
|
+{
|
|
|
+ This function puts the registers in place, does the call, and then
|
|
|
+ copies back the registers as they are after the SysCall.
|
|
|
+}
|
|
|
asm
|
|
|
mr r0,r3
|
|
|
- mr r3,r4
|
|
|
+ mr r3,r4
|
|
|
mr r4,r5
|
|
|
mr r5,r6
|
|
|
- mr r6,r7
|
|
|
+ mr r6,r7
|
|
|
mr r7,r8
|
|
|
mr r8,r9
|
|
|
- b actualsyscall
|
|
|
+ sc
|
|
|
+ blr
|
|
|
+ neg r3, r3
|
|
|
+ lis r4,(Errno+4)@ha
|
|
|
+ stw r3,(Errno+4)@l(r4)
|
|
|
+ li r3,-1
|
|
|
end;
|
|
|
|
|
|
|
|
|
-function Do_SysCall(sysnr,param1,param2,param3,param4,param5,param6,param7:LONGINT):int64; assembler; [public,alias:'FPC_DOSYS7'];
|
|
|
-
|
|
|
+function FpSysCall(sysnr,param1,param2,param3,param4,param5,param6,param7:TSysParam):TSysResult; assembler;[public,alias:'FPC_SYSCALL7'];
|
|
|
+{
|
|
|
+ This function puts the registers in place, does the call, and then
|
|
|
+ copies back the registers as they are after the SysCall.
|
|
|
+}
|
|
|
asm
|
|
|
mr r0,r3
|
|
|
mr r3,r4
|
|
|
- mr r4,r5
|
|
|
- mr r5,r6
|
|
|
- mr r6,r7
|
|
|
+ mr r4,r5
|
|
|
+ mr r5,r6
|
|
|
+ mr r6,r7
|
|
|
mr r7,r8
|
|
|
mr r8,r9
|
|
|
mr r9,r10
|
|
|
- b actualsyscall
|
|
|
+ sc
|
|
|
+ blr
|
|
|
+ neg r3, r3
|
|
|
+ lis r4,(Errno+4)@ha
|
|
|
+ stw r3,(Errno+4)@l(r4)
|
|
|
+ li r3,-1
|
|
|
end;
|
|
|
|
|
|
{
|
|
|
$Log$
|
|
|
- Revision 1.1 2002-10-26 14:33:09 jonas
|
|
|
- + initial version
|
|
|
-:
|
|
|
+ Revision 1.2 2003-05-25 13:51:58 jonas
|
|
|
+ * several fixes, addition of Mach trap numbers (thye are simply syscalls
|
|
|
+ with a negative number)
|
|
|
+
|
|
|
+ Revision 1.6 2003/05/23 21:58:30 jonas
|
|
|
+ * fixed storing to errno for single threaded programs
|
|
|
+
|
|
|
+ Revision 1.5 2003/05/11 16:07:55 jonas
|
|
|
+ * fixed mmap for non-i386 non-m68k architectures (not sure about
|
|
|
+ x86-64)
|
|
|
+
|
|
|
+ Revision 1.4 2003/04/22 17:07:55 florian
|
|
|
+ * there where two SYSCALL1 procedures for the powerpc, fixed
|
|
|
+
|
|
|
+ Revision 1.3 2003/01/09 13:38:26 florian
|
|
|
+ * syscall stuff fixed
|
|
|
+
|
|
|
+ Revision 1.2 2002/12/22 16:00:28 jonas
|
|
|
+ + added syscallh.inc, adapted syscall.inc
|
|
|
+
|
|
|
+ Revision 1.1 2002/11/09 20:32:14 marco
|
|
|
+ * powerpc version. Threadsafe errno access not yet done.
|
|
|
+
|
|
|
+ Revision 1.1 2002/10/14 19:39:44 peter
|
|
|
+ * syscall moved into seperate include
|
|
|
|
|
|
}
|
|
|
+
|