]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
ARM: Split Linuxism out of sysdeps/arm/nptl/tls.h
authorRoland McGrath <roland@hack.frob.com>
Mon, 30 Jun 2014 18:19:22 +0000 (11:19 -0700)
committerRoland McGrath <roland@hack.frob.com>
Mon, 30 Jun 2014 18:19:22 +0000 (11:19 -0700)
ChangeLog
sysdeps/arm/nptl/tls.h
sysdeps/unix/sysv/linux/arm/tls.h [new file with mode: 0644]

index 8897d9ce1487910c978b504ca35451ce80b9d1e9..785baf996b2871861e4c7d0672bdb4adc6ab36fe 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,10 @@
+2014-06-30  Roland McGrath  <roland@hack.frob.com>
+
+       * sysdeps/arm/nptl/tls.h: Rename the multiple inclusion guard
+       from _TLS_H to _ARM_NPTL_TLS_H.
+       (TLS_INIT_TP): Move macro, and #include of <sysdep.h>, to ...
+       * sysdeps/unix/sysv/linux/arm/tls.h: ... this new file.
+
 2014-06-30  Joseph Myers  <joseph@codesourcery.com>
 
        [BZ #16539]
index 6521bdce0e7ebe0ad21500dffca686f390df6fcb..95b6a20c5a85d7b4a3d1d5b1df5322ae38099802 100644 (file)
@@ -16,8 +16,8 @@
    License along with the GNU C Library.  If not, see
    <http://www.gnu.org/licenses/>.  */
 
-#ifndef _TLS_H
-#define _TLS_H 1
+#ifndef _ARM_NPTL_TLS_H
+#define _ARM_NPTL_TLS_H        1
 
 #include <dl-sysdep.h>
 
@@ -44,9 +44,6 @@ typedef union dtv
 
 #ifndef __ASSEMBLER__
 
-/* Get system call information.  */
-# include <sysdep.h>
-
 /* The TP points to the start of the thread blocks.  */
 # define TLS_DTV_AT_TP 1
 # define TLS_TCB_AT_TP 0
@@ -88,16 +85,6 @@ typedef struct
 # define GET_DTV(tcbp) \
   (((tcbhead_t *) (tcbp))->dtv)
 
-/* Code to initially initialize the thread pointer.  This might need
-   special attention since 'errno' is not yet available and if the
-   operation can cause a failure 'errno' must not be touched.  */
-# define TLS_INIT_TP(tcbp) \
-  ({ INTERNAL_SYSCALL_DECL (err);                                      \
-     long result_var;                                                  \
-     result_var = INTERNAL_SYSCALL_ARM (set_tls, err, 1, (tcbp));      \
-     INTERNAL_SYSCALL_ERROR_P (result_var, err)                                \
-       ? "unknown error" : NULL; })
-
 # define TLS_DEFINE_INIT_TP(tp, pd) void *tp = (pd) + 1
 
 /* Return the address of the dtv for the current thread.  */
diff --git a/sysdeps/unix/sysv/linux/arm/tls.h b/sysdeps/unix/sysv/linux/arm/tls.h
new file mode 100644 (file)
index 0000000..bfb76b3
--- /dev/null
@@ -0,0 +1,42 @@
+/* Definition for thread-local data handling.  ARM/Linux version.
+   Copyright (C) 2005-2014 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
+   <http://www.gnu.org/licenses/>.  */
+
+#ifndef _LINUX_ARM_TLS_H
+#define _LINUX_ARM_TLS_H       1
+
+/* Almost everything is OS-independent and common for all NPTL on ARM.  */
+#include <sysdeps/arm/nptl/tls.h>
+
+#ifndef __ASSEMBLER__
+
+/* Get system call information.  */
+# include <sysdep.h>
+
+/* Code to initially initialize the thread pointer.  This might need
+   special attention since 'errno' is not yet available and if the
+   operation can cause a failure 'errno' must not be touched.  */
+# define TLS_INIT_TP(tcbp) \
+  ({ INTERNAL_SYSCALL_DECL (err);                                      \
+     long int result_var;                                              \
+     result_var = INTERNAL_SYSCALL_ARM (set_tls, err, 1, (tcbp));      \
+     INTERNAL_SYSCALL_ERROR_P (result_var, err)                                \
+       ? "unknown error" : NULL; })
+
+#endif /* __ASSEMBLER__ */
+
+#endif  /* tls.h */