diff options
| author | Eric Andersen <andersen@codepoet.org> | 2001-02-22 05:29:50 +0000 | 
|---|---|---|
| committer | Eric Andersen <andersen@codepoet.org> | 2001-02-22 05:29:50 +0000 | 
| commit | 5b6e897d01a07f8391351a07321f2bcb7c025a7e (patch) | |
| tree | ed3dfba88ea6c62e0cb584bec74901292510dab3 /libc/sysdeps | |
| parent | 2109636071eb7b3c085b6fcefcbed272a61e6713 (diff) | |
Patch from Jean-Yves Avenard to add missing siglongjmp entry and
fix a bug in setjmp for SH
Diffstat (limited to 'libc/sysdeps')
| -rw-r--r-- | libc/sysdeps/linux/sh/Makefile | 4 | ||||
| -rw-r--r-- | libc/sysdeps/linux/sh/__longjmp.S (renamed from libc/sysdeps/linux/sh/longjmp.S) | 4 | ||||
| -rw-r--r-- | libc/sysdeps/linux/sh/jmp-unwind.c | 29 | ||||
| -rw-r--r-- | libc/sysdeps/linux/sh/longjmp.c | 58 | ||||
| -rw-r--r-- | libc/sysdeps/linux/sh/setjmp.S | 2 | 
5 files changed, 92 insertions, 5 deletions
| diff --git a/libc/sysdeps/linux/sh/Makefile b/libc/sysdeps/linux/sh/Makefile index 684983998..a8a0cbb16 100644 --- a/libc/sysdeps/linux/sh/Makefile +++ b/libc/sysdeps/linux/sh/Makefile @@ -34,10 +34,10 @@ CRT0=crt0.S  CRT0_OBJ=$(patsubst %.S,%.o, $(CRT0)) -SSRC=setjmp.S bsd-setjmp.S bsd-_setjmp.S longjmp.S +SSRC=setjmp.S bsd-setjmp.S bsd-_setjmp.S __longjmp.S  SOBJS=$(patsubst %.S,%.o, $(SSRC)) -CSRC=fork.c vfork.c _mmap.c +CSRC=fork.c vfork.c _mmap.c longjmp.c jmp-unwind.c  COBJS=$(patsubst %.c,%.o, $(CSRC))  OBJS=$(SOBJS) $(MOBJ) $(COBJS) diff --git a/libc/sysdeps/linux/sh/longjmp.S b/libc/sysdeps/linux/sh/__longjmp.S index 8f8832b9a..09f829ae3 100644 --- a/libc/sysdeps/linux/sh/longjmp.S +++ b/libc/sysdeps/linux/sh/__longjmp.S @@ -24,7 +24,7 @@  /* __longjmp(jmpbuf, val) */ -ENTRY (longjmp) +ENTRY (__longjmp)  	mov.l	@r4+, r8  	mov.l	@r4+, r9  	mov.l	@r4+, r10 @@ -41,4 +41,4 @@ ENTRY (longjmp)  1:  	rts  	 ldc.l	@r4+, gbr -END (longjmp) +END (__longjmp) diff --git a/libc/sysdeps/linux/sh/jmp-unwind.c b/libc/sysdeps/linux/sh/jmp-unwind.c new file mode 100644 index 000000000..083dc74a8 --- /dev/null +++ b/libc/sysdeps/linux/sh/jmp-unwind.c @@ -0,0 +1,29 @@ +/* _longjmp_unwind -- Clean up stack frames unwound by longjmp.  Stub version. +   Copyright (C) 1995, 1997 Free Software Foundation, Inc. +   This file is part of the GNU C Library. + +   The GNU C Library is free software; you can redistribute it and/or +   modify it under the terms of the GNU Library General Public License as +   published by the Free Software Foundation; either version 2 of the +   License, or (at your option) any later version. + +   The GNU C Library 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 +   Library General Public License for more details. + +   You should have received a copy of the GNU Library General Public +   License along with the GNU C Library; see the file COPYING.LIB.  If not, +   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, +   Boston, MA 02111-1307, USA.  */ + +#include <setjmp.h> + +void +_longjmp_unwind (jmp_buf env, int val) +{ + +  /* This function can perform any cleanups necessary to safely unwind the +     stack frames around the current context which ENV unwinds past.  */ + +} diff --git a/libc/sysdeps/linux/sh/longjmp.c b/libc/sysdeps/linux/sh/longjmp.c new file mode 100644 index 000000000..73a8e7504 --- /dev/null +++ b/libc/sysdeps/linux/sh/longjmp.c @@ -0,0 +1,58 @@ +/* Copyright (C) 1991, 92, 94, 95, 97, 98, 2000 Free Software Foundation, Inc. +   This file is part of the GNU C Library. + +   The GNU C Library is free software; you can redistribute it and/or +   modify it under the terms of the GNU Library General Public License as +   published by the Free Software Foundation; either version 2 of the +   License, or (at your option) any later version. + +   The GNU C Library 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 +   Library General Public License for more details. + +   You should have received a copy of the GNU Library General Public +   License along with the GNU C Library; see the file COPYING.LIB.  If not, +   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, +   Boston, MA 02111-1307, USA.  */ + +#include <stddef.h> +#include <setjmp.h> +#include <signal.h> + + +/* Set the signal mask to the one specified in ENV, and jump +   to the position specified in ENV, causing the setjmp +   call there to return VAL, or 1 if VAL is 0.  */ +void +__uClibc_siglongjmp (sigjmp_buf env, int val) +{ +  /* Perform any cleanups needed by the frames being unwound.  */ +  _longjmp_unwind (env, val); + +  if (env[0].__mask_was_saved) +    /* Restore the saved signal mask.  */ +    (void) __sigprocmask (SIG_SETMASK, &env[0].__saved_mask, +			  (sigset_t *) NULL); + +  /* Call the machine-dependent function to restore machine state.  */ +  __longjmp (env[0].__jmpbuf, val ?: 1); +} + +//strong_alias (__uClibc_siglongjmp, __uClibc_longjmp) + +//_weak_alias (__uClibc_siglongjmp, _longjmp) +asm(".weak _longjmp"); +asm("_longjmp = __uClibc_siglongjmp"); + +//weak_alias (__uClibc_siglongjmp, longjmp) +asm(".weak longjmp"); +asm("longjmp = __uClibc_siglongjmp"); + +//weak_alias (__uClibc_siglongjmp, siglongjmp) +asm(".weak siglongjmp"); +asm("siglongjmp = __uClibc_siglongjmp"); + +asm(".weak __sigprocmask"); +asm("__sigprocmask = sigprocmask"); + diff --git a/libc/sysdeps/linux/sh/setjmp.S b/libc/sysdeps/linux/sh/setjmp.S index 449d936dc..154cef1af 100644 --- a/libc/sysdeps/linux/sh/setjmp.S +++ b/libc/sysdeps/linux/sh/setjmp.S @@ -30,7 +30,7 @@ ENTRY (__sigsetjmp)  __sigsetjmp:  */  	/* Save registers */ -	add	#(JB_SIZE - 4 * 5), r4 +	add	#(JB_SIZE), r4  	stc.l	gbr, @-r4  	sts.l	pr, @-r4  	mov.l	r15, @-r4 | 
