diff options
| -rw-r--r-- | meta/recipes-extended/bash/bash-4.2/mkbuiltins_have_stringize.patch | 26 | ||||
| -rw-r--r-- | meta/recipes-extended/bash/bash_4.2.bb | 3 |
2 files changed, 28 insertions, 1 deletions
diff --git a/meta/recipes-extended/bash/bash-4.2/mkbuiltins_have_stringize.patch b/meta/recipes-extended/bash/bash-4.2/mkbuiltins_have_stringize.patch new file mode 100644 index 0000000000..a9391d6cac --- /dev/null +++ b/meta/recipes-extended/bash/bash-4.2/mkbuiltins_have_stringize.patch | |||
| @@ -0,0 +1,26 @@ | |||
| 1 | On hosts with FORTIFY_SOURCES, stringize support is required, as it's used by | ||
| 2 | the macros to wrap functions (e.g. read and open in unistd.h). Those wrappers | ||
| 3 | use the STRING() macro from unistd.h. A header in the bash sources overrides | ||
| 4 | the unistd.h macro to 'x' when HAVE_STRINGIZE is not defined, causing the | ||
| 5 | wrappers to generate calls to 'xread' and 'xopen', which do not exist, | ||
| 6 | resulting in a failure to link. | ||
| 7 | |||
| 8 | Assume we have stringize support when cross-compiling, which works around the | ||
| 9 | issue. | ||
| 10 | |||
| 11 | It may be best for upstream to either give up on supporting compilers without | ||
| 12 | stringize support, or to not define STRING() at all when FORTIFY_SOURCES is | ||
| 13 | defined, letting the unistd.h one be used, instead. | ||
| 14 | |||
| 15 | Upstream-Status: Pending | ||
| 16 | |||
| 17 | --- bash-4.2.orig/builtins/mkbuiltins.c | ||
| 18 | +++ bash-4.2/builtins/mkbuiltins.c | ||
| 19 | @@ -28,6 +28,7 @@ | ||
| 20 | # define HAVE_STDLIB_H | ||
| 21 | |||
| 22 | # define HAVE_RENAME | ||
| 23 | +# define HAVE_STRINGIZE | ||
| 24 | #endif /* CROSS_COMPILING */ | ||
| 25 | |||
| 26 | #if defined (HAVE_UNISTD_H) | ||
diff --git a/meta/recipes-extended/bash/bash_4.2.bb b/meta/recipes-extended/bash/bash_4.2.bb index 5a0f015c79..07dda09e83 100644 --- a/meta/recipes-extended/bash/bash_4.2.bb +++ b/meta/recipes-extended/bash/bash_4.2.bb | |||
| @@ -4,7 +4,7 @@ require bash.inc | |||
| 4 | LICENSE = "GPLv3+" | 4 | LICENSE = "GPLv3+" |
| 5 | LIC_FILES_CHKSUM = "file://COPYING;md5=d32239bcb673463ab874e80d47fae504" | 5 | LIC_FILES_CHKSUM = "file://COPYING;md5=d32239bcb673463ab874e80d47fae504" |
| 6 | 6 | ||
| 7 | PR = "r5" | 7 | PR = "r6" |
| 8 | 8 | ||
| 9 | SRC_URI = "${GNU_MIRROR}/bash/${BPN}-${PV}.tar.gz;name=tarball \ | 9 | SRC_URI = "${GNU_MIRROR}/bash/${BPN}-${PV}.tar.gz;name=tarball \ |
| 10 | ${GNU_MIRROR}/bash/bash-4.2-patches/bash42-001;apply=yes;striplevel=0;name=patch001 \ | 10 | ${GNU_MIRROR}/bash/bash-4.2-patches/bash42-001;apply=yes;striplevel=0;name=patch001 \ |
| @@ -18,6 +18,7 @@ SRC_URI = "${GNU_MIRROR}/bash/${BPN}-${PV}.tar.gz;name=tarball \ | |||
| 18 | ${GNU_MIRROR}/bash/bash-4.2-patches/bash42-009;apply=yes;striplevel=0;name=patch009 \ | 18 | ${GNU_MIRROR}/bash/bash-4.2-patches/bash42-009;apply=yes;striplevel=0;name=patch009 \ |
| 19 | ${GNU_MIRROR}/bash/bash-4.2-patches/bash42-010;apply=yes;striplevel=0;name=patch010 \ | 19 | ${GNU_MIRROR}/bash/bash-4.2-patches/bash42-010;apply=yes;striplevel=0;name=patch010 \ |
| 20 | file://execute_cmd.patch;striplevel=0 \ | 20 | file://execute_cmd.patch;striplevel=0 \ |
| 21 | file://mkbuiltins_have_stringize.patch \ | ||
| 21 | " | 22 | " |
| 22 | 23 | ||
| 23 | SRC_URI[tarball.md5sum] = "3fb927c7c33022f1c327f14a81c0d4b0" | 24 | SRC_URI[tarball.md5sum] = "3fb927c7c33022f1c327f14a81c0d4b0" |
