https://gcc.gnu.org/g:773beeaafb0ea31bd4e308b64781731d64b571ce
commit r15-6969-g773beeaafb0ea31bd4e308b64781731d64b571ce Author: Tamar Christina <tamar.christ...@arm.com> Date: Thu Jan 16 19:23:50 2025 +0000 AArch64: don't override march to assembler with mcpu if march is specified [PR110901] When both -mcpu and -march are specified, the value of -march wins out. This is done correctly for the calls to cc1 and for the assembler directives we put out in assembly files. However in the call to as we don't do this and instead use the arch from the cpu. This leads to a situation that GCC cannot reliably be used to compile assembly files which don't have a .arch directive. This is quite common with .S files which use macros to selectively enable codepath based on what the preprocessor sees. The fix is to change MCPU_TO_MARCH_SPEC to not override the march if an march is already specified. gcc/ChangeLog: PR target/110901 * config/aarch64/aarch64.h (MCPU_TO_MARCH_SPEC): Don't override if march is set. gcc/testsuite/ChangeLog: PR target/110901 * gcc.target/aarch64/options_set_29.c: New test. Diff: --- gcc/config/aarch64/aarch64.h | 2 +- gcc/testsuite/gcc.target/aarch64/options_set_29.c | 11 +++++++++++ 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/gcc/config/aarch64/aarch64.h b/gcc/config/aarch64/aarch64.h index 1ab49e229b08..218868a5246a 100644 --- a/gcc/config/aarch64/aarch64.h +++ b/gcc/config/aarch64/aarch64.h @@ -1510,7 +1510,7 @@ extern const char *host_detect_local_cpu (int argc, const char **argv); CONFIG_TUNE_SPEC #define MCPU_TO_MARCH_SPEC \ - " %{mcpu=*:-march=%:rewrite_mcpu(%{mcpu=*:%*})}" + "%{!march=*:%{mcpu=*:-march=%:rewrite_mcpu(%{mcpu=*:%*})}}" extern const char *aarch64_rewrite_mcpu (int argc, const char **argv); extern const char *is_host_cpu_not_armv8_base (int argc, const char **argv); diff --git a/gcc/testsuite/gcc.target/aarch64/options_set_29.c b/gcc/testsuite/gcc.target/aarch64/options_set_29.c new file mode 100644 index 000000000000..0a68550951ce --- /dev/null +++ b/gcc/testsuite/gcc.target/aarch64/options_set_29.c @@ -0,0 +1,11 @@ +/* { dg-do assemble } */ +/* { dg-additional-options "-march=armv8.2-a+sve -mcpu=cortex-a72 -O1 -w -###" } */ + +int main () +{ + return 0; +} + +/* { dg-message "-march=armv8-a\+crc" "no arch from cpu" { xfail *-*-* } 0 } */ +/* { dg-message "-march=armv8\\.2-a\\+sve" "using only sve" { target *-*-* } 0 } */ +/* { dg-excess-errors "" } */