diff options
| author | Mark Hatle <mark.hatle@kernel.crashing.org> | 2020-09-02 14:46:36 -0500 |
|---|---|---|
| committer | Mark Hatle <mark.hatle@xilinx.com> | 2020-11-30 12:46:23 -0800 |
| commit | 44d2470b340abe75a92a89e7598dff6a75472f2d (patch) | |
| tree | 13f9b31635faba938a613dacfcb6c8c7317f2028 /meta-microblaze/recipes-devtools | |
| parent | c4df43e8b4b965a6deb13ed108fb6da96cdaffb4 (diff) | |
| download | meta-xilinx-44d2470b340abe75a92a89e7598dff6a75472f2d.tar.gz | |
meta-microblaze: Move gcc patch that was missed in the prior work
Signed-off-by: Mark Hatle <mark.hatle@kernel.crashing.org>
Diffstat (limited to 'meta-microblaze/recipes-devtools')
| -rw-r--r-- | meta-microblaze/recipes-devtools/gcc/gcc-10/0059-microblaze-multilib-hack.patch | 58 | ||||
| -rw-r--r-- | meta-microblaze/recipes-devtools/gcc/gcc-source_10.%.bbappend | 1 |
2 files changed, 59 insertions, 0 deletions
diff --git a/meta-microblaze/recipes-devtools/gcc/gcc-10/0059-microblaze-multilib-hack.patch b/meta-microblaze/recipes-devtools/gcc/gcc-10/0059-microblaze-multilib-hack.patch new file mode 100644 index 00000000..af8ebf3b --- /dev/null +++ b/meta-microblaze/recipes-devtools/gcc/gcc-10/0059-microblaze-multilib-hack.patch | |||
| @@ -0,0 +1,58 @@ | |||
| 1 | Microblaze Mulitlib hack | ||
| 2 | |||
| 3 | Based on the patch: | ||
| 4 | |||
| 5 | From c2081c51db589471ea713870c72f13999abda815 Mon Sep 17 00:00:00 2001 | ||
| 6 | From: Khem Raj <raj.khem@gmail.com> | ||
| 7 | Date: Fri, 29 Mar 2013 09:10:06 +0400 | ||
| 8 | Subject: [PATCH 04/36] 64-bit multilib hack. | ||
| 9 | |||
| 10 | GCC has internal multilib handling code but it assumes a very specific rigid directory | ||
| 11 | layout. The build system implementation of multilib layout is very generic and allows | ||
| 12 | complete customisation of the library directories. | ||
| 13 | |||
| 14 | This patch is a partial solution to allow any custom directories to be passed into gcc | ||
| 15 | and handled correctly. It forces gcc to use the base_libdir (which is the current | ||
| 16 | directory, "."). We need to do this for each multilib that is configured as we don't | ||
| 17 | know which compiler options may be being passed into the compiler. Since we have a compiler | ||
| 18 | per mulitlib at this point that isn't an issue. | ||
| 19 | |||
| 20 | The one problem is the target compiler is only going to work for the default multlilib at | ||
| 21 | this point. Ideally we'd figure out which multilibs were being enabled with which paths | ||
| 22 | and be able to patch these entries with a complete set of correct paths but this we | ||
| 23 | don't have such code at this point. This is something the target gcc recipe should do | ||
| 24 | and override these platform defaults in its build config. | ||
| 25 | |||
| 26 | Do same for riscv64 and aarch64 | ||
| 27 | |||
| 28 | RP 15/8/11 | ||
| 29 | |||
| 30 | Upstream-Status: Inappropriate[OE-Specific] | ||
| 31 | |||
| 32 | Signed-off-by: Khem Raj <raj.khem@gmail.com> | ||
| 33 | Signed-off-by: Elvis Dowson <elvis.dowson@gmail.com> | ||
| 34 | Signed-off-by: Mark Hatle <mark.hatle@windriver.com> | ||
| 35 | Signed-off-by: Mark Hatle <mark.hatle@xilinx.com> | ||
| 36 | |||
| 37 | Index: gcc-9.2.0/gcc/config/microblaze/t-microblaze | ||
| 38 | =================================================================== | ||
| 39 | --- gcc-9.2.0.orig/gcc/config/microblaze/t-microblaze | ||
| 40 | +++ gcc-9.2.0/gcc/config/microblaze/t-microblaze | ||
| 41 | @@ -1,5 +1,6 @@ | ||
| 42 | MULTILIB_OPTIONS = m64 mxl-barrel-shift mlittle-endian mno-xl-soft-mul mxl-multiply-high | ||
| 43 | -MULTILIB_DIRNAMES = m64 bs le m mh | ||
| 44 | +#MULTILIB_DIRNAMES = m64 bs le m mh | ||
| 45 | +MULTILIB_DIRNAMES = . . . . . | ||
| 46 | MULTILIB_EXCEPTIONS = *m64/mxl-multiply-high mxl-multiply-high | ||
| 47 | MULTILIB_EXCEPTIONS += *m64 | ||
| 48 | MULTILIB_EXCEPTIONS += *m64/mxl-barrel-shift | ||
| 49 | Index: gcc-9.2.0/gcc/config/microblaze/t-microblaze-linux | ||
| 50 | =================================================================== | ||
| 51 | --- gcc-9.2.0.orig/gcc/config/microblaze/t-microblaze-linux | ||
| 52 | +++ gcc-9.2.0/gcc/config/microblaze/t-microblaze-linux | ||
| 53 | @@ -1,3 +1,4 @@ | ||
| 54 | MULTILIB_OPTIONS = mxl-barrel-shift mno-xl-soft-mul mxl-multiply-high | ||
| 55 | -MULTILIB_DIRNAMES = bs m mh | ||
| 56 | +#MULTILIB_DIRNAMES = bs m mh | ||
| 57 | +MULTILIB_DIRNAMES = . . . | ||
| 58 | MULTILIB_EXCEPTIONS = *mxl-barrel-shift/mxl-multiply-high mxl-multiply-high | ||
diff --git a/meta-microblaze/recipes-devtools/gcc/gcc-source_10.%.bbappend b/meta-microblaze/recipes-devtools/gcc/gcc-source_10.%.bbappend index 79b895fc..7e8c1fa5 100644 --- a/meta-microblaze/recipes-devtools/gcc/gcc-source_10.%.bbappend +++ b/meta-microblaze/recipes-devtools/gcc/gcc-source_10.%.bbappend | |||
| @@ -60,4 +60,5 @@ SRC_URI_append_microblaze = " \ | |||
| 60 | file://0056-Patch-MicroBlaze-Added-support-for-64-bit-Immediate-.patch \ | 60 | file://0056-Patch-MicroBlaze-Added-support-for-64-bit-Immediate-.patch \ |
| 61 | file://0057-Patch-microblaze-Fix-Compiler-crash-with-freg-struct.patch \ | 61 | file://0057-Patch-microblaze-Fix-Compiler-crash-with-freg-struct.patch \ |
| 62 | file://0058-microblaze-Avoid-UINTPTR_TYPE-macro-redefinition.patch \ | 62 | file://0058-microblaze-Avoid-UINTPTR_TYPE-macro-redefinition.patch \ |
| 63 | file://0059-microblaze-multilib-hack.patch \ | ||
| 63 | " | 64 | " |
