* [dpdk-dev] [PATCH] mk: pass CROSS_COMPILE when compiling kernel modules
@ 2014-02-07 16:44 Aaro Koskinen
  2014-02-25 21:55 ` Thomas Monjalon
  0 siblings, 1 reply; 4+ messages in thread
From: Aaro Koskinen @ 2014-02-07 16:44 UTC (permalink / raw)
  To: dev
Pass CROSS_COMPILE to the kernel build system when compiling kernel
modules. Although we export CC etc. the top level kernel Makefile will
override the environment. As a result it will end up using wrong tools
if cross-compilation is desired but CROSS_COMPILE is not set.
Signed-off-by: Aaro Koskinen <aaro.koskinen@nsn.com>
---
 mk/rte.module.mk | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/mk/rte.module.mk b/mk/rte.module.mk
index b3a630e..5d66d90 100644
--- a/mk/rte.module.mk
+++ b/mk/rte.module.mk
@@ -77,7 +77,7 @@ build: _postbuild
 # build module
 $(MODULE).ko: $(SRCS_LINKS)
 	@if [ ! -f $(notdir Makefile) ]; then ln -nfs $(SRCDIR)/Makefile . ; fi
-	@$(MAKE) -C $(RTE_KERNELDIR) M=$(CURDIR) O=$(RTE_KERNELDIR)
+	@$(MAKE) -C $(RTE_KERNELDIR) M=$(CURDIR) O=$(RTE_KERNELDIR) CROSS_COMPILE=$(CROSS)
 
 # install module in $(RTE_OUTPUT)/kmod
 $(RTE_OUTPUT)/kmod/$(MODULE).ko: $(MODULE).ko
-- 
1.8.5.1
^ permalink raw reply	[flat|nested] 4+ messages in thread
- * Re: [dpdk-dev] [PATCH] mk: pass CROSS_COMPILE when compiling kernel modules
  2014-02-07 16:44 [dpdk-dev] [PATCH] mk: pass CROSS_COMPILE when compiling kernel modules Aaro Koskinen
@ 2014-02-25 21:55 ` Thomas Monjalon
  2014-03-07 13:32   ` Aaro Koskinen
  0 siblings, 1 reply; 4+ messages in thread
From: Thomas Monjalon @ 2014-02-25 21:55 UTC (permalink / raw)
  To: Aaro Koskinen; +Cc: dev
Hi,
07/02/2014 18:44, Aaro Koskinen :
> Pass CROSS_COMPILE to the kernel build system when compiling kernel
> modules. Although we export CC etc. the top level kernel Makefile will
> override the environment. As a result it will end up using wrong tools
> if cross-compilation is desired but CROSS_COMPILE is not set.
> 
> Signed-off-by: Aaro Koskinen <aaro.koskinen@nsn.com>
Could you explain why it's needed ?
In a basic test, CC=$(CROSS)gcc in rte.vars.mk seems sufficient.
Thanks
-- 
Thomas
^ permalink raw reply	[flat|nested] 4+ messages in thread 
- * Re: [dpdk-dev] [PATCH] mk: pass CROSS_COMPILE when compiling kernel modules
  2014-02-25 21:55 ` Thomas Monjalon
@ 2014-03-07 13:32   ` Aaro Koskinen
  2014-04-17 13:38     ` Thomas Monjalon
  0 siblings, 1 reply; 4+ messages in thread
From: Aaro Koskinen @ 2014-03-07 13:32 UTC (permalink / raw)
  To: Thomas Monjalon; +Cc: dev
Hi,
On Tue, Feb 25, 2014 at 10:55:36PM +0100, Thomas Monjalon wrote:
> 07/02/2014 18:44, Aaro Koskinen :
> > Pass CROSS_COMPILE to the kernel build system when compiling kernel
> > modules. Although we export CC etc. the top level kernel Makefile will
> > override the environment. As a result it will end up using wrong tools
> > if cross-compilation is desired but CROSS_COMPILE is not set.
> > 
> > Signed-off-by: Aaro Koskinen <aaro.koskinen@nsn.com>
> 
> Could you explain why it's needed ?
> In a basic test, CC=$(CROSS)gcc in rte.vars.mk seems sufficient.
If you compile on 32-bit host to 64-bit target, the build fails with
errors such as:
[...]include/linux/kernfs.h:331:1: note: expected 'const char *' but argument is of type 'const unsigned char *'
 kernfs_find_and_get(struct kernfs_node *kn, const char *name)
 ^
cc1: all warnings being treated as errors
Build with V=1 shows that following appears in the command line
when compiling the kernel modules:
	-isystem /usr/lib/gcc/i486-linux-gnu/4.8/include
With the patch this will be corrected to point to my target's sysroot:
	-isystem /foo/bar/lib/gcc/x86_64-linux-gnu/4.8.2/include
And the build succeeds without any warnings.
A.
^ permalink raw reply	[flat|nested] 4+ messages in thread 
- * Re: [dpdk-dev] [PATCH] mk: pass CROSS_COMPILE when compiling kernel modules
  2014-03-07 13:32   ` Aaro Koskinen
@ 2014-04-17 13:38     ` Thomas Monjalon
  0 siblings, 0 replies; 4+ messages in thread
From: Thomas Monjalon @ 2014-04-17 13:38 UTC (permalink / raw)
  To: Aaro Koskinen; +Cc: dev
Hi,
2014-03-07 15:32, Aaro Koskinen:
> On Tue, Feb 25, 2014 at 10:55:36PM +0100, Thomas Monjalon wrote:
> > 07/02/2014 18:44, Aaro Koskinen :
> > > Pass CROSS_COMPILE to the kernel build system when compiling kernel
> > > modules. Although we export CC etc. the top level kernel Makefile will
> > > override the environment. As a result it will end up using wrong tools
> > > if cross-compilation is desired but CROSS_COMPILE is not set.
> > > 
> > > Signed-off-by: Aaro Koskinen <aaro.koskinen@nsn.com>
> > 
> > Could you explain why it's needed ?
> > In a basic test, CC=$(CROSS)gcc in rte.vars.mk seems sufficient.
> 
> If you compile on 32-bit host to 64-bit target, the build fails with
> errors such as:
> 
> [...]include/linux/kernfs.h:331:1: note: expected 'const char *' but
> argument is of type 'const unsigned char *' kernfs_find_and_get(struct
> kernfs_node *kn, const char *name)
>  ^
> cc1: all warnings being treated as errors
> 
> Build with V=1 shows that following appears in the command line
> when compiling the kernel modules:
> 
> 	-isystem /usr/lib/gcc/i486-linux-gnu/4.8/include
> 
> With the patch this will be corrected to point to my target's sysroot:
> 
> 	-isystem /foo/bar/lib/gcc/x86_64-linux-gnu/4.8.2/include
> 
> And the build succeeds without any warnings.
Acked-by: Thomas Monjalon <thomas.monjalon@6wind.com>
It's applied for version 1.6.0r2.
Thanks
-- 
Thomas
^ permalink raw reply	[flat|nested] 4+ messages in thread 
 
 
end of thread, other threads:[~2014-04-17 13:38 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2014-02-07 16:44 [dpdk-dev] [PATCH] mk: pass CROSS_COMPILE when compiling kernel modules Aaro Koskinen
2014-02-25 21:55 ` Thomas Monjalon
2014-03-07 13:32   ` Aaro Koskinen
2014-04-17 13:38     ` Thomas Monjalon
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).