[PATCH] Makefile.am: don't confuse CFLAGS and CFLAGS_FOR_BUILD

Dmitry V. Levin ldv at altlinux.org
Wed Nov 16 19:27:18 UTC 2016


Hi,

On Tue, Oct 18, 2016 at 01:42:44PM +0200, Thomas De Schampheleire wrote:
> From: Thomas De Schampheleire <thomas.de_schampheleire at nokia.com>
> 
> Commit dc427d50d96b15c9a64d7e78d97ce4d194622a63 enabled a number of extra
> warning flags through configure.ac. The configure script will determine
> dynamically if CC supports these flags before adding them to WARN_CFLAGS.
> 
> ioctlsort is compiled with CC_FOR_BUILD, rather than CC. Nevertheless, the
> flags passed to this compilation also include WARN_CFLAGS (through
> AM_CFLAGS). This is incorrect: in a cross-compilation use case, CC and
> CC_FOR_BUILD are not the same. The former is the cross-compiler,
> the latter is the host compiler. Both may be of different versions and
> support different warning flags.
> 
> In particular, this posed a problem when cross-compiling with a host
> compiler gcc 4.1, which does not support all the new flags:
> 
>     /usr/bin/gcc -DHAVE_CONFIG_H   -I./linux/arm -I./linux/arm -I./linux
>     -I./linux -I. -I. -I/host-sysroot/usr/include -Wall -Wempty-body
>     -Wformat-security -Wignored-qualifiers -Winit-self -Wlogical-op
>     -Wmissing-parameter-type -Wnested-externs -Wold-style-declaration
>     -Wold-style-definition -Wsign-compare -Wtype-limits -Wwrite-strings -O2
>     -I/host-sysroot/usr/include -DIOCTLSORT_INC=\"ioctls_all0.h\" -c -o
>     ioctlsort0.o ./ioctlsort.c
>     cc1: error: unrecognized command line option "-Wempty-body"
>     cc1: error: unrecognized command line option "-Wignored-qualifiers"
>     cc1: error: unrecognized command line option "-Wlogical-op"
>     cc1: error: unrecognized command line option "-Wmissing-parameter-type"
>     cc1: error: unrecognized command line option "-Wold-style-declaration"
>     cc1: error: unrecognized command line option "-Wtype-limits"
>     make[2]: *** [ioctlsort0.o] Error 1
> 
> Fix by introducing AM_C/CPP/LDFLAGS_FOR_BUILD which are empty by default.
> Only AM_CPPFLAGS_FOR_BUILD actually needs to be filled for now, based on
> AM_CPPFLAGS.
> 
> Signed-off-by: Thomas De Schampheleire <thomas.de_schampheleire at nokia.com>

Good catch.  Unfortunately, the change you propose also strips all
WARN_CFLAGS from the build of ioctlsort executable, which is certainly
not what we want.

The correct fix is going to be more complex, e.g.
- move all gl_WARN_ADD/WARN_CFLAGS related code from configure.ac to a
  separate m4 macro, say st_WARN_CFLAGS;
- call st_WARN_CFLAGS in configure.ac;
- modify AX_PROG_CC_FOR_BUILD to
  + pushdef WARN_CFLAGS to WARN_CFLAGS_FOR_BUILD,
  + call st_WARN_CFLAGS,
  + popdef WARN_CFLAGS back,
  + AC_SUBST WARN_CFLAGS_FOR_BUILD;
- add WARN_CFLAGS_FOR_BUILD to AM_CFLAGS_FOR_BUILD.

> --- a/Makefile.am
> +++ b/Makefile.am
> @@ -52,6 +52,7 @@ AM_CPPFLAGS = -I$(builddir)/$(OS)/$(ARCH) \
>  	      -I$(srcdir)/$(OS) \
>  	      -I$(builddir) \
>  	      -I$(srcdir)
> +AM_CPPFLAGS_FOR_BUILD = $(AM_CPPFLAGS)
>  
>  include xlat/Makemodule.am
>  
> @@ -720,9 +721,9 @@ news-check: NEWS
>  ioctlsort_CC = $(CC_FOR_BUILD)
>  ioctlsort_DEFS = $(DEFS)
>  ioctlsort_INCLUDES = $(DEFAULT_INCLUDES) $(INCLUDES)
> -ioctlsort_CPPFLAGS = $(AM_CPPFLAGS) $(CPPFLAGS_FOR_BUILD)
> -ioctlsort_CFLAGS = $(AM_CFLAGS) $(CFLAGS_FOR_BUILD)
> -ioctlsort_LDFLAGS = $(AM_LDFLAGS) $(LDFLAGS_FOR_BUILD)
> +ioctlsort_CPPFLAGS = $(AM_CPPFLAGS_FOR_BUILD) $(CPPFLAGS_FOR_BUILD)
> +ioctlsort_CFLAGS = $(AM_CFLAGS_FOR_BUILD) $(CFLAGS_FOR_BUILD)
> +ioctlsort_LDFLAGS = $(AM_LDFLAGS_FOR_BUILD) $(LDFLAGS_FOR_BUILD)
>  
>  ioctls_inc_h = $(wildcard $(srcdir)/$(OS)/$(ARCH)/ioctls_inc*.h)
>  ioctlent_h = $(patsubst $(srcdir)/$(OS)/$(ARCH)/ioctls_inc%,ioctlent%,$(ioctls_inc_h))

-- 
ldv
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 819 bytes
Desc: not available
URL: <http://lists.strace.io/pipermail/strace-devel/attachments/20161116/28c66e86/attachment.bin>


More information about the Strace-devel mailing list