1feee8
commit b41c535f46e7e7bbd8ff2ac68b94c2348e2f66e4
1feee8
Author: Raphael Moreira Zinsly <rzinsly@linux.ibm.com>
1feee8
Date:   Wed Aug 24 11:43:37 2022 -0300
1feee8
1feee8
    Apply asm redirections in wchar.h before first use
1feee8
    
1feee8
    Similar to d0fa09a770, but for wchar.h.  Fixes [BZ #27087] by applying
1feee8
    all long double related asm redirections before using functions in
1feee8
    bits/wchar2.h.
1feee8
    Moves the function declarations from wcsmbs/bits/wchar2.h to a new file
1feee8
    wcsmbs/bits/wchar2-decl.h that will be included first in wcsmbs/wchar.h.
1feee8
    
1feee8
    Tested with build-many-glibcs.py.
1feee8
    Reviewed-by: Adhemerval Zanella  <adhemerval.zanella@linaro.org>
1feee8
    
1feee8
    (cherry picked from commit c7509d49c4e8fa494120c5ead21338559dad16f5)
1feee8
1feee8
diff --git a/include/bits/wchar2-decl.h b/include/bits/wchar2-decl.h
1feee8
new file mode 100644
1feee8
index 0000000000000000..00b1b93342ef28ff
1feee8
--- /dev/null
1feee8
+++ b/include/bits/wchar2-decl.h
1feee8
@@ -0,0 +1 @@
1feee8
+#include <wcsmbs/bits/wchar2-decl.h>
1feee8
diff --git a/wcsmbs/Makefile b/wcsmbs/Makefile
1feee8
index f38eb5cfe16fd3d7..5fe755e65df6c621 100644
1feee8
--- a/wcsmbs/Makefile
1feee8
+++ b/wcsmbs/Makefile
1feee8
@@ -22,8 +22,9 @@ subdir	:= wcsmbs
1feee8
 
1feee8
 include ../Makeconfig
1feee8
 
1feee8
-headers	:= wchar.h bits/wchar.h bits/wchar2.h bits/wchar-ldbl.h uchar.h \
1feee8
-	   bits/types/__mbstate_t.h bits/types/mbstate_t.h bits/types/wint_t.h
1feee8
+headers	:= wchar.h bits/wchar.h bits/wchar2.h bits/wchar2-decl.h \
1feee8
+	   bits/wchar-ldbl.h uchar.h bits/types/__mbstate_t.h \
1feee8
+	   bits/types/mbstate_t.h bits/types/wint_t.h
1feee8
 
1feee8
 routines := wcscat wcschr wcscmp wcscpy wcscspn wcsdup wcslen wcsncat \
1feee8
 	    wcsncmp wcsncpy wcspbrk wcsrchr wcsspn wcstok wcsstr wmemchr \
1feee8
diff --git a/wcsmbs/bits/wchar2-decl.h b/wcsmbs/bits/wchar2-decl.h
1feee8
new file mode 100644
1feee8
index 0000000000000000..8e1735c33b7f7e78
1feee8
--- /dev/null
1feee8
+++ b/wcsmbs/bits/wchar2-decl.h
1feee8
@@ -0,0 +1,124 @@
1feee8
+/* Checking macros for wchar functions.  Declarations only.
1feee8
+   Copyright (C) 2004-2022 Free Software Foundation, Inc.
1feee8
+   This file is part of the GNU C Library.
1feee8
+
1feee8
+   The GNU C Library is free software; you can redistribute it and/or
1feee8
+   modify it under the terms of the GNU Lesser General Public
1feee8
+   License as published by the Free Software Foundation; either
1feee8
+   version 2.1 of the License, or (at your option) any later version.
1feee8
+
1feee8
+   The GNU C Library is distributed in the hope that it will be useful,
1feee8
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
1feee8
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
1feee8
+   Lesser General Public License for more details.
1feee8
+
1feee8
+   You should have received a copy of the GNU Lesser General Public
1feee8
+   License along with the GNU C Library; if not, see
1feee8
+   <https://www.gnu.org/licenses/>.  */
1feee8
+
1feee8
+#ifndef _BITS_WCHAR2_DECL_H
1feee8
+#define _BITS_WCHAR2_DECL_H 1
1feee8
+
1feee8
+#ifndef _WCHAR_H
1feee8
+# error "Never include <bits/wchar2-decl.h> directly; use <wchar.h> instead."
1feee8
+#endif
1feee8
+
1feee8
+
1feee8
+extern wchar_t *__wmemcpy_chk (wchar_t *__restrict __s1,
1feee8
+			       const wchar_t *__restrict __s2, size_t __n,
1feee8
+			       size_t __ns1) __THROW;
1feee8
+extern wchar_t *__wmemmove_chk (wchar_t *__s1, const wchar_t *__s2,
1feee8
+				size_t __n, size_t __ns1) __THROW;
1feee8
+
1feee8
+
1feee8
+#ifdef __USE_GNU
1feee8
+
1feee8
+extern wchar_t *__wmempcpy_chk (wchar_t *__restrict __s1,
1feee8
+				const wchar_t *__restrict __s2, size_t __n,
1feee8
+				size_t __ns1) __THROW;
1feee8
+
1feee8
+#endif
1feee8
+
1feee8
+
1feee8
+extern wchar_t *__wmemset_chk (wchar_t *__s, wchar_t __c, size_t __n,
1feee8
+			       size_t __ns) __THROW;
1feee8
+extern wchar_t *__wcscpy_chk (wchar_t *__restrict __dest,
1feee8
+			      const wchar_t *__restrict __src,
1feee8
+			      size_t __n) __THROW;
1feee8
+extern wchar_t *__wcpcpy_chk (wchar_t *__restrict __dest,
1feee8
+			      const wchar_t *__restrict __src,
1feee8
+			      size_t __destlen) __THROW;
1feee8
+extern wchar_t *__wcsncpy_chk (wchar_t *__restrict __dest,
1feee8
+			       const wchar_t *__restrict __src, size_t __n,
1feee8
+			       size_t __destlen) __THROW;
1feee8
+extern wchar_t *__wcpncpy_chk (wchar_t *__restrict __dest,
1feee8
+			       const wchar_t *__restrict __src, size_t __n,
1feee8
+			       size_t __destlen) __THROW;
1feee8
+extern wchar_t *__wcscat_chk (wchar_t *__restrict __dest,
1feee8
+			      const wchar_t *__restrict __src,
1feee8
+			      size_t __destlen) __THROW;
1feee8
+extern wchar_t *__wcsncat_chk (wchar_t *__restrict __dest,
1feee8
+			       const wchar_t *__restrict __src,
1feee8
+			       size_t __n, size_t __destlen) __THROW;
1feee8
+extern int __swprintf_chk (wchar_t *__restrict __s, size_t __n,
1feee8
+			   int __flag, size_t __s_len,
1feee8
+			   const wchar_t *__restrict __format, ...)
1feee8
+     __THROW /* __attribute__ ((__format__ (__wprintf__, 5, 6))) */;
1feee8
+extern int __vswprintf_chk (wchar_t *__restrict __s, size_t __n,
1feee8
+			    int __flag, size_t __s_len,
1feee8
+			    const wchar_t *__restrict __format,
1feee8
+			    __gnuc_va_list __arg)
1feee8
+     __THROW /* __attribute__ ((__format__ (__wprintf__, 5, 0))) */;
1feee8
+
1feee8
+#if __USE_FORTIFY_LEVEL > 1
1feee8
+
1feee8
+extern int __fwprintf_chk (__FILE *__restrict __stream, int __flag,
1feee8
+			   const wchar_t *__restrict __format, ...);
1feee8
+extern int __wprintf_chk (int __flag, const wchar_t *__restrict __format,
1feee8
+			  ...);
1feee8
+extern int __vfwprintf_chk (__FILE *__restrict __stream, int __flag,
1feee8
+			    const wchar_t *__restrict __format,
1feee8
+			    __gnuc_va_list __ap);
1feee8
+extern int __vwprintf_chk (int __flag, const wchar_t *__restrict __format,
1feee8
+			   __gnuc_va_list __ap);
1feee8
+
1feee8
+#endif
1feee8
+
1feee8
+extern wchar_t *__fgetws_chk (wchar_t *__restrict __s, size_t __size, int __n,
1feee8
+			      __FILE *__restrict __stream) __wur;
1feee8
+
1feee8
+#ifdef __USE_GNU
1feee8
+
1feee8
+extern wchar_t *__fgetws_unlocked_chk (wchar_t *__restrict __s, size_t __size,
1feee8
+				       int __n, __FILE *__restrict __stream)
1feee8
+       __wur;
1feee8
+
1feee8
+#endif
1feee8
+
1feee8
+extern size_t __wcrtomb_chk (char *__restrict __s, wchar_t __wchar,
1feee8
+			     mbstate_t *__restrict __p,
1feee8
+			     size_t __buflen) __THROW __wur;
1feee8
+extern size_t __mbsrtowcs_chk (wchar_t *__restrict __dst,
1feee8
+			       const char **__restrict __src,
1feee8
+			       size_t __len, mbstate_t *__restrict __ps,
1feee8
+			       size_t __dstlen) __THROW;
1feee8
+extern size_t __wcsrtombs_chk (char *__restrict __dst,
1feee8
+			       const wchar_t **__restrict __src,
1feee8
+			       size_t __len, mbstate_t *__restrict __ps,
1feee8
+			       size_t __dstlen) __THROW;
1feee8
+
1feee8
+#ifdef	__USE_XOPEN2K8
1feee8
+
1feee8
+extern size_t __mbsnrtowcs_chk (wchar_t *__restrict __dst,
1feee8
+				const char **__restrict __src, size_t __nmc,
1feee8
+				size_t __len, mbstate_t *__restrict __ps,
1feee8
+				size_t __dstlen) __THROW;
1feee8
+extern size_t __wcsnrtombs_chk (char *__restrict __dst,
1feee8
+				const wchar_t **__restrict __src,
1feee8
+				size_t __nwc, size_t __len,
1feee8
+				mbstate_t *__restrict __ps, size_t __dstlen)
1feee8
+       __THROW;
1feee8
+
1feee8
+#endif
1feee8
+
1feee8
+#endif /* bits/wchar2-decl.h.  */
1feee8
diff --git a/wcsmbs/bits/wchar2.h b/wcsmbs/bits/wchar2.h
1feee8
index 88c1fdfcd34292f4..50151b424d85a032 100644
1feee8
--- a/wcsmbs/bits/wchar2.h
1feee8
+++ b/wcsmbs/bits/wchar2.h
1feee8
@@ -21,9 +21,6 @@
1feee8
 #endif
1feee8
 
1feee8
 
1feee8
-extern wchar_t *__wmemcpy_chk (wchar_t *__restrict __s1,
1feee8
-			       const wchar_t *__restrict __s2, size_t __n,
1feee8
-			       size_t __ns1) __THROW;
1feee8
 extern wchar_t *__REDIRECT_NTH (__wmemcpy_alias,
1feee8
 				(wchar_t *__restrict __s1,
1feee8
 				 const wchar_t *__restrict __s2, size_t __n),
1feee8
@@ -45,8 +42,6 @@ __NTH (wmemcpy (wchar_t *__restrict __s1, const wchar_t *__restrict __s2,
1feee8
 }
1feee8
 
1feee8
 
1feee8
-extern wchar_t *__wmemmove_chk (wchar_t *__s1, const wchar_t *__s2,
1feee8
-				size_t __n, size_t __ns1) __THROW;
1feee8
 extern wchar_t *__REDIRECT_NTH (__wmemmove_alias, (wchar_t *__s1,
1feee8
 						   const wchar_t *__s2,
1feee8
 						   size_t __n), wmemmove);
1feee8
@@ -66,9 +61,6 @@ __NTH (wmemmove (wchar_t *__s1, const wchar_t *__s2, size_t __n))
1feee8
 
1feee8
 
1feee8
 #ifdef __USE_GNU
1feee8
-extern wchar_t *__wmempcpy_chk (wchar_t *__restrict __s1,
1feee8
-				const wchar_t *__restrict __s2, size_t __n,
1feee8
-				size_t __ns1) __THROW;
1feee8
 extern wchar_t *__REDIRECT_NTH (__wmempcpy_alias,
1feee8
 				(wchar_t *__restrict __s1,
1feee8
 				 const wchar_t *__restrict __s2,
1feee8
@@ -91,8 +83,6 @@ __NTH (wmempcpy (wchar_t *__restrict __s1, const wchar_t *__restrict __s2,
1feee8
 #endif
1feee8
 
1feee8
 
1feee8
-extern wchar_t *__wmemset_chk (wchar_t *__s, wchar_t __c, size_t __n,
1feee8
-			       size_t __ns) __THROW;
1feee8
 extern wchar_t *__REDIRECT_NTH (__wmemset_alias, (wchar_t *__s, wchar_t __c,
1feee8
 						  size_t __n), wmemset);
1feee8
 extern wchar_t *__REDIRECT_NTH (__wmemset_chk_warn,
1feee8
@@ -110,9 +100,6 @@ __NTH (wmemset (wchar_t *__s, wchar_t __c, size_t __n))
1feee8
 }
1feee8
 
1feee8
 
1feee8
-extern wchar_t *__wcscpy_chk (wchar_t *__restrict __dest,
1feee8
-			      const wchar_t *__restrict __src,
1feee8
-			      size_t __n) __THROW;
1feee8
 extern wchar_t *__REDIRECT_NTH (__wcscpy_alias,
1feee8
 				(wchar_t *__restrict __dest,
1feee8
 				 const wchar_t *__restrict __src), wcscpy);
1feee8
@@ -127,9 +114,6 @@ __NTH (wcscpy (wchar_t *__restrict __dest, const wchar_t *__restrict __src))
1feee8
 }
1feee8
 
1feee8
 
1feee8
-extern wchar_t *__wcpcpy_chk (wchar_t *__restrict __dest,
1feee8
-			      const wchar_t *__restrict __src,
1feee8
-			      size_t __destlen) __THROW;
1feee8
 extern wchar_t *__REDIRECT_NTH (__wcpcpy_alias,
1feee8
 				(wchar_t *__restrict __dest,
1feee8
 				 const wchar_t *__restrict __src), wcpcpy);
1feee8
@@ -144,9 +128,6 @@ __NTH (wcpcpy (wchar_t *__restrict __dest, const wchar_t *__restrict __src))
1feee8
 }
1feee8
 
1feee8
 
1feee8
-extern wchar_t *__wcsncpy_chk (wchar_t *__restrict __dest,
1feee8
-			       const wchar_t *__restrict __src, size_t __n,
1feee8
-			       size_t __destlen) __THROW;
1feee8
 extern wchar_t *__REDIRECT_NTH (__wcsncpy_alias,
1feee8
 				(wchar_t *__restrict __dest,
1feee8
 				 const wchar_t *__restrict __src,
1feee8
@@ -168,9 +149,6 @@ __NTH (wcsncpy (wchar_t *__restrict __dest, const wchar_t *__restrict __src,
1feee8
 }
1feee8
 
1feee8
 
1feee8
-extern wchar_t *__wcpncpy_chk (wchar_t *__restrict __dest,
1feee8
-			       const wchar_t *__restrict __src, size_t __n,
1feee8
-			       size_t __destlen) __THROW;
1feee8
 extern wchar_t *__REDIRECT_NTH (__wcpncpy_alias,
1feee8
 				(wchar_t *__restrict __dest,
1feee8
 				 const wchar_t *__restrict __src,
1feee8
@@ -192,9 +170,6 @@ __NTH (wcpncpy (wchar_t *__restrict __dest, const wchar_t *__restrict __src,
1feee8
 }
1feee8
 
1feee8
 
1feee8
-extern wchar_t *__wcscat_chk (wchar_t *__restrict __dest,
1feee8
-			      const wchar_t *__restrict __src,
1feee8
-			      size_t __destlen) __THROW;
1feee8
 extern wchar_t *__REDIRECT_NTH (__wcscat_alias,
1feee8
 				(wchar_t *__restrict __dest,
1feee8
 				 const wchar_t *__restrict __src), wcscat);
1feee8
@@ -209,9 +184,6 @@ __NTH (wcscat (wchar_t *__restrict __dest, const wchar_t *__restrict __src))
1feee8
 }
1feee8
 
1feee8
 
1feee8
-extern wchar_t *__wcsncat_chk (wchar_t *__restrict __dest,
1feee8
-			       const wchar_t *__restrict __src,
1feee8
-			       size_t __n, size_t __destlen) __THROW;
1feee8
 extern wchar_t *__REDIRECT_NTH (__wcsncat_alias,
1feee8
 				(wchar_t *__restrict __dest,
1feee8
 				 const wchar_t *__restrict __src,
1feee8
@@ -228,10 +200,6 @@ __NTH (wcsncat (wchar_t *__restrict __dest, const wchar_t *__restrict __src,
1feee8
 }
1feee8
 
1feee8
 
1feee8
-extern int __swprintf_chk (wchar_t *__restrict __s, size_t __n,
1feee8
-			   int __flag, size_t __s_len,
1feee8
-			   const wchar_t *__restrict __format, ...)
1feee8
-     __THROW /* __attribute__ ((__format__ (__wprintf__, 5, 6))) */;
1feee8
 
1feee8
 extern int __REDIRECT_NTH_LDBL (__swprintf_alias,
1feee8
 				(wchar_t *__restrict __s, size_t __n,
1feee8
@@ -258,11 +226,6 @@ __NTH (swprintf (wchar_t *__restrict __s, size_t __n,
1feee8
    : swprintf (s, n, __VA_ARGS__))
1feee8
 #endif
1feee8
 
1feee8
-extern int __vswprintf_chk (wchar_t *__restrict __s, size_t __n,
1feee8
-			    int __flag, size_t __s_len,
1feee8
-			    const wchar_t *__restrict __format,
1feee8
-			    __gnuc_va_list __arg)
1feee8
-     __THROW /* __attribute__ ((__format__ (__wprintf__, 5, 0))) */;
1feee8
 
1feee8
 extern int __REDIRECT_NTH_LDBL (__vswprintf_alias,
1feee8
 				(wchar_t *__restrict __s, size_t __n,
1feee8
@@ -283,16 +246,6 @@ __NTH (vswprintf (wchar_t *__restrict __s, size_t __n,
1feee8
 
1feee8
 #if __USE_FORTIFY_LEVEL > 1
1feee8
 
1feee8
-extern int __fwprintf_chk (__FILE *__restrict __stream, int __flag,
1feee8
-			   const wchar_t *__restrict __format, ...);
1feee8
-extern int __wprintf_chk (int __flag, const wchar_t *__restrict __format,
1feee8
-			  ...);
1feee8
-extern int __vfwprintf_chk (__FILE *__restrict __stream, int __flag,
1feee8
-			    const wchar_t *__restrict __format,
1feee8
-			    __gnuc_va_list __ap);
1feee8
-extern int __vwprintf_chk (int __flag, const wchar_t *__restrict __format,
1feee8
-			   __gnuc_va_list __ap);
1feee8
-
1feee8
 # ifdef __va_arg_pack
1feee8
 __fortify_function int
1feee8
 wprintf (const wchar_t *__restrict __fmt, ...)
1feee8
@@ -328,8 +281,6 @@ vfwprintf (__FILE *__restrict __stream,
1feee8
 
1feee8
 #endif
1feee8
 
1feee8
-extern wchar_t *__fgetws_chk (wchar_t *__restrict __s, size_t __size, int __n,
1feee8
-			      __FILE *__restrict __stream) __wur;
1feee8
 extern wchar_t *__REDIRECT (__fgetws_alias,
1feee8
 			    (wchar_t *__restrict __s, int __n,
1feee8
 			     __FILE *__restrict __stream), fgetws) __wur;
1feee8
@@ -351,9 +302,6 @@ fgetws (wchar_t *__restrict __s, int __n, __FILE *__restrict __stream)
1feee8
 }
1feee8
 
1feee8
 #ifdef __USE_GNU
1feee8
-extern wchar_t *__fgetws_unlocked_chk (wchar_t *__restrict __s, size_t __size,
1feee8
-				       int __n, __FILE *__restrict __stream)
1feee8
-  __wur;
1feee8
 extern wchar_t *__REDIRECT (__fgetws_unlocked_alias,
1feee8
 			    (wchar_t *__restrict __s, int __n,
1feee8
 			     __FILE *__restrict __stream), fgetws_unlocked)
1feee8
@@ -379,9 +327,6 @@ fgetws_unlocked (wchar_t *__restrict __s, int __n, __FILE *__restrict __stream)
1feee8
 #endif
1feee8
 
1feee8
 
1feee8
-extern size_t __wcrtomb_chk (char *__restrict __s, wchar_t __wchar,
1feee8
-			     mbstate_t *__restrict __p,
1feee8
-			     size_t __buflen) __THROW __wur;
1feee8
 extern size_t __REDIRECT_NTH (__wcrtomb_alias,
1feee8
 			      (char *__restrict __s, wchar_t __wchar,
1feee8
 			       mbstate_t *__restrict __ps), wcrtomb) __wur;
1feee8
@@ -404,10 +349,6 @@ __NTH (wcrtomb (char *__restrict __s, wchar_t __wchar,
1feee8
 }
1feee8
 
1feee8
 
1feee8
-extern size_t __mbsrtowcs_chk (wchar_t *__restrict __dst,
1feee8
-			       const char **__restrict __src,
1feee8
-			       size_t __len, mbstate_t *__restrict __ps,
1feee8
-			       size_t __dstlen) __THROW;
1feee8
 extern size_t __REDIRECT_NTH (__mbsrtowcs_alias,
1feee8
 			      (wchar_t *__restrict __dst,
1feee8
 			       const char **__restrict __src,
1feee8
@@ -431,10 +372,6 @@ __NTH (mbsrtowcs (wchar_t *__restrict __dst, const char **__restrict __src,
1feee8
 }
1feee8
 
1feee8
 
1feee8
-extern size_t __wcsrtombs_chk (char *__restrict __dst,
1feee8
-			       const wchar_t **__restrict __src,
1feee8
-			       size_t __len, mbstate_t *__restrict __ps,
1feee8
-			       size_t __dstlen) __THROW;
1feee8
 extern size_t __REDIRECT_NTH (__wcsrtombs_alias,
1feee8
 			      (char *__restrict __dst,
1feee8
 			       const wchar_t **__restrict __src,
1feee8
@@ -458,10 +395,6 @@ __NTH (wcsrtombs (char *__restrict __dst, const wchar_t **__restrict __src,
1feee8
 
1feee8
 
1feee8
 #ifdef	__USE_XOPEN2K8
1feee8
-extern size_t __mbsnrtowcs_chk (wchar_t *__restrict __dst,
1feee8
-				const char **__restrict __src, size_t __nmc,
1feee8
-				size_t __len, mbstate_t *__restrict __ps,
1feee8
-				size_t __dstlen) __THROW;
1feee8
 extern size_t __REDIRECT_NTH (__mbsnrtowcs_alias,
1feee8
 			      (wchar_t *__restrict __dst,
1feee8
 			       const char **__restrict __src, size_t __nmc,
1feee8
@@ -485,11 +418,6 @@ __NTH (mbsnrtowcs (wchar_t *__restrict __dst, const char **__restrict __src,
1feee8
 }
1feee8
 
1feee8
 
1feee8
-extern size_t __wcsnrtombs_chk (char *__restrict __dst,
1feee8
-				const wchar_t **__restrict __src,
1feee8
-				size_t __nwc, size_t __len,
1feee8
-				mbstate_t *__restrict __ps, size_t __dstlen)
1feee8
-     __THROW;
1feee8
 extern size_t __REDIRECT_NTH (__wcsnrtombs_alias,
1feee8
 			      (char *__restrict __dst,
1feee8
 			       const wchar_t **__restrict __src,
1feee8
diff --git a/wcsmbs/wchar.h b/wcsmbs/wchar.h
1feee8
index 075776890f214842..1c6d4026c46b7306 100644
1feee8
--- a/wcsmbs/wchar.h
1feee8
+++ b/wcsmbs/wchar.h
1feee8
@@ -864,14 +864,21 @@ extern size_t wcsftime_l (wchar_t *__restrict __s, size_t __maxsize,
1feee8
 
1feee8
 /* Define some macros helping to catch buffer overflows.  */
1feee8
 #if __USE_FORTIFY_LEVEL > 0 && defined __fortify_function
1feee8
-# include <bits/wchar2.h>
1feee8
+/* Declare all functions from bits/wchar2-decl.h first.  */
1feee8
+# include <bits/wchar2-decl.h>
1feee8
 #endif
1feee8
 
1feee8
-#include <bits/floatn.h>
1feee8
+/* The following headers provide asm redirections.  These redirections must
1feee8
+   appear before the first usage of these functions, e.g. in bits/wchar.h.  */
1feee8
 #if defined __LDBL_COMPAT || __LDOUBLE_REDIRECTS_TO_FLOAT128_ABI == 1
1feee8
 # include <bits/wchar-ldbl.h>
1feee8
 #endif
1feee8
 
1feee8
+#if __USE_FORTIFY_LEVEL > 0 && defined __fortify_function
1feee8
+/* Now include the function definitions and redirects too.  */
1feee8
+# include <bits/wchar2.h>
1feee8
+#endif
1feee8
+
1feee8
 __END_DECLS
1feee8
 
1feee8
 #endif /* wchar.h  */