[Buildroot] [PATCH 1/1] package/qemu: fix host-qemu compilation with recent GCC

Arnout Vandecappelle arnout at mind.be
Thu Apr 14 19:34:21 UTC 2022



On 06/04/2022 23:10, Dario Binacchi via buildroot wrote:
> Fixes:
> cc1: error: ‘-fcf-protection’ is not compatible with this target
> 
> The new Ubuntu GCC packages (e.g. Ubuntu 11.2.0-7ubuntu2, 11.2.0) turn
> on ‘-fcf-protection’ globally, which causes a build failure in the x86
> realmode code. Turn it off explicitly on compilers that understand this
> option.
> 
> Signed-off-by: Dario Binacchi <dariobin at libero.it>
> Signed-off-by: Dario Binacchi <dario.binacchi at amarulasolutions.com>

  Two Sob is a bit exaggerated :-)

> ---
>   ...able-fcf-protection-on-march-486-m16.patch | 49 +++++++++++++++++++
>   1 file changed, 49 insertions(+)
>   create mode 100644 package/qemu/0002-build-disable-fcf-protection-on-march-486-m16.patch
> 
> diff --git a/package/qemu/0002-build-disable-fcf-protection-on-march-486-m16.patch b/package/qemu/0002-build-disable-fcf-protection-on-march-486-m16.patch
> new file mode 100644
> index 0000000000..7a841fcb60
> --- /dev/null
> +++ b/package/qemu/0002-build-disable-fcf-protection-on-march-486-m16.patch
> @@ -0,0 +1,49 @@
> +From 9584d3d00a454f47b0341465142bcf0735d734ae Mon Sep 17 00:00:00 2001
> +From: Christian Ehrhardt <christian.ehrhardt at canonical.com>
> +Date: Wed, 23 Mar 2022 10:07:13 +0100
> +Subject: [PATCH] build: disable fcf-protection on -march=486 -m16
> +MIME-Version: 1.0
> +Content-Type: text/plain; charset=UTF-8
> +Content-Transfer-Encoding: 8bit
> +
> +Some of the roms build with -march=i486 -m16 which is incompatible
> +with -fcf-protection. That in turn is can be set by default, for
> +example in Ubuntu [1].
> +That causes:
> + cc1: error: ‘-fcf-protection’ is not compatible with this target
> +
> +This won't work on -march=i486 -m16 and no matter if set or not we can
> +override it to "none" if the option is known to the compiler to be
> +able to build reliably.
> +
> +Fixes: https://gitlab.com/qemu-project/qemu/-/issues/889
> +
> +[1]: https://wiki.ubuntu.com/ToolChain/CompilerFlags#A-fcf-protection
> +
> +Signed-off-by: Christian Ehrhardt <christian.ehrhardt at canonical.com>
> +Reviewed-by: Philippe Mathieu-Daudé <f4bug at amsat.org>
> +Reviewed-by: Thomas Huth <thuth at redhat.com>
> +Message-Id: <20220323090713.1002588-1-christian.ehrhardt at canonical.com>
> +Signed-off-by: Paolo Bonzini <pbonzini at redhat.com>

  And here your Sob was missing! I took the liberty of adding it.

  Applied to master, thanks.

  Regards,
  Arnout

> +---
> + pc-bios/optionrom/Makefile | 4 ++++
> + 1 file changed, 4 insertions(+)
> +
> +diff --git a/pc-bios/optionrom/Makefile b/pc-bios/optionrom/Makefile
> +index 5d55d25acca2..f1ef89807355 100644
> +--- a/pc-bios/optionrom/Makefile
> ++++ b/pc-bios/optionrom/Makefile
> +@@ -14,6 +14,10 @@ cc-option = $(if $(shell $(CC) $1 -c -o /dev/null -xc /dev/null >/dev/null 2>&1
> +
> + override CFLAGS += -march=i486 -Wall
> +
> ++# If -fcf-protection is enabled in flags or compiler defaults that will
> ++# conflict with -march=i486
> ++override CFLAGS += $(call cc-option, -fcf-protection=none)
> ++
> + # Flags for dependency generation
> + override CPPFLAGS += -MMD -MP -MT $@ -MF $(@D)/$(*F).d
> +
> +--
> +2.32.0
> +



More information about the buildroot mailing list