summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorpeter <peter@FreeBSD.org>2007-07-04 23:18:38 +0000
committerpeter <peter@FreeBSD.org>2007-07-04 23:18:38 +0000
commit1b55a32fbf471df5850c6998ad88edb70b2b1bc6 (patch)
tree974e0aa76f3ee9dad506c3e179d7fc5cb80d58e7
parent6d9e6c677c1a7ef838878317c645098d31f598ff (diff)
downloadFreeBSD-src-1b55a32fbf471df5850c6998ad88edb70b2b1bc6.zip
FreeBSD-src-1b55a32fbf471df5850c6998ad88edb70b2b1bc6.tar.gz
Adjust the syscall stub macros to be consistent in their meaning. In
particular: SYSCALL() makes a syscall, with errno handling, and continues execution directly after the macro in the non-error case. RSYSCALL() is just like SYSCALL(), but returns after success. Both SYSCALL(name) and RSYSCALL(name) export "__sys_name" as a strong symbol, with "_name" and "name" as weak aliases. PSEUDO() is just like RSYSCALL(), but skipping the "name" weak alias. It still does "__sys_name" and "_name". Change i386 to add errno handling to PSEUDO. The same for amd64 and sparc64, with appear to have copied the behavior. ia64 was correct (as was alpha). Just remove some apparently unused variants of the macros. (untested!) I believe powerpc is correct. Fix arm to not export "name" from the PSEUDO case. Remove apparently extra unused variants. (untested!) The errno problem manifested on i386/amd64/sparc64 by having "PSEUDO" classified syscalls return without setting errno. eg: "addr = mmap()" could return with "addr" = 22 instead of setting errno to 22 and returning -1. Approved by: re (kensmith)
-rw-r--r--lib/libc/amd64/SYS.h11
-rw-r--r--lib/libc/arm/SYS.h21
-rw-r--r--lib/libc/i386/SYS.h5
-rw-r--r--lib/libc/ia64/SYS.h14
-rw-r--r--lib/libc/sparc64/SYS.h3
5 files changed, 20 insertions, 34 deletions
diff --git a/lib/libc/amd64/SYS.h b/lib/libc/amd64/SYS.h
index 20811a0..ef75377 100644
--- a/lib/libc/amd64/SYS.h
+++ b/lib/libc/amd64/SYS.h
@@ -44,6 +44,12 @@
.set CNAME(__CONCAT(_,x)),CNAME(__CONCAT(__sys_,x)); \
mov __CONCAT($SYS_,x),%rax; KERNCALL; jb 2f; ret; \
2: movq PIC_GOT(HIDENAME(cerror)),%rcx; jmp *%rcx
+
+#define PSEUDO(x) ENTRY(__CONCAT(__sys_,x)); \
+ .weak CNAME(__CONCAT(_,x)); \
+ .set CNAME(__CONCAT(_,x)),CNAME(__CONCAT(__sys_,x)); \
+ mov __CONCAT($SYS_,x),%rax; KERNCALL; jb 2f; ret ; \
+ 2: movq PIC_GOT(HIDENAME(cerror)),%rcx; jmp *%rcx
#else
#define RSYSCALL(x) ENTRY(__CONCAT(__sys_,x)); \
.weak CNAME(x); \
@@ -52,11 +58,12 @@
.set CNAME(__CONCAT(_,x)),CNAME(__CONCAT(__sys_,x)); \
mov __CONCAT($SYS_,x),%rax; KERNCALL; jb 2f; ret; \
2: jmp HIDENAME(cerror)
-#endif
#define PSEUDO(x) ENTRY(__CONCAT(__sys_,x)); \
.weak CNAME(__CONCAT(_,x)); \
.set CNAME(__CONCAT(_,x)),CNAME(__CONCAT(__sys_,x)); \
- mov __CONCAT($SYS_,x),%rax; KERNCALL; ret
+ mov __CONCAT($SYS_,x),%rax; KERNCALL; jb 2f; ret; \
+ 2: jmp HIDENAME(cerror)
+#endif
#define KERNCALL movq %rcx, %r10; syscall
diff --git a/lib/libc/arm/SYS.h b/lib/libc/arm/SYS.h
index 4710876..223c26b 100644
--- a/lib/libc/arm/SYS.h
+++ b/lib/libc/arm/SYS.h
@@ -56,26 +56,19 @@
_SYSCALL_NOERROR(x); \
bcs PIC_SYM(CERROR, PLT)
-#define SYSCALL_NOERROR(x) \
- _SYSCALL_NOERROR(x)
-
#define SYSCALL(x) \
_SYSCALL(x)
-
-#define PSEUDO_NOERROR(x) \
- _SYSCALL_NOERROR(x); \
- RET
-
#define PSEUDO(x) \
- _SYSCALL(x); \
+ ENTRY(__CONCAT(__sys_, x)); \
+ .weak _C_LABEL(__CONCAT(_,x)); \
+ .set _C_LABEL(__CONCAT(_,x)),_C_LABEL(__CONCAT(__sys_,x)); \
+ SYSTRAP(x)
+ bcs PIC_SYM(CERROR, PLT)
RET
-
-#define RSYSCALL_NOERROR(x) \
- PSEUDO_NOERROR(x)
-
#define RSYSCALL(x) \
- PSEUDO(x)
+ _SYSCALL(x); \
+ RET
.globl CERROR
diff --git a/lib/libc/i386/SYS.h b/lib/libc/i386/SYS.h
index 6b79e3c..2f8a293 100644
--- a/lib/libc/i386/SYS.h
+++ b/lib/libc/i386/SYS.h
@@ -46,10 +46,11 @@
#define RSYSCALL(x) SYSCALL(x); ret
-#define PSEUDO(x) ENTRY(__CONCAT(__sys_,x)); \
+#define PSEUDO(x) 2: PIC_PROLOGUE; jmp PIC_PLT(HIDENAME(cerror)); \
+ ENTRY(__CONCAT(__sys_,x)); \
.weak CNAME(__CONCAT(_,x)); \
.set CNAME(__CONCAT(_,x)),CNAME(__CONCAT(__sys_,x)); \
- mov __CONCAT($SYS_,x),%eax; KERNCALL; ret
+ mov __CONCAT($SYS_,x),%eax; KERNCALL; jb 2b; ret
/* gas messes up offset -- although we don't currently need it, do for BCS */
#define LCALL(x,y) .byte 0x9a ; .long y; .word x
diff --git a/lib/libc/ia64/SYS.h b/lib/libc/ia64/SYS.h
index 64d50d2..eb019a2 100644
--- a/lib/libc/ia64/SYS.h
+++ b/lib/libc/ia64/SYS.h
@@ -50,28 +50,14 @@ ENTRY(__sys_ ## name,0); /* XXX # of args? */ \
WEAK_ALIAS(_ ## name, __sys_ ## name); \
CALLSYS_NOERROR(name)
-
#define RSYSCALL(name) \
SYSCALL(name); \
br.ret.sptk.few rp; \
END(__sys_ ## name)
-#define RSYSCALL_NOERROR(name) \
- SYSCALL_NOERROR(name); \
- br.ret.sptk.few rp; \
-END(__sys_ ## name)
-
-
#define PSEUDO(name) \
ENTRY(__sys_ ## name,0); /* XXX # of args? */ \
WEAK_ALIAS(_ ## name, __sys_ ## name); \
CALLSYS_ERROR(name); \
br.ret.sptk.few rp; \
END(__sys_ ## name);
-
-#define PSEUDO_NOERROR(name) \
-ENTRY(__sys_ ## name,0); /* XXX # of args? */ \
- WEAK_ALIAS(_ ## name, __sys_ ## name); \
- CALLSYS_NOERROR(name); \
- br.ret.sptk.few rp; \
-END(__sys_ ## name);
diff --git a/lib/libc/sparc64/SYS.h b/lib/libc/sparc64/SYS.h
index f98a8d4..0bc7840 100644
--- a/lib/libc/sparc64/SYS.h
+++ b/lib/libc/sparc64/SYS.h
@@ -78,8 +78,7 @@ ENTRY(__CONCAT(__sys_,x)) ; \
.weak CNAME(__CONCAT(_,x)) ; \
.type CNAME(__CONCAT(_,x)),@function ; \
.set CNAME(__CONCAT(_,x)),CNAME(__CONCAT(__sys_,x)) ; \
- mov __CONCAT(SYS_,x), %g1 ; \
- ta %xcc, ST_SYSCALL ; \
+ _SYSCALL(x) ; \
retl ; \
nop ; \
.size CNAME(__CONCAT(__sys_,x)), . - CNAME(__CONCAT(__sys_,x)) ; \
OpenPOWER on IntegriCloud