From: Roland McGrath Date: Fri, 11 Jun 2004 09:56:02 +0000 (+0000) Subject: * elf/tls-macros.h [__s390x__] (TLS_LD, TLS_GD): Clobber also r14. X-Git-Tag: cvs/fedora-base~406 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=b80af23ac6973e69df6cd23d221fa44fffb21e17;p=thirdparty%2Fglibc.git * elf/tls-macros.h [__s390x__] (TLS_LD, TLS_GD): Clobber also r14. --- diff --git a/ChangeLog b/ChangeLog index 13ee51fed7a..c8b8c929697 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +2004-06-10 Jakub Jelinek + + * elf/tls-macros.h [__s390x__] (TLS_LD, TLS_GD): Clobber also r14. + 2004-06-08 Jakub Jelinek [BZ #199] diff --git a/elf/tls-macros.h b/elf/tls-macros.h index d02e9b2d909..bed2e148994 100644 --- a/elf/tls-macros.h +++ b/elf/tls-macros.h @@ -484,7 +484,7 @@ register void *__gp __asm__("$29"); "algr %0,%%r2\n\t" \ "lgr %%r12,%1" \ : "=&a" (__offset), "=&a" (__save12) \ - : : "cc", "0", "1", "2", "3", "4", "5" ); \ + : : "cc", "0", "1", "2", "3", "4", "5", "14" ); \ (int *) (__builtin_thread_pointer() + __offset); }) # else # define TLS_LD(x) \ @@ -497,7 +497,8 @@ register void *__gp __asm__("$29"); "brasl %%r14,__tls_get_offset@plt:tls_ldcall:" #x "\n\t" \ "lg %0,8(%0)\n\t" \ "algr %0,%%r2" \ - : "=&a" (__offset) : : "cc", "0", "1", "2", "3", "4", "5", "12" ); \ + : "=&a" (__offset) \ + : : "cc", "0", "1", "2", "3", "4", "5", "12", "14" ); \ (int *) (__builtin_thread_pointer() + __offset); }) # endif @@ -513,7 +514,7 @@ register void *__gp __asm__("$29"); "lgr %0,%%r2\n\t" \ "lgr %%r12,%1" \ : "=&a" (__offset), "=&a" (__save12) \ - : : "cc", "0", "1", "2", "3", "4", "5" ); \ + : : "cc", "0", "1", "2", "3", "4", "5", "14" ); \ (int *) (__builtin_thread_pointer() + __offset); }) # else # define TLS_GD(x) \ @@ -524,7 +525,8 @@ register void *__gp __asm__("$29"); "lg %%r2,0(%0)\n\t" \ "brasl %%r14,__tls_get_offset@plt:tls_gdcall:" #x "\n\t" \ "lgr %0,%%r2" \ - : "=&a" (__offset) : : "cc", "0", "1", "2", "3", "4", "5", "12" ); \ + : "=&a" (__offset) \ + : : "cc", "0", "1", "2", "3", "4", "5", "12", "14" ); \ (int *) (__builtin_thread_pointer() + __offset); }) # endif