diff options
-rw-r--r-- | meta/recipes-core/glibc/glibc/relocate-locales.patch | 33 | ||||
-rw-r--r-- | meta/recipes-core/glibc/glibc_2.24.bb | 1 |
2 files changed, 34 insertions, 0 deletions
diff --git a/meta/recipes-core/glibc/glibc/relocate-locales.patch b/meta/recipes-core/glibc/glibc/relocate-locales.patch new file mode 100644 index 0000000000..11f7df4aca --- /dev/null +++ b/meta/recipes-core/glibc/glibc/relocate-locales.patch | |||
@@ -0,0 +1,33 @@ | |||
1 | The glibc locale path is hard-coded to the install prefix, but in SDKs we need | ||
2 | to be able to relocate the binaries. Expand the strings to 4K and put them in a | ||
3 | magic segment that we can relocate at install time. | ||
4 | |||
5 | Upstream-Status: Inappropriate (OE-specific) | ||
6 | Signed-off-by: Ross Burton <ross.burton@intel.com> | ||
7 | |||
8 | Index: git/locale/localeinfo.h | ||
9 | =================================================================== | ||
10 | --- git.orig/locale/localeinfo.h | ||
11 | +++ git/locale/localeinfo.h | ||
12 | @@ -325,7 +325,7 @@ _nl_lookup_word (locale_t l, int categor | ||
13 | } | ||
14 | |||
15 | /* Default search path if no LOCPATH environment variable. */ | ||
16 | -extern char _nl_default_locale_path[] attribute_hidden; | ||
17 | +extern char _nl_default_locale_path[4096] attribute_hidden; | ||
18 | |||
19 | /* Load the locale data for CATEGORY from the file specified by *NAME. | ||
20 | If *NAME is "", use environment variables as specified by POSIX, and | ||
21 | Index: git/locale/loadarchive.c | ||
22 | =================================================================== | ||
23 | --- git.orig/locale/loadarchive.c | ||
24 | +++ git/locale/loadarchive.c | ||
25 | @@ -42,7 +42,7 @@ | ||
26 | |||
27 | |||
28 | /* Name of the locale archive file. */ | ||
29 | -static const char archfname[] = COMPLOCALEDIR "/locale-archive"; | ||
30 | +static const char archfname[4096] __attribute__ ((section (".gccrelocprefix"))) = COMPLOCALEDIR "/locale-archive"; | ||
31 | |||
32 | /* Size of initial mapping window, optimal if large enough to | ||
33 | cover the header plus the initial locale. */ | ||
diff --git a/meta/recipes-core/glibc/glibc_2.24.bb b/meta/recipes-core/glibc/glibc_2.24.bb index 616f4e9817..94df4fc948 100644 --- a/meta/recipes-core/glibc/glibc_2.24.bb +++ b/meta/recipes-core/glibc/glibc_2.24.bb | |||
@@ -65,6 +65,7 @@ SRC_URI_append_class-nativesdk = "\ | |||
65 | file://0002-nativesdk-glibc-Fix-buffer-overrun-with-a-relocated-.patch \ | 65 | file://0002-nativesdk-glibc-Fix-buffer-overrun-with-a-relocated-.patch \ |
66 | file://0003-nativesdk-glibc-Raise-the-size-of-arrays-containing-.patch \ | 66 | file://0003-nativesdk-glibc-Raise-the-size-of-arrays-containing-.patch \ |
67 | file://0004-nativesdk-glibc-Allow-64-bit-atomics-for-x86.patch \ | 67 | file://0004-nativesdk-glibc-Allow-64-bit-atomics-for-x86.patch \ |
68 | file://relocate-locales.patch \ | ||
68 | " | 69 | " |
69 | 70 | ||
70 | S = "${WORKDIR}/git" | 71 | S = "${WORKDIR}/git" |