diff options
author | Luc Van Oostenryck <luc.vanoostenryck@gmail.com> | 2019-11-09 13:12:16 +0100 |
---|---|---|
committer | Masahiro Yamada <yamada.masahiro@socionext.com> | 2019-11-15 00:13:23 +0900 |
commit | 80591e61a0f7e88deaada69844e4a31280c4a38f (patch) | |
tree | 30bad55cd656dc200bb83ac12f70c9e0e1bc4913 /Makefile | |
parent | 5347291415a33bfa6efa5bb61350b078f200956b (diff) | |
download | linux-80591e61a0f7e88deaada69844e4a31280c4a38f.tar.gz linux-80591e61a0f7e88deaada69844e4a31280c4a38f.tar.bz2 linux-80591e61a0f7e88deaada69844e4a31280c4a38f.zip |
kbuild: tell sparse about the $ARCH
Sparse uses the same executable for all archs and uses flags
like -m64, -mbig-endian or -D__arm__ for arch-specific parameters.
But Sparse also uses value from the host machine used to build
Sparse as default value for the target machine.
This works, of course, well for native build but can create
problems when cross-compiling, like defining both '__i386__'
and '__arm__' when cross-compiling for arm on a x86-64 machine.
Fix this by explicitely telling sparse the target architecture.
Reported-by: Ben Dooks <ben.dooks@codethink.co.uk>
Signed-off-by: Luc Van Oostenryck <luc.vanoostenryck@gmail.com>
Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
Diffstat (limited to 'Makefile')
-rw-r--r-- | Makefile | 3 |
1 files changed, 3 insertions, 0 deletions
@@ -917,6 +917,9 @@ ifeq ($(CONFIG_RELR),y) LDFLAGS_vmlinux += --pack-dyn-relocs=relr endif +# make the checker run with the right architecture +CHECKFLAGS += --arch=$(ARCH) + # insure the checker run with the right endianness CHECKFLAGS += $(if $(CONFIG_CPU_BIG_ENDIAN),-mbig-endian,-mlittle-endian) |