mirror of git://sourceware.org/git/glibc.git
				
				
				
			S390: Refactor wcscspn ifunc handling.
The ifunc handling for wcscspn is adjusted in order to omit ifunc if the minimum architecture level already supports newer CPUs by default. Unfortunately the c ifunc variant can't be omitted at all as it is used by the z13 ifunc variant as fallback if the pointers are not 4-byte aligned. ChangeLog: * sysdeps/s390/multiarch/Makefile (sysdep_routines): Remove wcscspn variants. * sysdeps/s390/Makefile (sysdep_routines): Add wcscspn variants. * sysdeps/s390/multiarch/ifunc-impl-list.c (__libc_ifunc_impl_list): Refactor ifunc handling for wcscspn. * sysdeps/s390/multiarch/wcscspn-c.c: Move to ... * sysdeps/s390/wcscspn-c.c: ... here and adjust ifunc handling. * sysdeps/s390/multiarch/wcscspn-vx.S: Move to ... * sysdeps/s390/wcscspn-vx.S: ... here and adjust ifunc handling. * sysdeps/s390/multiarch/wcscspn.c: Move to ... * sysdeps/s390/wcscspn.c: ... here and adjust ifunc handling. * sysdeps/s390/ifunc-wcscspn.h: New file.
This commit is contained in:
		
							parent
							
								
									8e87c1f6d4
								
							
						
					
					
						commit
						79b44cf611
					
				
							
								
								
									
										15
									
								
								ChangeLog
								
								
								
								
							
							
						
						
									
										15
									
								
								ChangeLog
								
								
								
								
							|  | @ -1,3 +1,18 @@ | ||||||
|  | 2018-12-18  Stefan Liebler  <stli@linux.ibm.com> | ||||||
|  | 
 | ||||||
|  | 	* sysdeps/s390/multiarch/Makefile | ||||||
|  | 	(sysdep_routines): Remove wcscspn variants. | ||||||
|  | 	* sysdeps/s390/Makefile (sysdep_routines): Add wcscspn variants. | ||||||
|  | 	* sysdeps/s390/multiarch/ifunc-impl-list.c | ||||||
|  | 	(__libc_ifunc_impl_list): Refactor ifunc handling for wcscspn. | ||||||
|  | 	* sysdeps/s390/multiarch/wcscspn-c.c: Move to ... | ||||||
|  | 	* sysdeps/s390/wcscspn-c.c: ... here and adjust ifunc handling. | ||||||
|  | 	* sysdeps/s390/multiarch/wcscspn-vx.S: Move to ... | ||||||
|  | 	* sysdeps/s390/wcscspn-vx.S: ... here and adjust ifunc handling. | ||||||
|  | 	* sysdeps/s390/multiarch/wcscspn.c: Move to ... | ||||||
|  | 	* sysdeps/s390/wcscspn.c: ... here and adjust ifunc handling. | ||||||
|  | 	* sysdeps/s390/ifunc-wcscspn.h: New file. | ||||||
|  | 
 | ||||||
| 2018-12-18  Stefan Liebler  <stli@linux.ibm.com> | 2018-12-18  Stefan Liebler  <stli@linux.ibm.com> | ||||||
| 
 | 
 | ||||||
| 	* sysdeps/s390/multiarch/Makefile | 	* sysdeps/s390/multiarch/Makefile | ||||||
|  |  | ||||||
|  | @ -97,5 +97,6 @@ sysdep_routines += wcslen wcslen-vx wcslen-c \ | ||||||
| 		   wcschrnul wcschrnul-vx wcschrnul-c \
 | 		   wcschrnul wcschrnul-vx wcschrnul-c \
 | ||||||
| 		   wcsrchr wcsrchr-vx wcsrchr-c \
 | 		   wcsrchr wcsrchr-vx wcsrchr-c \
 | ||||||
| 		   wcsspn wcsspn-vx wcsspn-c \
 | 		   wcsspn wcsspn-vx wcsspn-c \
 | ||||||
| 		   wcspbrk wcspbrk-vx wcspbrk-c | 		   wcspbrk wcspbrk-vx wcspbrk-c \
 | ||||||
|  | 		   wcscspn wcscspn-vx wcscspn-c | ||||||
| endif | endif | ||||||
|  |  | ||||||
|  | @ -0,0 +1,53 @@ | ||||||
|  | /* wcscspn variant information on S/390 version.
 | ||||||
|  |    Copyright (C) 2018 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/>.  */
 | ||||||
|  | 
 | ||||||
|  | #if defined USE_MULTIARCH && IS_IN (libc)		\ | ||||||
|  |   && ! defined HAVE_S390_MIN_Z13_ZARCH_ASM_SUPPORT | ||||||
|  | # define HAVE_WCSCSPN_IFUNC	1 | ||||||
|  | #else | ||||||
|  | # define HAVE_WCSCSPN_IFUNC	0 | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | #ifdef HAVE_S390_VX_ASM_SUPPORT | ||||||
|  | # define HAVE_WCSCSPN_IFUNC_AND_VX_SUPPORT HAVE_WCSCSPN_IFUNC | ||||||
|  | #else | ||||||
|  | # define HAVE_WCSCSPN_IFUNC_AND_VX_SUPPORT 0 | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | #if defined HAVE_S390_MIN_Z13_ZARCH_ASM_SUPPORT | ||||||
|  | # define WCSCSPN_DEFAULT	WCSCSPN_Z13 | ||||||
|  | /* The z13 ifunc variant is using the common code variant as fallback!  */ | ||||||
|  | # define HAVE_WCSCSPN_C		1 | ||||||
|  | # define HAVE_WCSCSPN_Z13	1 | ||||||
|  | #else | ||||||
|  | # define WCSCSPN_DEFAULT	WCSCSPN_C | ||||||
|  | # define HAVE_WCSCSPN_C		1 | ||||||
|  | # define HAVE_WCSCSPN_Z13	HAVE_WCSCSPN_IFUNC_AND_VX_SUPPORT | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | #if HAVE_WCSCSPN_C | ||||||
|  | # define WCSCSPN_C		__wcscspn_c | ||||||
|  | #else | ||||||
|  | # define WCSCSPN_C		NULL | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | #if HAVE_WCSCSPN_Z13 | ||||||
|  | # define WCSCSPN_Z13		__wcscspn_vx | ||||||
|  | #else | ||||||
|  | # define WCSCSPN_Z13		NULL | ||||||
|  | #endif | ||||||
|  | @ -1,6 +1,5 @@ | ||||||
| ifeq ($(subdir),wcsmbs) | ifeq ($(subdir),wcsmbs) | ||||||
| sysdep_routines += wcscspn wcscspn-vx wcscspn-c \
 | sysdep_routines += wmemchr wmemchr-vx wmemchr-c \
 | ||||||
| 		   wmemchr wmemchr-vx wmemchr-c \
 |  | ||||||
| 		   wmemset wmemset-vx wmemset-c \
 | 		   wmemset wmemset-vx wmemset-c \
 | ||||||
| 		   wmemcmp wmemcmp-vx wmemcmp-c | 		   wmemcmp wmemcmp-vx wmemcmp-c | ||||||
| endif | endif | ||||||
|  |  | ||||||
|  | @ -61,6 +61,7 @@ | ||||||
| #include <ifunc-wcsrchr.h> | #include <ifunc-wcsrchr.h> | ||||||
| #include <ifunc-wcsspn.h> | #include <ifunc-wcsspn.h> | ||||||
| #include <ifunc-wcspbrk.h> | #include <ifunc-wcspbrk.h> | ||||||
|  | #include <ifunc-wcscspn.h> | ||||||
| 
 | 
 | ||||||
| /* Maximum number of IFUNC implementations.  */ | /* Maximum number of IFUNC implementations.  */ | ||||||
| #define MAX_IFUNC	3 | #define MAX_IFUNC	3 | ||||||
|  | @ -619,6 +620,18 @@ __libc_ifunc_impl_list (const char *name, struct libc_ifunc_impl *array, | ||||||
| 		) | 		) | ||||||
| #endif /* HAVE_WCSPBRK_IFUNC  */ | #endif /* HAVE_WCSPBRK_IFUNC  */ | ||||||
| 
 | 
 | ||||||
|  | #if HAVE_WCSCSPN_IFUNC | ||||||
|  |     IFUNC_IMPL (i, name, wcscspn, | ||||||
|  | # if HAVE_WCSCSPN_Z13 | ||||||
|  | 		IFUNC_IMPL_ADD (array, i, wcscspn, | ||||||
|  | 				dl_hwcap & HWCAP_S390_VX, WCSCSPN_Z13) | ||||||
|  | # endif | ||||||
|  | # if HAVE_WCSCSPN_C | ||||||
|  | 		IFUNC_IMPL_ADD (array, i, wcscspn, 1, WCSCSPN_C) | ||||||
|  | # endif | ||||||
|  | 		) | ||||||
|  | #endif /* HAVE_WCSCSPN_IFUNC  */ | ||||||
|  | 
 | ||||||
| #ifdef HAVE_S390_VX_ASM_SUPPORT | #ifdef HAVE_S390_VX_ASM_SUPPORT | ||||||
| 
 | 
 | ||||||
| # define IFUNC_VX_IMPL(FUNC)						\ | # define IFUNC_VX_IMPL(FUNC)						\ | ||||||
|  | @ -627,8 +640,6 @@ __libc_ifunc_impl_list (const char *name, struct libc_ifunc_impl *array, | ||||||
| 			      __##FUNC##_vx)				\ | 			      __##FUNC##_vx)				\ | ||||||
| 	      IFUNC_IMPL_ADD (array, i, FUNC, 1, __##FUNC##_c)) | 	      IFUNC_IMPL_ADD (array, i, FUNC, 1, __##FUNC##_c)) | ||||||
| 
 | 
 | ||||||
|   IFUNC_VX_IMPL (wcscspn); |  | ||||||
| 
 |  | ||||||
|   IFUNC_VX_IMPL (wmemchr); |   IFUNC_VX_IMPL (wmemchr); | ||||||
| 
 | 
 | ||||||
|   IFUNC_VX_IMPL (wmemset); |   IFUNC_VX_IMPL (wmemset); | ||||||
|  |  | ||||||
|  | @ -16,11 +16,12 @@ | ||||||
|    License along with the GNU C Library; if not, see |    License along with the GNU C Library; if not, see | ||||||
|    <http://www.gnu.org/licenses/>.  */
 |    <http://www.gnu.org/licenses/>.  */
 | ||||||
| 
 | 
 | ||||||
| #if defined HAVE_S390_VX_ASM_SUPPORT && IS_IN (libc) | #include <ifunc-wcscspn.h> | ||||||
| # define WCSCSPN  __wcscspn_c |  | ||||||
| 
 | 
 | ||||||
| # include <wchar.h> | #if HAVE_WCSCSPN_C | ||||||
| extern __typeof (wcscspn) __wcscspn_c; | # if HAVE_WCSCSPN_IFUNC || HAVE_WCSCSPN_Z13 | ||||||
|  | #  define WCSCSPN WCSCSPN_C | ||||||
|  | # endif | ||||||
| 
 | 
 | ||||||
| # include <wcsmbs/wcscspn.c> | # include <wcsmbs/wcscspn.c> | ||||||
| #endif | #endif | ||||||
|  | @ -16,7 +16,8 @@ | ||||||
|    License along with the GNU C Library; if not, see
 |    License along with the GNU C Library; if not, see
 | ||||||
|    <http://www.gnu.org/licenses/>.  */ |    <http://www.gnu.org/licenses/>.  */ | ||||||
| 
 | 
 | ||||||
| #if defined HAVE_S390_VX_ASM_SUPPORT && IS_IN (libc) | #include <ifunc-wcscspn.h> | ||||||
|  | #if HAVE_WCSCSPN_Z13 | ||||||
| 
 | 
 | ||||||
| # include "sysdep.h" | # include "sysdep.h" | ||||||
| # include "asm-syntax.h" | # include "asm-syntax.h" | ||||||
|  | @ -57,7 +58,7 @@ | ||||||
| 			otherwise =0;
 | 			otherwise =0;
 | ||||||
|    r9:  loaded byte count of vlbb reject-string |    r9:  loaded byte count of vlbb reject-string | ||||||
| */ | */ | ||||||
| ENTRY(__wcscspn_vx) | ENTRY(WCSCSPN_Z13) | ||||||
| 	.machine "z13" | 	.machine "z13" | ||||||
| 	.machinemode "zarch_nohighgprs" | 	.machinemode "zarch_nohighgprs" | ||||||
| 
 | 
 | ||||||
|  | @ -288,6 +289,10 @@ ENTRY(__wcscspn_vx) | ||||||
| 	vlgvg	%r9,%v31,1 | 	vlgvg	%r9,%v31,1 | ||||||
| 	br	%r14 | 	br	%r14 | ||||||
| .Lfallback: | .Lfallback: | ||||||
| 	jg	__wcscspn_c | 	jg	WCSCSPN_C | ||||||
| END(__wcscspn_vx) | END(WCSCSPN_Z13) | ||||||
| #endif /* HAVE_S390_VX_ASM_SUPPORT && IS_IN (libc) */ | 
 | ||||||
|  | # if ! HAVE_WCSCSPN_IFUNC | ||||||
|  | strong_alias (WCSCSPN_Z13, wcscspn) | ||||||
|  | # endif | ||||||
|  | #endif | ||||||
|  | @ -16,12 +16,23 @@ | ||||||
|    License along with the GNU C Library; if not, see |    License along with the GNU C Library; if not, see | ||||||
|    <http://www.gnu.org/licenses/>.  */
 |    <http://www.gnu.org/licenses/>.  */
 | ||||||
| 
 | 
 | ||||||
| #if defined HAVE_S390_VX_ASM_SUPPORT && IS_IN (libc) | #include <ifunc-wcscspn.h> | ||||||
|  | 
 | ||||||
|  | #if HAVE_WCSCSPN_IFUNC | ||||||
| # include <wchar.h> | # include <wchar.h> | ||||||
| # include <ifunc-resolve.h> | # include <ifunc-resolve.h> | ||||||
| 
 | 
 | ||||||
| s390_vx_libc_ifunc2 (__wcscspn, wcscspn) | # if HAVE_WCSCSPN_C | ||||||
|  | extern __typeof (wcscspn) WCSCSPN_C attribute_hidden; | ||||||
|  | # endif | ||||||
| 
 | 
 | ||||||
| #else | # if HAVE_WCSCSPN_Z13 | ||||||
| # include <wcsmbs/wcscspn.c> | extern __typeof (wcscspn) WCSCSPN_Z13 attribute_hidden; | ||||||
| #endif /* !(defined HAVE_S390_VX_ASM_SUPPORT && IS_IN (libc)) */ | # endif | ||||||
|  | 
 | ||||||
|  | s390_libc_ifunc_expr (wcscspn, wcscspn, | ||||||
|  | 		      (HAVE_WCSCSPN_Z13 && (hwcap & HWCAP_S390_VX)) | ||||||
|  | 		      ? WCSCSPN_Z13 | ||||||
|  | 		      : WCSCSPN_DEFAULT | ||||||
|  | 		      ) | ||||||
|  | #endif | ||||||
		Loading…
	
		Reference in New Issue