From: H.J. Lu Date: Tue, 22 May 2012 12:34:36 +0000 (-0700) Subject: Use "neg %eax" in x86_64 SYSCALL_SET_ERRNO X-Git-Tag: glibc-2.16-tps~217 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=0e44a77e481e18b56ef5bd2354fc97a267487551;p=thirdparty%2Fglibc.git Use "neg %eax" in x86_64 SYSCALL_SET_ERRNO --- diff --git a/ChangeLog b/ChangeLog index f1921def94e..200c7269941 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,8 @@ 2012-05-22 H.J. Lu + * sysdeps/unix/sysv/linux/x86_64/sysdep.h (SYSCALL_SET_ERRNO): + Use "neg %eax". + * sysdeps/unix/sysv/linux/bits/resource.h (RLIM_INFINITY): Use __rlim_t cast. (struct rusage): Use anonymous union to pad each field to diff --git a/sysdeps/unix/sysv/linux/x86_64/sysdep.h b/sysdeps/unix/sysv/linux/x86_64/sysdep.h index 3f5bdd2ac37..396345e8b72 100644 --- a/sysdeps/unix/sysv/linux/x86_64/sysdep.h +++ b/sysdeps/unix/sysv/linux/x86_64/sysdep.h @@ -115,9 +115,8 @@ # if defined PIC && defined RTLD_PRIVATE_ERRNO # define SYSCALL_SET_ERRNO \ lea rtld_errno(%rip), %RCX_LP; \ - xorl %edx, %edx; \ - sub %RAX_LP, %RDX_LP; \ - movl %edx, (%rcx) + neg %eax; \ + movl %eax, (%rcx) # else # ifndef NOT_IN_libc # define SYSCALL_ERROR_ERRNO __libc_errno @@ -126,9 +125,8 @@ # endif # define SYSCALL_SET_ERRNO \ movq SYSCALL_ERROR_ERRNO@GOTTPOFF(%rip), %rcx;\ - xorl %edx, %edx; \ - sub %RAX_LP, %RDX_LP; \ - movl %edx, %fs:(%rcx) + neg %eax; \ + movl %eax, %fs:(%rcx); # endif # ifndef PIC