diff options
author | Andreas Schwab <schwab@redhat.com> | 2011-04-07 16:23:52 -0400 |
---|---|---|
committer | Ulrich Drepper <drepper@gmail.com> | 2011-04-07 16:23:52 -0400 |
commit | e451d22b22c959a4dbf86dbc9f125985601473ab (patch) | |
tree | da1bcb1d557bca949f9c44e5ed6ee5b792819f71 | |
parent | 821ae7137b7b4dacdd7fcb73e4f3d479afed1014 (diff) | |
download | glibc-e451d22b22c959a4dbf86dbc9f125985601473ab.zip glibc-e451d22b22c959a4dbf86dbc9f125985601473ab.tar.gz glibc-e451d22b22c959a4dbf86dbc9f125985601473ab.tar.bz2 |
Maintain stack alignment in ____longjmp_chk on x86_64
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/x86_64/____longjmp_chk.S | 26 |
2 files changed, 21 insertions, 11 deletions
@@ -1,3 +1,9 @@ +2011-04-07 Andreas Schwab <schwab@redhat.com> + + * sysdeps/unix/sysv/linux/x86_64/____longjmp_chk.S (CALL_FAIL): + Maintain aligned stack. + (CHECK_RSP): Remove unused macro. + 2011-04-03 Ulrich Drepper <drepper@gmail.com> * sysdeps/x86_64/cacheinfo.c (intel_02_known): Fix typo in table. diff --git a/sysdeps/unix/sysv/linux/x86_64/____longjmp_chk.S b/sysdeps/unix/sysv/linux/x86_64/____longjmp_chk.S index da35115..3881082 100644 --- a/sysdeps/unix/sysv/linux/x86_64/____longjmp_chk.S +++ b/sysdeps/unix/sysv/linux/x86_64/____longjmp_chk.S @@ -1,4 +1,4 @@ -/* Copyright (C) 2001,2004,2005,2006,2009,2010 Free Software Foundation, Inc. +/* Copyright (C) 2001,2004,2005,2006,2009,2010,2011 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 @@ -30,19 +30,23 @@ longjmp_msg: //#define __longjmp ____longjmp_chk #ifdef PIC -# define CALL_FAIL leaq longjmp_msg(%rip), %rdi; \ - call __GI___fortify_fail +# define CALL_FAIL subq $8, %rsp; \ + cfi_remember_state; \ + cfi_def_cfa_offset(16); \ + leaq longjmp_msg(%rip), %rdi; \ + call __GI___fortify_fail; \ + nop; \ + cfi_restore_state #else -# define CALL_FAIL movq $longjmp_msg, %rdi; \ - call __fortify_fail +# define CALL_FAIL subq $8, %rsp; \ + cfi_remember_state; \ + cfi_def_cfa_offset(16); \ + movq $longjmp_msg, %rdi; \ + call __fortify_fail; \ + nop; \ + cfi_restore_state #endif -#define CHECK_RSP(reg) \ - cmpq reg, %rsp; \ - jbe .Lok; \ - CALL_FAIL; \ -.Lok: - /* Jump to the position specified by ENV, causing the setjmp call there to return VAL, or 1 if VAL is 0. void __longjmp (__jmp_buf env, int val). */ |