On Mon, Jun 3, 2024 at 2:23 AM Andrew Pinski (QUIC) <quic_apin...@quicinc.com> wrote: > > > -----Original Message----- > > From: Andrew Pinski (QUIC) <quic_apin...@quicinc.com> > > Sent: Saturday, May 4, 2024 2:03 AM > > To: gcc-patches@gcc.gnu.org > > Cc: Andrew Pinski (QUIC) <quic_apin...@quicinc.com> > > Subject: [PATCH] aarch64: Support multiple variants including > > up to 3 > > > > On some of the Qualcomm's SoC that includes oryon-1 core, > > the variant will be different on the cores due to big.little > > config. Though the difference between big and little is not > > significant enough to have seperate cost/scheduling models > > for them and the feature set is the same across all variants. > > > > Also on some SoCs, there are 3 variants of the core, > > big.middle.little so this increases the support there for up to 3 > > cores and 3 variants in the original parsing loop but it does not > > change the support for max of 2 different cores. > > > > After this patch and the patch that adds oryon-1, - > > mcpu=native works on the SoCs I am working with. > > > > Bootstrapped and tested on aarch64-linux-gnu with no > > regressions. > > Ping?
Ping? Thanks, Andrew > > > > > gcc/ChangeLog: > > > > * config/aarch64/driver-aarch64.cc > > (host_detect_local_cpu): Support > > 3 cores and 3 variants. If there is one core but multiple > > variant, > > then treat the variant as being all. > > > > gcc/testsuite/ChangeLog: > > > > * gcc.target/aarch64/cpunative/info_25: New file. > > * gcc.target/aarch64/cpunative/info_26: New file. > > * gcc.target/aarch64/cpunative/native_cpu_25.c: New > > test. > > * gcc.target/aarch64/cpunative/native_cpu_26.c: New > > test. > > > > Signed-off-by: Andrew Pinski <quic_apin...@quicinc.com> > > --- > > gcc/config/aarch64/driver-aarch64.cc | 14 ++++++---- > > .../gcc.target/aarch64/cpunative/info_25 | 17 > > ++++++++++++ > > .../gcc.target/aarch64/cpunative/info_26 | 26 > > +++++++++++++++++++ > > .../aarch64/cpunative/native_cpu_25.c | 11 ++++++++ > > .../aarch64/cpunative/native_cpu_26.c | 11 ++++++++ > > 5 files changed, 74 insertions(+), 5 deletions(-) create mode > > 100644 gcc/testsuite/gcc.target/aarch64/cpunative/info_25 > > create mode 100644 > > gcc/testsuite/gcc.target/aarch64/cpunative/info_26 > > create mode 100644 > > gcc/testsuite/gcc.target/aarch64/cpunative/native_cpu_25.c > > create mode 100644 > > gcc/testsuite/gcc.target/aarch64/cpunative/native_cpu_26.c > > > > diff --git a/gcc/config/aarch64/driver-aarch64.cc > > b/gcc/config/aarch64/driver-aarch64.cc > > index b620351e572..abe6e7df7dc 100644 > > --- a/gcc/config/aarch64/driver-aarch64.cc > > +++ b/gcc/config/aarch64/driver-aarch64.cc > > @@ -256,9 +256,9 @@ host_detect_local_cpu (int argc, const > > char **argv) > > bool cpu = false; > > unsigned int i = 0; > > unsigned char imp = INVALID_IMP; > > - unsigned int cores[2] = { INVALID_CORE, INVALID_CORE }; > > + unsigned int cores[3] = { INVALID_CORE, INVALID_CORE, > > INVALID_CORE }; > > unsigned int n_cores = 0; > > - unsigned int variants[2] = { ALL_VARIANTS, ALL_VARIANTS }; > > + unsigned int variants[3] = { ALL_VARIANTS, ALL_VARIANTS, > > ALL_VARIANTS > > + }; > > unsigned int n_variants = 0; > > bool processed_exts = false; > > aarch64_feature_flags extension_flags = 0; @@ -314,7 > > +314,7 @@ host_detect_local_cpu (int argc, const char > > **argv) > > unsigned cvariant = parse_field (buf); > > if (!contains_core_p (variants, cvariant)) > > { > > - if (n_variants == 2) > > + if (n_variants == 3) > > goto not_found; > > > > variants[n_variants++] = cvariant; @@ -326,7 +326,7 > > @@ host_detect_local_cpu (int argc, const char **argv) > > unsigned ccore = parse_field (buf); > > if (!contains_core_p (cores, ccore)) > > { > > - if (n_cores == 2) > > + if (n_cores == 3) > > goto not_found; > > > > cores[n_cores++] = ccore; > > @@ -383,11 +383,15 @@ host_detect_local_cpu (int argc, > > const char **argv) > > /* Weird cpuinfo format that we don't know how to handle. > > */ > > if (n_cores == 0 > > || n_cores > 2 > > - || (n_cores == 1 && n_variants != 1) > > || imp == INVALID_IMP > > || !processed_exts) > > goto not_found; > > > > + /* If we have one core type but multiple variants, consider > > + that as one variant with ALL_VARIANTS instead. */ if > > (n_cores == > > + 1 && n_variants != 1) > > + variants[0] = ALL_VARIANTS; > > + > > /* Simple case, one core type or just looking for the arch. */ > > if (n_cores == 1 || arch) > > { > > diff --git a/gcc/testsuite/gcc.target/aarch64/cpunative/info_25 > > b/gcc/testsuite/gcc.target/aarch64/cpunative/info_25 > > new file mode 100644 > > index 00000000000..d6e83ccab09 > > --- /dev/null > > +++ b/gcc/testsuite/gcc.target/aarch64/cpunative/info_25 > > @@ -0,0 +1,17 @@ > > +processor : 0 > > +BogoMIPS : 38.40 > > +Features : fp asimd evtstrm aes pmull sha1 sha2 crc32 > > atomics fphp asimdhp cpuid asimdrdm jscvt fcma lrcpc dcpop > > sha3 sm3 sm4 asimddp sha512 asimdfhm dit uscat ilrcpc flagm > > ssbs sb paca pacg dcpodp flagm2 frint i8mm bf16 rng bti ecv > > afp rpres > > +CPU implementer : 0x51 > > +CPU architecture: 8 > > +CPU variant : 0x2 > > +CPU part : 0x001 > > +CPU revision : 1 > > + > > +processor : 1 > > +BogoMIPS : 38.40 > > +Features : fp asimd evtstrm aes pmull sha1 sha2 crc32 > > atomics fphp asimdhp cpuid asimdrdm jscvt fcma lrcpc dcpop > > sha3 sm3 sm4 asimddp sha512 asimdfhm dit uscat ilrcpc flagm > > ssbs sb paca pacg dcpodp flagm2 frint i8mm bf16 rng bti ecv > > afp rpres > > +CPU implementer : 0x51 > > +CPU architecture: 8 > > +CPU variant : 0x1 > > +CPU part : 0x001 > > +CPU revision : 1 > > \ No newline at end of file > > diff --git a/gcc/testsuite/gcc.target/aarch64/cpunative/info_26 > > b/gcc/testsuite/gcc.target/aarch64/cpunative/info_26 > > new file mode 100644 > > index 00000000000..7631baf3239 > > --- /dev/null > > +++ b/gcc/testsuite/gcc.target/aarch64/cpunative/info_26 > > @@ -0,0 +1,26 @@ > > +processor : 0 > > +BogoMIPS : 38.40 > > +Features : fp asimd evtstrm aes pmull sha1 sha2 crc32 > > atomics fphp asimdhp cpuid asimdrdm jscvt fcma lrcpc dcpop > > sha3 sm3 sm4 asimddp sha512 asimdfhm dit uscat ilrcpc flagm > > ssbs sb paca pacg dcpodp flagm2 frint i8mm bf16 rng bti ecv > > afp rpres > > +CPU implementer : 0x51 > > +CPU architecture: 8 > > +CPU variant : 0x2 > > +CPU part : 0x001 > > +CPU revision : 1 > > + > > +processor : 1 > > +BogoMIPS : 38.40 > > +Features : fp asimd evtstrm aes pmull sha1 sha2 crc32 > > atomics fphp asimdhp cpuid asimdrdm jscvt fcma lrcpc dcpop > > sha3 sm3 sm4 asimddp sha512 asimdfhm dit uscat ilrcpc flagm > > ssbs sb paca pacg dcpodp flagm2 frint i8mm bf16 rng bti ecv > > afp rpres > > +CPU implementer : 0x51 > > +CPU architecture: 8 > > +CPU variant : 0x1 > > +CPU part : 0x001 > > +CPU revision : 1 > > + > > +processor : 2 > > +BogoMIPS : 38.40 > > +Features : fp asimd evtstrm aes pmull sha1 sha2 crc32 > > atomics fphp asimdhp cpuid asimdrdm jscvt fcma lrcpc dcpop > > sha3 sm3 sm4 asimddp sha512 asimdfhm dit uscat ilrcpc flagm > > ssbs sb paca pacg dcpodp flagm2 frint i8mm bf16 rng bti ecv > > afp rpres > > +CPU implementer : 0x51 > > +CPU architecture: 8 > > +CPU variant : 0x2 > > +CPU part : 0x001 > > +CPU revision : 1 > > \ No newline at end of file > > diff --git > > a/gcc/testsuite/gcc.target/aarch64/cpunative/native_cpu_25.c > > b/gcc/testsuite/gcc.target/aarch64/cpunative/native_cpu_25. > > c > > new file mode 100644 > > index 00000000000..05c88a2edc8 > > --- /dev/null > > +++ > > b/gcc/testsuite/gcc.target/aarch64/cpunative/native_cpu_25. > > c > > @@ -0,0 +1,11 @@ > > +/* { dg-do compile { target { { aarch64*-*-linux*} && native } } > > } */ > > +/* { dg-set-compiler-env-var GCC_CPUINFO > > +"$srcdir/gcc.target/aarch64/cpunative/info_25" } */ > > +/* { dg-additional-options "-mcpu=native --save-temps " } */ > > + > > +int main() > > +{ > > + return 0; > > +} > > + > > +/* { dg-final { scan-assembler {\.arch > > +armv8.6-a\+rng\+sm4\+crc\+aes\+sha3\+fp16} } } */ > > +/* Test that SoC with cores of 2 variants work. */ > > diff --git > > a/gcc/testsuite/gcc.target/aarch64/cpunative/native_cpu_26.c > > b/gcc/testsuite/gcc.target/aarch64/cpunative/native_cpu_26. > > c > > new file mode 100644 > > index 00000000000..4eb943d5204 > > --- /dev/null > > +++ > > b/gcc/testsuite/gcc.target/aarch64/cpunative/native_cpu_26. > > c > > @@ -0,0 +1,11 @@ > > +/* { dg-do compile { target { { aarch64*-*-linux*} && native } } > > } */ > > +/* { dg-set-compiler-env-var GCC_CPUINFO > > +"$srcdir/gcc.target/aarch64/cpunative/info_26" } */ > > +/* { dg-additional-options "-mcpu=native --save-temps " } */ > > + > > +int main() > > +{ > > + return 0; > > +} > > + > > +/* { dg-final { scan-assembler {\.arch > > +armv8.6-a\+rng\+sm4\+crc\+aes\+sha3\+fp16} } } */ > > +/* Test that SoC with cores of 3 variants work. */ > > \ No newline at end of file > > -- > > 2.43.0 >