From: Andreas Jaeger Date: Tue, 22 May 2012 20:35:04 +0000 (+0200) Subject: Fix x86_64/sched_getcpu.S error code X-Git-Tag: upstream/2.20~3842 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=73338355920056d87648c65ccba9a875c289b37e;p=platform%2Fupstream%2Flinaro-glibc.git Fix x86_64/sched_getcpu.S error code Rearrange code so that pseudo_end is just ret and the stack pointer is correct also for static library in error case. --- diff --git a/ChangeLog b/ChangeLog index 159f4f2..8206ea4 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +2012-05-22 Andreas Jaeger + + * sysdeps/unix/sysv/linux/x86_64/sched_getcpu.S: Rearrange code so + that pseudo_end is just ret and the stack pointer is correct also + for static library in error case. + 2012-05-22 Paul Pluzhnikov [BZ #14122] diff --git a/sysdeps/unix/sysv/linux/x86_64/sched_getcpu.S b/sysdeps/unix/sysv/linux/x86_64/sched_getcpu.S index 4c3cebe..896deb0 100644 --- a/sysdeps/unix/sysv/linux/x86_64/sched_getcpu.S +++ b/sysdeps/unix/sysv/linux/x86_64/sched_getcpu.S @@ -1,4 +1,4 @@ -/* Copyright (C) 2007, 2011 Free Software Foundation, Inc. +/* Copyright (C) 2007-2012 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 @@ -59,13 +59,17 @@ ENTRY (sched_getcpu) # endif #endif + /* Local variable is result if the call is successful. */ + movl (%rsp), %edx + /* Restore stack pointer before we might jump to + SYSCALL_ERROR_LABEL which returns to the caller. */ + add $0x8, %rsp + cfi_adjust_cfa_offset(-8) + cmpq $-4095, %rax jae SYSCALL_ERROR_LABEL - movl (%rsp), %eax - + movl %edx, %eax L(pseudo_end): - add $0x8, %rsp - cfi_adjust_cfa_offset(-8) ret PSEUDO_END(sched_getcpu)