# HG changeset patch # User Cody Schafer # Date 1399688029 25200 # Node ID 4876ff97e0399f76b30a1f2266aa5a023495d02e # Parent e35fa03cd2043496839aa5fa3a1a3d2d375b5535 cc/gcc: allow CC_EXTRA_CONFIG_ARRAY on baremetal The final bare-metal compiler is built using the core backend. Currently the core uses the CC_CORE_EXTRA_CONFIG_ARRAY variable. While this works as supposed to, this can leave the user puzzled in the menuconfig, since all he can see is the core options, not the final options. Only show the core options if any of the core passes are needed, and use the final options in the core-backend if we're issuing the bare-metal compiler. Signed-off-by: Cody P Schafer [yann.morin.1998@free.fr: hide core options if no core pass needed; use final option in core backend if issuing the bare-metal compiler] Signed-off-by: "Yann E. MORIN" Message-Id: <22181e546ba746202489.1399688067@localhost> Patchwork-Id: 347586 diff -r e35fa03cd204 -r 4876ff97e039 config/cc/gcc.in.2 --- a/config/cc/gcc.in.2 Fri May 09 19:11:59 2014 -0700 +++ b/config/cc/gcc.in.2 Fri May 09 19:13:49 2014 -0700 @@ -15,6 +15,7 @@ string prompt "Core gcc extra config" default "" + depends on CC_CORE_PASS_1_NEEDED || CC_CORE_PASS_2_NEEDED help Extra flags to pass onto ./configure when configuring the core gcc. @@ -29,7 +30,6 @@ string prompt "gcc extra config" default "" - depends on ! BARE_METAL help Extra flags to pass onto ./configure when configuring gcc. diff -r e35fa03cd204 -r 4876ff97e039 scripts/build/cc/gcc.sh --- a/scripts/build/cc/gcc.sh Fri May 09 19:11:59 2014 -0700 +++ b/scripts/build/cc/gcc.sh Fri May 09 19:13:49 2014 -0700 @@ -188,6 +188,7 @@ local -a extra_config local -a core_LDFLAGS local -a core_targets + local -a extra_user_config local arg for arg in "$@"; do @@ -201,17 +202,20 @@ extra_config+=("--with-newlib") extra_config+=("--enable-threads=no") extra_config+=("--disable-shared") + extra_user_config=( "${CT_CC_CORE_EXTRA_CONFIG_ARRAY[@]}" ) copy_headers=y # For baremetal, as there's no headers to copy, # we copy an empty directory. So, who cares? ;; shared) extra_config+=("--enable-shared") + extra_user_config=( "${CT_CC_CORE_EXTRA_CONFIG_ARRAY[@]}" ) copy_headers=y ;; baremetal) extra_config+=("--with-newlib") extra_config+=("--enable-threads=no") extra_config+=("--disable-shared") + extra_user_config=( "${CT_CC_EXTRA_CONFIG_ARRAY[@]}" ) copy_headers=n ;; *) @@ -391,7 +395,7 @@ ${CC_CORE_SYSROOT_ARG} \ "${extra_config[@]}" \ --enable-languages="${lang_list}" \ - "${CT_CC_CORE_EXTRA_CONFIG_ARRAY[@]}" + "${extra_user_config[@]}" if [ "${build_libgcc}" = "yes" ]; then # HACK: we need to override SHLIB_LC from gcc/config/t-slibgcc-elf-ver or