* sysdeps/sparc/sparc32/dl-trampoline.S: Add CFI markings.

* sysdeps/sparc/sparc32/elf/start.S: Likewise.
	* sysdeps/sparc/sparc64/dl-trampoline.S: Likewise.
	* sysdeps/sparc/sparc64/elf/start.S: Likewise.
	* sysdeps/sparc/sparc32/memchr.S: Rearrange code to reside
	within ENTRY/END.
	* sysdeps/sparc/sparc32/memcpy.S: Likewise.
	* sysdeps/sparc/sparc32/stpcpy.S: Likewise.
	* sysdeps/sparc/sparc32/strcat.S: Likewise.
	* sysdeps/sparc/sparc32/strchr.S: Likewise.
	* sysdeps/sparc/sparc32/strcmp.S: Likewise.
	* sysdeps/sparc/sparc32/strcpy.S: Likewise.
	* sysdeps/sparc/sparc32/strlen.S: Likewise.
	* sysdeps/sparc/sparc64/memcpy.S: Likewise.
	* sysdeps/sparc/sparc64/sparcv9v/memset.S: Likewise.
	* sysdeps/unix/sysv/linux/sparc/sparc32/clone.S: Add CFI markings
	and use __syscall_error.
	* sysdeps/unix/sysv/linux/sparc/sparc64/clone.S: Likewise.
	* sysdeps/unix/sysv/linux/sparc/sparc64/brk.S: Likewise.
	* sysdeps/unix/sysv/linux/sparc/sparc32/pipe.S: Use __syscall_error.
	* sysdeps/unix/sysv/linux/sparc/sparc64/pipe.S: Likewise.
	* sysdeps/unix/sysv/linux/sparc/sparc32/socket.S: Likewise.
	* sysdeps/unix/sysv/linux/sparc/sparc64/socket.S: Likewise.
	* sysdeps/unix/sysv/linux/sparc/sparc32/syscall.S: Likewise.
	* sysdeps/unix/sysv/linux/sparc/sparc64/syscall.S: Likewise.
	* sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h: Rewrite to use
	CFI markings and __syscall_error.
	* sysdeps/unix/sysv/linux/sparc/sparc64/sysdep.h: Likewise.
	* sysdeps/unix/sysv/linux/sparc/sparc64/setcontext.S: Rearrange
	code to reside within ENTRY/END.
	* sysdeps/unix/sysv/linux/sparc/sparc64/setjmp.S: Likewise.
	* sysdeps/unix/sysv/linux/sparc/sysdep.c: New file.
	* sysdeps/unix/sysv/linux/sparc/sysdep.S: File removed.
	* sysdeps/unix/sysv/linux/sparc/rt-sysdep.c: New file.
	* sysdeps/unix/sysv/linux/sparc/Makefile (librt-routines): Add it.
This commit is contained in:
Roland McGrath 2006-03-06 01:41:08 +00:00
parent 043cee3700
commit 7ccbe1a133
10 changed files with 164 additions and 116 deletions

View File

@ -1,5 +1,41 @@
2006-03-05 David S. Miller <davem@sunset.davemloft.net> 2006-03-05 David S. Miller <davem@sunset.davemloft.net>
* sysdeps/sparc/sparc32/dl-trampoline.S: Add CFI markings.
* sysdeps/sparc/sparc32/elf/start.S: Likewise.
* sysdeps/sparc/sparc64/dl-trampoline.S: Likewise.
* sysdeps/sparc/sparc64/elf/start.S: Likewise.
* sysdeps/sparc/sparc32/memchr.S: Rearrange code to reside
within ENTRY/END.
* sysdeps/sparc/sparc32/memcpy.S: Likewise.
* sysdeps/sparc/sparc32/stpcpy.S: Likewise.
* sysdeps/sparc/sparc32/strcat.S: Likewise.
* sysdeps/sparc/sparc32/strchr.S: Likewise.
* sysdeps/sparc/sparc32/strcmp.S: Likewise.
* sysdeps/sparc/sparc32/strcpy.S: Likewise.
* sysdeps/sparc/sparc32/strlen.S: Likewise.
* sysdeps/sparc/sparc64/memcpy.S: Likewise.
* sysdeps/sparc/sparc64/sparcv9v/memset.S: Likewise.
* sysdeps/unix/sysv/linux/sparc/sparc32/clone.S: Add CFI markings
and use __syscall_error.
* sysdeps/unix/sysv/linux/sparc/sparc64/clone.S: Likewise.
* sysdeps/unix/sysv/linux/sparc/sparc64/brk.S: Likewise.
* sysdeps/unix/sysv/linux/sparc/sparc32/pipe.S: Use __syscall_error.
* sysdeps/unix/sysv/linux/sparc/sparc64/pipe.S: Likewise.
* sysdeps/unix/sysv/linux/sparc/sparc32/socket.S: Likewise.
* sysdeps/unix/sysv/linux/sparc/sparc64/socket.S: Likewise.
* sysdeps/unix/sysv/linux/sparc/sparc32/syscall.S: Likewise.
* sysdeps/unix/sysv/linux/sparc/sparc64/syscall.S: Likewise.
* sysdeps/unix/sysv/linux/sparc/sparc32/sysdep.h: Rewrite to use
CFI markings and __syscall_error.
* sysdeps/unix/sysv/linux/sparc/sparc64/sysdep.h: Likewise.
* sysdeps/unix/sysv/linux/sparc/sparc64/setcontext.S: Rearrange
code to reside within ENTRY/END.
* sysdeps/unix/sysv/linux/sparc/sparc64/setjmp.S: Likewise.
* sysdeps/unix/sysv/linux/sparc/sysdep.c: New file.
* sysdeps/unix/sysv/linux/sparc/sysdep.S: File removed.
* sysdeps/unix/sysv/linux/sparc/rt-sysdep.c: New file.
* sysdeps/unix/sysv/linux/sparc/Makefile (librt-routines): Add it.
* shlib-versions: Use sparc64.*- for CPU patterns. * shlib-versions: Use sparc64.*- for CPU patterns.
2006-03-05 Roland McGrath <roland@frob.com> 2006-03-05 Roland McGrath <roland@frob.com>

View File

@ -1,3 +1,8 @@
2006-03-05 Roland McGrath <roland@redhat.com>
* configure (libc_add_on): Disable add-on when $add_ons_automatic = yes
and $config_os doesn't match *linux*.
2006-03-05 David S. Miller <davem@sunset.davemloft.net> 2006-03-05 David S. Miller <davem@sunset.davemloft.net>
* sysdeps/unix/sysv/linux/sparc/sparc32/pt-vfork.S: * sysdeps/unix/sysv/linux/sparc/sparc32/pt-vfork.S:

8
nptl/configure vendored
View File

@ -3,3 +3,11 @@
# as a subdirectory to search for in other add-ons' sysdeps trees. # as a subdirectory to search for in other add-ons' sysdeps trees.
libc_add_on_canonical=nptl libc_add_on_canonical=nptl
# Only linux configurations support NPTL.
if test $add_ons_automatic = yes; then
case "$config_os" in
*linux*) ;;
*) libc_add_on= ;;
esac
fi

View File

@ -0,0 +1,2 @@
# pull in __syscall_error routine
libpthread-routines += sysdep

View File

@ -21,6 +21,7 @@
#include <tcb-offsets.h> #include <tcb-offsets.h>
.text .text
.globl __syscall_error
ENTRY(__vfork) ENTRY(__vfork)
ld [%g7 + PID], %o5 ld [%g7 + PID], %o5
sub %g0, %o5, %o4 sub %g0, %o5, %o4
@ -28,15 +29,17 @@ ENTRY(__vfork)
LOADSYSCALL(vfork) LOADSYSCALL(vfork)
ta 0x10 ta 0x10
bcs,a __syscall_error_handler bcc 2f
st %o5, [%g7 + PID] mov %o7, %g1
SYSCALL_ERROR_HANDLER st %o5, [%g7 + PID]
sub %o1, 1, %o1 call __syscall_error
mov %g1, %o7
2: sub %o1, 1, %o1
andcc %o0, %o1, %o0 andcc %o0, %o1, %o0
bne,a 1f bne,a 1f
st %o5, [%g7 + PID] st %o5, [%g7 + PID]
1: retl 1: retl
nop nop
END(__vfork)
PSEUDO_END (__vfork)
weak_alias (__vfork, vfork) weak_alias (__vfork, vfork)

View File

@ -26,55 +26,48 @@
#if !defined NOT_IN_libc || defined IS_IN_libpthread || defined IS_IN_librt #if !defined NOT_IN_libc || defined IS_IN_libpthread || defined IS_IN_librt
# undef PSEUDO # undef PSEUDO
# define PSEUDO(name, syscall_name, args) \ # define PSEUDO(name, syscall_name, args) \
.text; \ .text; \
ENTRY(name) \ .globl __syscall_error; \
ld [%g7 + MULTIPLE_THREADS_OFFSET], %g1; \ ENTRY(name) \
cmp %g1, 0; \ ld [%g7 + MULTIPLE_THREADS_OFFSET], %g1;\
bne 1f; \ cmp %g1, 0; \
.type __##syscall_name##_nocancel,@function; \ bne 1f; \
.globl __##syscall_name##_nocancel; \ .type __##syscall_name##_nocancel,@function; \
__##syscall_name##_nocancel: \ .globl __##syscall_name##_nocancel; \
mov SYS_ify(syscall_name), %g1; \ __##syscall_name##_nocancel: \
ta 0x10; \ mov SYS_ify(syscall_name), %g1; \
bcs __syscall_error_handler; \ ta 0x10; \
nop; \ bcc 8f; \
.size __##syscall_name##_nocancel,.-__##syscall_name##_nocancel; \ mov %o7, %g1; \
.subsection 2; \ call __syscall_error; \
cfi_startproc; \ mov %g1, %o7; \
1: save %sp, -96, %sp; \ 8: jmpl %o7 + 8, %g0; \
cfi_def_cfa_register (%fp); \ nop; \
cfi_window_save; \ .size __##syscall_name##_nocancel,.-__##syscall_name##_nocancel;\
cfi_register (%o7, %i7); \ 1: save %sp, -96, %sp; \
CENABLE; \ cfi_def_cfa_register(%fp); \
nop; \ cfi_window_save; \
mov %o0, %l0; \ cfi_register(%o7, %i7); \
COPY_ARGS_##args \ CENABLE; \
mov SYS_ify(syscall_name), %g1; \ nop; \
ta 0x10; \ mov %o0, %l0; \
bcs __syscall_error_handler2; \ COPY_ARGS_##args \
mov %o0, %l1; \ mov SYS_ify(syscall_name), %g1; \
CDISABLE; \ ta 0x10; \
mov %l0, %o0; \ bcc 1f; \
jmpl %i7 + 8, %g0; \ mov %o0, %l1; \
restore %g0, %l1, %o0; \ CDISABLE; \
cfi_endproc; \ mov %l0, %o0; \
.previous; \ call __syscall_error; \
SYSCALL_ERROR_HANDLER \ mov %l1, %o0; \
SYSCALL_ERROR_HANDLER2 b 2f; \
mov -1, %l1; \
1: CDISABLE; \
mov %l0, %o0; \
2: jmpl %i7 + 8, %g0; \
restore %g0, %l1, %o0;
#define SYSCALL_ERROR_HANDLER2 \
SYSCALL_ERROR_HANDLER_ENTRY(__syscall_error_handler2) \
.global __errno_location; \
.type __errno_location,@function; \
CDISABLE; \
mov %l0, %o0; \
call __errno_location; \
nop; \
st %l1, [%o0]; \
jmpl %i7 + 8, %g0; \
restore %g0, -1, %o0; \
.previous;
# ifdef IS_IN_libpthread # ifdef IS_IN_libpthread
# define CENABLE call __pthread_enable_asynccancel # define CENABLE call __pthread_enable_asynccancel

View File

@ -21,6 +21,7 @@
#include <tcb-offsets.h> #include <tcb-offsets.h>
.text .text
.globl __syscall_error
ENTRY(__vfork) ENTRY(__vfork)
ld [%g7 + PID], %o5 ld [%g7 + PID], %o5
cmp %o5, 0 cmp %o5, 0
@ -31,16 +32,18 @@ ENTRY(__vfork)
LOADSYSCALL(vfork) LOADSYSCALL(vfork)
ta 0x10 ta 0x10
bcs,a __syscall_error_handler bcc 2f
st %o5, [%g7 + PID] mov %o7, %g1
SYSCALL_ERROR_HANDLER st %o5, [%g7 + PID]
sub %o1, 1, %o1 call __syscall_error
mov %g1, %o7
2: sub %o1, 1, %o1
andcc %o0, %o1, %o0 andcc %o0, %o1, %o0
bne,a 1f bne,a 1f
st %o5, [%g7 + PID] st %o5, [%g7 + PID]
1: retl 1: retl
nop nop
END(__vfork)
PSEUDO_END (__vfork)
libc_hidden_def (__vfork) libc_hidden_def (__vfork)
weak_alias (__vfork, vfork) weak_alias (__vfork, vfork)

View File

@ -21,6 +21,7 @@
#include <tcb-offsets.h> #include <tcb-offsets.h>
.text .text
.globl __syscall_error
ENTRY(__vfork) ENTRY(__vfork)
ld [%g7 + PID], %o5 ld [%g7 + PID], %o5
sub %g0, %o5, %o4 sub %g0, %o5, %o4
@ -28,15 +29,17 @@ ENTRY(__vfork)
LOADSYSCALL(vfork) LOADSYSCALL(vfork)
ta 0x6d ta 0x6d
bcs,a,pn %xcc, __syscall_error_handler bcc,pt %xcc, 2f
st %o5, [%g7 + PID] mov %o7, %g1
SYSCALL_ERROR_HANDLER st %o5, [%g7 + PID]
sub %o1, 1, %o1 call __syscall_error
mov %g1, %o7
2: sub %o1, 1, %o1
andcc %o0, %o1, %o0 andcc %o0, %o1, %o0
bne,a,pt %icc, 1f bne,a,pt %icc, 1f
st %o5, [%g7 + PID] st %o5, [%g7 + PID]
1: retl 1: retl
nop nop
END(__vfork)
PSEUDO_END (__vfork)
weak_alias (__vfork, vfork) weak_alias (__vfork, vfork)

View File

@ -26,54 +26,46 @@
#if !defined NOT_IN_libc || defined IS_IN_libpthread || defined IS_IN_librt #if !defined NOT_IN_libc || defined IS_IN_libpthread || defined IS_IN_librt
# undef PSEUDO # undef PSEUDO
# define PSEUDO(name, syscall_name, args) \ # define PSEUDO(name, syscall_name, args) \
.text; \ .text; \
ENTRY(name) \ .globl __syscall_error; \
ld [%g7 + MULTIPLE_THREADS_OFFSET], %g1; \ ENTRY(name) \
brnz,pn %g1, 1f; \ ld [%g7 + MULTIPLE_THREADS_OFFSET], %g1;\
.type __##syscall_name##_nocancel,@function; \ brnz,pn %g1, 1f; \
.globl __##syscall_name##_nocancel; \ .type __##syscall_name##_nocancel,@function; \
__##syscall_name##_nocancel: \ .globl __##syscall_name##_nocancel; \
mov SYS_ify(syscall_name), %g1; \ __##syscall_name##_nocancel: \
ta 0x6d; \ mov SYS_ify(syscall_name), %g1; \
bcs,pn %xcc, __syscall_error_handler; \ ta 0x6d; \
nop; \ bcc,pt %xcc, 8f; \
.size __##syscall_name##_nocancel,.-__##syscall_name##_nocancel; \ mov %o7, %g1; \
.subsection 2; \ call __syscall_error; \
cfi_startproc; \ mov %g1, %o7; \
1: save %sp, -192, %sp; \ 8: jmpl %o7 + 8, %g0; \
cfi_def_cfa_register (%fp); \ nop; \
cfi_window_save; \ .size __##syscall_name##_nocancel,.-__##syscall_name##_nocancel;\
cfi_register (%o7, %i7); \ 1: save %sp, -192, %sp; \
CENABLE; \ cfi_def_cfa_register(%fp); \
nop; \ cfi_window_save; \
mov %o0, %l0; \ cfi_register(%o7, %i7); \
COPY_ARGS_##args \ CENABLE; \
mov SYS_ify(syscall_name), %g1; \ nop; \
ta 0x6d; \ mov %o0, %l0; \
bcs,pn %xcc, __syscall_error_handler2; \ COPY_ARGS_##args \
mov %o0, %l1; \ mov SYS_ify(syscall_name), %g1; \
CDISABLE; \ ta 0x6d; \
mov %l0, %o0; \ bcc,pt %xcc, 1f; \
jmpl %i7 + 8, %g0; \ mov %o0, %l1; \
restore %g0, %l1, %o0; \ CDISABLE; \
cfi_endproc; \ mov %l0, %o0; \
.previous; \ call __syscall_error; \
SYSCALL_ERROR_HANDLER \ mov %l1, %o0; \
SYSCALL_ERROR_HANDLER2 ba,pt %xcc, 2f; \
mov -1, %l1; \
#define SYSCALL_ERROR_HANDLER2 \ 1: CDISABLE; \
SYSCALL_ERROR_HANDLER_ENTRY(__syscall_error_handler2) \ mov %l0, %o0; \
.global __errno_location; \ 2: jmpl %i7 + 8, %g0; \
.type __errno_location,@function; \ restore %g0, %l1, %o0;
CDISABLE; \
mov %l0, %o0; \
call __errno_location; \
nop; \
st %l1, [%o0]; \
jmpl %i7 + 8, %g0; \
restore %g0, -1, %o0; \
.previous;
# ifdef IS_IN_libpthread # ifdef IS_IN_libpthread
# define CENABLE call __pthread_enable_asynccancel # define CENABLE call __pthread_enable_asynccancel

View File

@ -21,6 +21,7 @@
#include <tcb-offsets.h> #include <tcb-offsets.h>
.text .text
.globl __syscall_error
ENTRY(__vfork) ENTRY(__vfork)
ld [%g7 + PID], %o5 ld [%g7 + PID], %o5
sethi %hi(0x80000000), %o3 sethi %hi(0x80000000), %o3
@ -31,16 +32,18 @@ ENTRY(__vfork)
LOADSYSCALL(vfork) LOADSYSCALL(vfork)
ta 0x6d ta 0x6d
bcs,a,pn %xcc, __syscall_error_handler bcc,pt %xcc, 2f
st %o5, [%g7 + PID] mov %o7, %g1
SYSCALL_ERROR_HANDLER st %o5, [%g7 + PID]
sub %o1, 1, %o1 call __syscall_error
mov %g1, %o7
2: sub %o1, 1, %o1
andcc %o0, %o1, %o0 andcc %o0, %o1, %o0
bne,a,pt %icc, 1f bne,a,pt %icc, 1f
st %o5, [%g7 + PID] st %o5, [%g7 + PID]
1: retl 1: retl
nop nop
END(__vfork)
PSEUDO_END (__vfork)
libc_hidden_def (__vfork) libc_hidden_def (__vfork)
weak_alias (__vfork, vfork) weak_alias (__vfork, vfork)