Re: [PATCH] RISC-V: Use KBUILD_CFLAGS instead of KCFLAGS when building the vDSO

From: Christoph Hellwig
Date: Thu Jul 05 2018 - 11:44:24 EST


On Wed, Jul 04, 2018 at 02:10:56PM -0700, Palmer Dabbelt wrote:
> If you use a 64-bit compiler to build a 32-bit kernel then you'll get an
> error when building the vDSO due to a library mismatch. The happens
> because the relevant "-march" argument isn't supplied to the GCC run
> that generates one of the vDSO intermediate files.
>
> I'm not actually sure what the right thing to do here is as I'm not
> particularly familiar with the kernel build system. I poked the
> documentation and it appears that KCFLAGS is the correct thing to do
> (it's suggested that should be used when building modules), but we set
> KBUILD_CFLAGS in arch/riscv/Makefile.
>
> This does at least fix the build error.

Looks good to me for now. In the future we might want to use different
ABIs in the kernel and in userspace, at which point we'd need yet
another cflags variable.

Reviewed-by: Christoph Hellwig <hch@xxxxxx>