From c67da0b50e3d20f89d7bb352cd67dcf66d808e50 Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Thu, 22 Dec 2005 17:44:18 +0000 Subject: [PATCH] Also protect SP and BP. --- sysdeps/x86_64/__longjmp.S | 2 ++ sysdeps/x86_64/setjmp.S | 9 +++++++++ 2 files changed, 11 insertions(+) diff --git a/sysdeps/x86_64/__longjmp.S b/sysdeps/x86_64/__longjmp.S index becfb4f..dd797e8 100644 --- a/sysdeps/x86_64/__longjmp.S +++ b/sysdeps/x86_64/__longjmp.S @@ -51,6 +51,8 @@ ENTRY(__longjmp) movq (JB_PC*8)(%rdi),%rdx movq (JB_RSP*8)(%rdi),%rsp #ifdef PTR_DEMANGLE + PTR_DEMANGLE (%rbp) + PTR_DEMANGLE (%rsp) PTR_DEMANGLE (%rdx) #endif jmpq *%rdx diff --git a/sysdeps/x86_64/setjmp.S b/sysdeps/x86_64/setjmp.S index 8af5502..39c78c9 100644 --- a/sysdeps/x86_64/setjmp.S +++ b/sysdeps/x86_64/setjmp.S @@ -26,12 +26,21 @@ ENTRY (__sigsetjmp) /* Save registers. */ movq %rbx, (JB_RBX*8)(%rdi) +#ifdef PTR_MANGLE + movq %rbp, %rax + PTR_MANGLE (%rax) + movq %rax, (JB_RBP*8)(%rdi) +#else movq %rbp, (JB_RBP*8)(%rdi) +#endif movq %r12, (JB_R12*8)(%rdi) movq %r13, (JB_R13*8)(%rdi) movq %r14, (JB_R14*8)(%rdi) movq %r15, (JB_R15*8)(%rdi) leaq 8(%rsp), %rdx /* Save SP as it will be after we return. */ +#ifdef PTR_MANGLE + PTR_MANGLE (%rdx) +#endif movq %rdx, (JB_RSP*8)(%rdi) movq (%rsp), %rax /* Save PC we are returning to now. */ #ifdef PTR_MANGLE -- 2.7.4