From 60d45b36a5cf5befde06d44424c720edf1f88244 Mon Sep 17 00:00:00 2001 From: "H.J. Lu" Date: Fri, 11 May 2012 14:33:12 -0700 Subject: Add sysdeps/x86_64/x32/tls.h --- nptl/ChangeLog | 4 ++++ nptl/sysdeps/x86_64/x32/tls.h | 46 +++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 50 insertions(+) create mode 100644 nptl/sysdeps/x86_64/x32/tls.h (limited to 'nptl') diff --git a/nptl/ChangeLog b/nptl/ChangeLog index bf648a3..49e42ef 100644 --- a/nptl/ChangeLog +++ b/nptl/ChangeLog @@ -1,5 +1,9 @@ 2012-05-11 H.J. Lu + * sysdeps/x86_64/x32/tls.h: New file. + +2012-05-11 H.J. Lu + * sysdeps/x86_64/tls.h (THREAD_SETMEM): Use uint64_t on 64-bit integer. (THREAD_SETMEM_NC): Likewise. diff --git a/nptl/sysdeps/x86_64/x32/tls.h b/nptl/sysdeps/x86_64/x32/tls.h new file mode 100644 index 0000000..6cc0ea7 --- /dev/null +++ b/nptl/sysdeps/x86_64/x32/tls.h @@ -0,0 +1,46 @@ +/* Definition for thread-local data handling. nptl/x32 version. + Copyright (C) 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 + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + The GNU C Library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with the GNU C Library; if not, see + . */ + +#ifndef _X32_TLS_H +#define _X32_TLS_H 1 + +#include + +#ifndef __ASSEMBLER__ + +/* X32 doesn't support 32-bit indirect call via memory. Instead, we + load 32-bit address from memory into the lower 32bits of return + register, which will automatically zero-extend the uppper 32-bits + of return register. We then do the indirect call via 64-bit return + register. */ +# undef CALL_THREAD_FCT +# define CALL_THREAD_FCT(descr) \ + ({ void *__res; \ + asm volatile ("movl %%fs:%P2, %%edi\n\t" \ + "movl %%fs:%P1, %k0\n\t" \ + "callq *%q0" \ + : "=a" (__res) \ + : "i" (offsetof (struct pthread, start_routine)), \ + "i" (offsetof (struct pthread, arg)) \ + : "di", "si", "cx", "dx", "r8", "r9", "r10", "r11", \ + "memory", "cc"); \ + __res; }) + +#endif /* __ASSEMBLER__ */ + +#endif /* x32/tls.h */ -- cgit v1.1