mirror of
https://sourceware.org/git/glibc.git
synced 2025-07-28 00:21:52 +03:00
Add _STRING_INLINE_unaligned and string_private.h
As discussed in https://sourceware.org/ml/libc-alpha/2015-10/msg00403.html the setting of _STRING_ARCH_unaligned currently controls the external GLIBC ABI as well as selecting the use of unaligned accesses withing GLIBC. Since _STRING_ARCH_unaligned was recently changed for AArch64, this would potentially break the ABI in GLIBC 2.23, so split the uses and add _STRING_INLINE_unaligned to select the string ABI. This setting must be fixed for each target, while _STRING_ARCH_unaligned may be changed from release to release. _STRING_ARCH_unaligned is used unconditionally in glibc. But <bits/string.h>, which defines _STRING_ARCH_unaligned, isn't included with -Os. Since _STRING_ARCH_unaligned is internal to glibc and may change between glibc releases, it should be made private to glibc. _STRING_ARCH_unaligned should defined in the new string_private.h heade file which is included unconditionally from internal <string.h> for glibc build. [BZ #19462] * bits/string.h (_STRING_ARCH_unaligned): Renamed to ... (_STRING_INLINE_unaligned): This. * include/string.h: Include <string_private.h>. * string/bits/string2.h: Replace _STRING_ARCH_unaligned with _STRING_INLINE_unaligned. * sysdeps/aarch64/bits/string.h (_STRING_ARCH_unaligned): Removed. (_STRING_INLINE_unaligned): New. * sysdeps/aarch64/string_private.h: New file. * sysdeps/generic/string_private.h: Likewise. * sysdeps/m68k/m680x0/m68020/string_private.h: Likewise. * sysdeps/s390/string_private.h: Likewise. * sysdeps/x86/string_private.h: Likewise. * sysdeps/m68k/m680x0/m68020/bits/string.h (_STRING_ARCH_unaligned): Renamed to ... (_STRING_INLINE_unaligned): This. * sysdeps/s390/bits/string.h (_STRING_ARCH_unaligned): Renamed to ... (_STRING_INLINE_unaligned): This. * sysdeps/sparc/bits/string.h (_STRING_ARCH_unaligned): Renamed to ... (_STRING_INLINE_unaligned): This. * sysdeps/x86/bits/string.h (_STRING_ARCH_unaligned): Renamed to ... (_STRING_INLINE_unaligned): This.
This commit is contained in:
committed by
Adhemerval Zanella
parent
6400ae6ecf
commit
16396c41de
29
ChangeLog
29
ChangeLog
@ -1,3 +1,32 @@
|
|||||||
|
2016-02-18 H.J. Lu <hongjiu.lu@intel.com>
|
||||||
|
Wilco Dijkstra <wdijkstr@arm.com>
|
||||||
|
|
||||||
|
[BZ #19462]
|
||||||
|
* bits/string.h (_STRING_ARCH_unaligned): Renamed to ...
|
||||||
|
(_STRING_INLINE_unaligned): This.
|
||||||
|
* include/string.h: Include <string_private.h>.
|
||||||
|
* string/bits/string2.h: Replace _STRING_ARCH_unaligned with
|
||||||
|
_STRING_INLINE_unaligned.
|
||||||
|
* sysdeps/aarch64/bits/string.h (_STRING_ARCH_unaligned): Removed.
|
||||||
|
(_STRING_INLINE_unaligned): New.
|
||||||
|
* sysdeps/aarch64/string_private.h: New file.
|
||||||
|
* sysdeps/generic/string_private.h: Likewise.
|
||||||
|
* sysdeps/m68k/m680x0/m68020/string_private.h: Likewise.
|
||||||
|
* sysdeps/s390/string_private.h: Likewise.
|
||||||
|
* sysdeps/x86/string_private.h: Likewise.
|
||||||
|
* sysdeps/m68k/m680x0/m68020/bits/string.h
|
||||||
|
(_STRING_ARCH_unaligned): Renamed to ...
|
||||||
|
(_STRING_INLINE_unaligned): This.
|
||||||
|
* sysdeps/s390/bits/string.h (_STRING_ARCH_unaligned): Renamed
|
||||||
|
to ...
|
||||||
|
(_STRING_INLINE_unaligned): This.
|
||||||
|
* sysdeps/sparc/bits/string.h (_STRING_ARCH_unaligned): Renamed
|
||||||
|
to ...
|
||||||
|
(_STRING_INLINE_unaligned): This.
|
||||||
|
* sysdeps/x86/bits/string.h (_STRING_ARCH_unaligned): Renamed
|
||||||
|
to ...
|
||||||
|
(_STRING_INLINE_unaligned): This.
|
||||||
|
|
||||||
2016-02-17 Andrew Senkevich <andrew.senkevich@intel.com>
|
2016-02-17 Andrew Senkevich <andrew.senkevich@intel.com>
|
||||||
H.J. Lu <hongjiu.lu@intel.com>
|
H.J. Lu <hongjiu.lu@intel.com>
|
||||||
|
|
||||||
|
@ -8,7 +8,11 @@
|
|||||||
#ifndef _BITS_STRING_H
|
#ifndef _BITS_STRING_H
|
||||||
#define _BITS_STRING_H 1
|
#define _BITS_STRING_H 1
|
||||||
|
|
||||||
/* Define if architecture can access unaligned multi-byte variables. */
|
/* Define whether to use the unaligned string inline ABI.
|
||||||
#define _STRING_ARCH_unaligned 0
|
The string inline functions are an external ABI, thus cannot be changed
|
||||||
|
after the first release of a new target (unlike _STRING_ARCH_unaligned
|
||||||
|
which may be changed from release to release). Targets must support
|
||||||
|
unaligned accesses in hardware if either define is set to true. */
|
||||||
|
#define _STRING_INLINE_unaligned 0
|
||||||
|
|
||||||
#endif /* bits/string.h */
|
#endif /* bits/string.h */
|
||||||
|
@ -46,6 +46,9 @@ extern int __ffs (int __i) __attribute__ ((const));
|
|||||||
extern char *__strerror_r (int __errnum, char *__buf, size_t __buflen);
|
extern char *__strerror_r (int __errnum, char *__buf, size_t __buflen);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* Get _STRING_ARCH_unaligned. */
|
||||||
|
#include <string_private.h>
|
||||||
|
|
||||||
/* Now the real definitions. We do this here since some of the functions
|
/* Now the real definitions. We do this here since some of the functions
|
||||||
above are defined as macros in the headers. */
|
above are defined as macros in the headers. */
|
||||||
#include <string/string.h>
|
#include <string/string.h>
|
||||||
|
@ -46,7 +46,7 @@
|
|||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if _STRING_ARCH_unaligned
|
#if _STRING_INLINE_unaligned
|
||||||
/* If we can do unaligned memory accesses we must know the endianess. */
|
/* If we can do unaligned memory accesses we must know the endianess. */
|
||||||
# include <endian.h>
|
# include <endian.h>
|
||||||
# include <bits/types.h>
|
# include <bits/types.h>
|
||||||
@ -95,7 +95,7 @@ __STRING2_COPY_TYPE (8);
|
|||||||
/* Set N bytes of S to C. */
|
/* Set N bytes of S to C. */
|
||||||
#if !defined _HAVE_STRING_ARCH_memset
|
#if !defined _HAVE_STRING_ARCH_memset
|
||||||
# if !__GNUC_PREREQ (3, 0)
|
# if !__GNUC_PREREQ (3, 0)
|
||||||
# if _STRING_ARCH_unaligned
|
# if _STRING_INLINE_unaligned
|
||||||
# define memset(s, c, n) \
|
# define memset(s, c, n) \
|
||||||
(__extension__ (__builtin_constant_p (n) && (n) <= 16 \
|
(__extension__ (__builtin_constant_p (n) && (n) <= 16 \
|
||||||
? ((n) == 1 \
|
? ((n) == 1 \
|
||||||
@ -223,7 +223,7 @@ __STRING2_COPY_TYPE (8);
|
|||||||
# endif
|
# endif
|
||||||
|
|
||||||
# if !__GNUC_PREREQ (3, 0) || defined _FORCE_INLINES
|
# if !__GNUC_PREREQ (3, 0) || defined _FORCE_INLINES
|
||||||
# if _STRING_ARCH_unaligned
|
# if _STRING_INLINE_unaligned
|
||||||
# ifndef _FORCE_INLINES
|
# ifndef _FORCE_INLINES
|
||||||
# define __mempcpy_args(src) \
|
# define __mempcpy_args(src) \
|
||||||
((const char *) (src))[0], ((const char *) (src))[2], \
|
((const char *) (src))[0], ((const char *) (src))[2], \
|
||||||
@ -419,7 +419,7 @@ extern void *__rawmemchr (const void *__s, int __c);
|
|||||||
: strcpy (dest, src)))
|
: strcpy (dest, src)))
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
# if _STRING_ARCH_unaligned
|
# if _STRING_INLINE_unaligned
|
||||||
# ifndef _FORCE_INLINES
|
# ifndef _FORCE_INLINES
|
||||||
# define __strcpy_args(src) \
|
# define __strcpy_args(src) \
|
||||||
__extension__ __STRING2_SMALL_GET16 (src, 0), \
|
__extension__ __STRING2_SMALL_GET16 (src, 0), \
|
||||||
@ -598,7 +598,7 @@ __strcpy_small (char *__dest,
|
|||||||
# endif
|
# endif
|
||||||
|
|
||||||
# if !__GNUC_PREREQ (3, 0) || defined _FORCE_INLINES
|
# if !__GNUC_PREREQ (3, 0) || defined _FORCE_INLINES
|
||||||
# if _STRING_ARCH_unaligned
|
# if _STRING_INLINE_unaligned
|
||||||
# ifndef _FORCE_INLINES
|
# ifndef _FORCE_INLINES
|
||||||
# define __stpcpy_args(src) \
|
# define __stpcpy_args(src) \
|
||||||
__extension__ __STRING2_SMALL_GET16 (src, 0), \
|
__extension__ __STRING2_SMALL_GET16 (src, 0), \
|
||||||
|
@ -20,5 +20,5 @@
|
|||||||
# error "Never use <bits/string.h> directly; include <string.h> instead."
|
# error "Never use <bits/string.h> directly; include <string.h> instead."
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* AArch64 implementations support efficient unaligned access. */
|
/* AArch64 uses the aligned string inline ABI. */
|
||||||
#define _STRING_ARCH_unaligned 1
|
#define _STRING_INLINE_unaligned 0
|
||||||
|
20
sysdeps/aarch64/string_private.h
Normal file
20
sysdeps/aarch64/string_private.h
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
/* Define _STRING_ARCH_unaligned. AArch64 version.
|
||||||
|
Copyright (C) 2016 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/>. */
|
||||||
|
|
||||||
|
/* AArch64 implementations support efficient unaligned access. */
|
||||||
|
#define _STRING_ARCH_unaligned 1
|
21
sysdeps/generic/string_private.h
Normal file
21
sysdeps/generic/string_private.h
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
/* Define _STRING_ARCH_unaligned. Generic version.
|
||||||
|
Copyright (C) 2016 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/>. */
|
||||||
|
|
||||||
|
/* Define to 1 if architecture can access unaligned multi-byte
|
||||||
|
variables. */
|
||||||
|
#define _STRING_ARCH_unaligned 0
|
@ -20,6 +20,5 @@
|
|||||||
# error "Never use <bits/string.h> directly; include <string.h> instead."
|
# error "Never use <bits/string.h> directly; include <string.h> instead."
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Currently the only purpose of this file is to tell the generic inline
|
/* Use the unaligned string inline ABI. */
|
||||||
macros that unaligned memory access is possible. */
|
#define _STRING_INLINE_unaligned 1
|
||||||
#define _STRING_ARCH_unaligned 1
|
|
||||||
|
21
sysdeps/m68k/m680x0/m68020/string_private.h
Normal file
21
sysdeps/m68k/m680x0/m68020/string_private.h
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
/* Define _STRING_ARCH_unaligned. m680x0 version, x >= 2.
|
||||||
|
Copyright (C) 2016 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/>. */
|
||||||
|
|
||||||
|
/* Tell the generic inline macros that unaligned memory access is
|
||||||
|
possible. */
|
||||||
|
#define _STRING_ARCH_unaligned 1
|
@ -21,8 +21,8 @@
|
|||||||
# error "Never use <bits/string.h> directly; include <string.h> instead."
|
# error "Never use <bits/string.h> directly; include <string.h> instead."
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* The s390 processors can access unaligned multi-byte variables. */
|
/* Use the unaligned string inline ABI. */
|
||||||
#define _STRING_ARCH_unaligned 1
|
#define _STRING_INLINE_unaligned 1
|
||||||
|
|
||||||
/* We only provide optimizations if the user selects them and if
|
/* We only provide optimizations if the user selects them and if
|
||||||
GNU CC is used. */
|
GNU CC is used. */
|
||||||
|
20
sysdeps/s390/string_private.h
Normal file
20
sysdeps/s390/string_private.h
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
/* Define _STRING_ARCH_unaligned. S/390 version.
|
||||||
|
Copyright (C) 2016 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/>. */
|
||||||
|
|
||||||
|
/* The s390 processors can access unaligned multi-byte variables. */
|
||||||
|
#define _STRING_ARCH_unaligned 1
|
@ -20,8 +20,8 @@
|
|||||||
# error "Never use <bits/string.h> directly; include <string.h> instead."
|
# error "Never use <bits/string.h> directly; include <string.h> instead."
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Define if architecture can access unaligned multi-byte variables. */
|
/* sparc uses the aligned string inline ABI. */
|
||||||
#define _STRING_ARCH_unaligned 0
|
#define _STRING_INLINE_unaligned 0
|
||||||
|
|
||||||
/* sparc32 and sparc64 strchr(x, '\0') perform better than
|
/* sparc32 and sparc64 strchr(x, '\0') perform better than
|
||||||
__rawmemchr(x, '\0'). */
|
__rawmemchr(x, '\0'). */
|
||||||
|
@ -20,8 +20,8 @@
|
|||||||
# error "Never use <bits/string.h> directly; include <string.h> instead."
|
# error "Never use <bits/string.h> directly; include <string.h> instead."
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* The ix86 processors can access unaligned multi-byte variables. */
|
/* Use the unaligned string inline ABI. */
|
||||||
#define _STRING_ARCH_unaligned 1
|
#define _STRING_INLINE_unaligned 1
|
||||||
|
|
||||||
/* Enable inline functions only for i486 or better when compiling for
|
/* Enable inline functions only for i486 or better when compiling for
|
||||||
ia32. */
|
ia32. */
|
||||||
|
20
sysdeps/x86/string_private.h
Normal file
20
sysdeps/x86/string_private.h
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
/* Define _STRING_ARCH_unaligned. i486/x86-64 version.
|
||||||
|
Copyright (C) 2016 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/>. */
|
||||||
|
|
||||||
|
/* The ix86 processors can access unaligned multi-byte variables. */
|
||||||
|
#define _STRING_ARCH_unaligned 1
|
Reference in New Issue
Block a user