[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[commits] r8774 - in /fsf/trunk/ports: ./ sysdeps/mips/ sysdeps/mips/mips64/ sysdeps/unix/sysv/linux/mips/
- To: commits@xxxxxxxxxx
- Subject: [commits] r8774 - in /fsf/trunk/ports: ./ sysdeps/mips/ sysdeps/mips/mips64/ sysdeps/unix/sysv/linux/mips/
- From: eglibc@xxxxxxxxxx
- Date: Thu, 06 Aug 2009 07:05:08 -0000
Author: eglibc
Date: Thu Aug 6 00:04:54 2009
New Revision: 8774
Log:
Import glibc-ports-mainline for 2009-08-06
Added:
fsf/trunk/ports/sysdeps/unix/sysv/linux/mips/____longjmp_chk.c
Removed:
fsf/trunk/ports/sysdeps/mips/____longjmp_chk.c
Modified:
fsf/trunk/ports/ChangeLog.mips
fsf/trunk/ports/sysdeps/mips/__longjmp.c
fsf/trunk/ports/sysdeps/mips/mips64/__longjmp.c
Modified: fsf/trunk/ports/ChangeLog.mips
==============================================================================
--- fsf/trunk/ports/ChangeLog.mips (original)
+++ fsf/trunk/ports/ChangeLog.mips Thu Aug 6 00:04:54 2009
@@ -1,3 +1,11 @@
+2009-08-05 Joseph Myers <joseph@xxxxxxxxxxxxxxxx>
+
+ * sysdeps/mips/____longjmp_chk.c: Remove. Replaced by....
+ * sysdeps/unix/sysv/linux/mips/____longjmp_chk.c: This. New file.
+ * sysdeps/mips/__longjmp.c (__longjmp): Use explicit register
+ variable for env. Use expansion of CHECK_SP macro for check.
+ * sysdeps/mips/mips64/__longjmp.c (__Longjmp): Likewise.
+
2009-08-03 Joseph Myers <joseph@xxxxxxxxxxxxxxxx>
* sysdeps/unix/sysv/linux/mips/mips32/accept4.c,
Modified: fsf/trunk/ports/sysdeps/mips/__longjmp.c
==============================================================================
--- fsf/trunk/ports/sysdeps/mips/__longjmp.c (original)
+++ fsf/trunk/ports/sysdeps/mips/__longjmp.c Thu Aug 6 00:04:54 2009
@@ -25,19 +25,19 @@
#endif
void
-__longjmp (env, val_arg)
- __jmp_buf env;
+__longjmp (env_arg, val_arg)
+ __jmp_buf env_arg;
int val_arg;
{
/* gcc 1.39.19 miscompiled the longjmp routine (as it did setjmp before
the hack around it); force it to use $a1 for the longjmp value.
Without this it saves $a1 in a register which gets clobbered
along the way. */
+ register struct __jmp_buf_internal_tag *env asm ("a0");
register int val asm ("a1");
#ifdef CHECK_SP
register long sp asm ("$29");
- if ((long) (env[0].__sp) < sp)
- __fortify_fail ("longjmp causes uninitialized stack frame");
+ CHECK_SP (env[0].__sp, sp, long);
#endif
#ifdef __mips_hard_float
Modified: fsf/trunk/ports/sysdeps/mips/mips64/__longjmp.c
==============================================================================
--- fsf/trunk/ports/sysdeps/mips/mips64/__longjmp.c (original)
+++ fsf/trunk/ports/sysdeps/mips/mips64/__longjmp.c Thu Aug 6 00:04:54 2009
@@ -27,19 +27,19 @@
#endif
void
-__longjmp (env, val_arg)
- __jmp_buf env;
+__longjmp (env_arg, val_arg)
+ __jmp_buf env_arg;
int val_arg;
{
/* gcc 1.39.19 miscompiled the longjmp routine (as it did setjmp before
the hack around it); force it to use $a1 for the longjmp value.
Without this it saves $a1 in a register which gets clobbered
along the way. */
+ register struct __jmp_buf_internal_tag *env asm ("a0");
register int val asm ("a1");
#ifdef CHECK_SP
register long long sp asm ("$29");
- if ((long long) (env[0].__sp) < sp)
- __fortify_fail ("longjmp causes uninitialized stack frame");
+ CHECK_SP (env[0].__sp, sp, long long);
#endif
#ifdef __mips_hard_float
Added: fsf/trunk/ports/sysdeps/unix/sysv/linux/mips/____longjmp_chk.c
==============================================================================
--- fsf/trunk/ports/sysdeps/unix/sysv/linux/mips/____longjmp_chk.c (added)
+++ fsf/trunk/ports/sysdeps/unix/sysv/linux/mips/____longjmp_chk.c Thu Aug 6 00:04:54 2009
@@ -1,0 +1,42 @@
+/* Copyright (C) 2009 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 Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 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
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with the GNU C Library; if not, write to the Free
+ Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+ 02111-1307 USA. */
+
+#include <signal.h>
+#include <stdio.h>
+#define __longjmp ____longjmp_chk
+#define CHECK_SP(saved_sp, cur_sp, sp_type) \
+ do { \
+ sp_type sp_saved = (sp_type) (saved_sp); \
+ if (sp_saved < (cur_sp)) \
+ { \
+ struct __jmp_buf_internal_tag *env_save = env_arg; \
+ int val_save = val_arg; \
+ stack_t ss; \
+ int ret = __sigaltstack (NULL, &ss); \
+ if (ret == 0 \
+ && (!(ss.ss_flags & SS_ONSTACK) \
+ || ((unsigned sp_type) ((sp_type) ss.ss_sp \
+ + (sp_type) ss.ss_size \
+ - sp_saved) \
+ < ss.ss_size))) \
+ __fortify_fail ("longjmp causes uninitialized stack frame"); \
+ asm volatile ("move %0, %1" : "=r" (env) : "r" (env_save)); \
+ asm volatile ("move %0, %1" : "=r" (val) : "r" (val_save)); \
+ } \
+ } while (0)
+#include <__longjmp.c>