Skip to content

Conversation

@mshockwave
Copy link
Member

X390 is an in-order core designed for AI/ML workload, with VLEN=1024.
https://www.sifive.com/cores/intelligence-x300-series

Scheduling model will be added in a follow-up patch.

@llvmbot llvmbot added clang Clang issues not falling into any other category backend:RISC-V clang:driver 'clang' and 'clang++' user-facing binaries. Not 'clang-cl' labels Jun 3, 2025
@llvmbot
Copy link
Member

llvmbot commented Jun 3, 2025

@llvm/pr-subscribers-clang-driver
@llvm/pr-subscribers-backend-risc-v

@llvm/pr-subscribers-clang

Author: Min-Yih Hsu (mshockwave)

Changes

X390 is an in-order core designed for AI/ML workload, with VLEN=1024.
https://www.sifive.com/cores/intelligence-x300-series

Scheduling model will be added in a follow-up patch.


Full diff: https://github.com/llvm/llvm-project/pull/142517.diff

5 Files Affected:

  • (added) clang/test/Driver/print-enabled-extensions/riscv-sifive-x390.c (+71)
  • (modified) clang/test/Driver/riscv-cpus.c (+5)
  • (modified) clang/test/Misc/target-invalid-cpu-note/riscv.c (+2)
  • (modified) llvm/docs/ReleaseNotes.md (+1)
  • (modified) llvm/lib/Target/RISCV/RISCVProcessors.td (+49-5)
diff --git a/clang/test/Driver/print-enabled-extensions/riscv-sifive-x390.c b/clang/test/Driver/print-enabled-extensions/riscv-sifive-x390.c
new file mode 100644
index 0000000000000..3dc4d6a6b4fa3
--- /dev/null
+++ b/clang/test/Driver/print-enabled-extensions/riscv-sifive-x390.c
@@ -0,0 +1,71 @@
+// RUN: %clang --target=riscv64 -mcpu=sifive-x390 -menable-experimental-extensions --print-enabled-extensions | FileCheck %s
+// REQUIRES: riscv-registered-target
+
+// CHECK:     Name                 Version   Description
+// CHECK-NEXT:     i                    2.1       'I' (Base Integer Instruction Set)
+// CHECK-NEXT:     m                    2.0       'M' (Integer Multiplication and Division)
+// CHECK-NEXT:     a                    2.1       'A' (Atomic Instructions)
+// CHECK-NEXT:     f                    2.2       'F' (Single-Precision Floating-Point)
+// CHECK-NEXT:     d                    2.2       'D' (Double-Precision Floating-Point)
+// CHECK-NEXT:     c                    2.0       'C' (Compressed Instructions)
+// CHECK-NEXT:     b                    1.0       'B' (the collection of the Zba, Zbb, Zbs extensions)
+// CHECK-NEXT:     v                    1.0       'V' (Vector Extension for Application Processors)
+// CHECK-NEXT:     zic64b               1.0       'Zic64b' (Cache Block Size Is 64 Bytes)
+// CHECK-NEXT:     zicbom               1.0       'Zicbom' (Cache-Block Management Instructions)
+// CHECK-NEXT:     zicbop               1.0       'Zicbop' (Cache-Block Prefetch Instructions)
+// CHECK-NEXT:     zicboz               1.0       'Zicboz' (Cache-Block Zero Instructions)
+// CHECK-NEXT:     ziccamoa             1.0       'Ziccamoa' (Main Memory Supports All Atomics in A)
+// CHECK-NEXT:     ziccif               1.0       'Ziccif' (Main Memory Supports Instruction Fetch with Atomicity Requirement)
+// CHECK-NEXT:     ziccrse              1.0       'Ziccrse' (Main Memory Supports Forward Progress on LR/SC Sequences)
+// CHECK-NEXT:     zicntr               2.0       'Zicntr' (Base Counters and Timers)
+// CHECK-NEXT:     zicond               1.0       'Zicond' (Integer Conditional Operations)
+// CHECK-NEXT:     zicsr                2.0       'Zicsr' (CSRs)
+// CHECK-NEXT:     zifencei             2.0       'Zifencei' (fence.i)
+// CHECK-NEXT:     zihintntl            1.0       'Zihintntl' (Non-Temporal Locality Hints)
+// CHECK-NEXT:     zihintpause          2.0       'Zihintpause' (Pause Hint)
+// CHECK-NEXT:     zihpm                2.0       'Zihpm' (Hardware Performance Counters)
+// CHECK-NEXT:     zimop                1.0       'Zimop' (May-Be-Operations)
+// CHECK-NEXT:     zmmul                1.0       'Zmmul' (Integer Multiplication)
+// CHECK-NEXT:     za64rs               1.0       'Za64rs' (Reservation Set Size of at Most 64 Bytes)
+// CHECK-NEXT:     zaamo                1.0       'Zaamo' (Atomic Memory Operations)
+// CHECK-NEXT:     zalrsc               1.0       'Zalrsc' (Load-Reserved/Store-Conditional)
+// CHECK-NEXT:     zawrs                1.0       'Zawrs' (Wait on Reservation Set)
+// CHECK-NEXT:     zfa                  1.0       'Zfa' (Additional Floating-Point)
+// CHECK-NEXT:     zfbfmin              1.0       'Zfbfmin' (Scalar BF16 Converts)
+// CHECK-NEXT:     zfh                  1.0       'Zfh' (Half-Precision Floating-Point)
+// CHECK-NEXT:     zfhmin               1.0       'Zfhmin' (Half-Precision Floating-Point Minimal)
+// CHECK-NEXT:     zca                  1.0       'Zca' (part of the C extension, excluding compressed floating point loads/stores)
+// CHECK-NEXT:     zcb                  1.0       'Zcb' (Compressed basic bit manipulation instructions)
+// CHECK-NEXT:     zcd                  1.0       'Zcd' (Compressed Double-Precision Floating-Point Instructions)
+// CHECK-NEXT:     zcmop                1.0       'Zcmop' (Compressed May-Be-Operations)
+// CHECK-NEXT:     zba                  1.0       'Zba' (Address Generation Instructions)
+// CHECK-NEXT:     zbb                  1.0       'Zbb' (Basic Bit-Manipulation)
+// CHECK-NEXT:     zbs                  1.0       'Zbs' (Single-Bit Instructions)
+// CHECK-NEXT:     zkr                  1.0       'Zkr' (Entropy Source Extension)
+// CHECK-NEXT:     zkt                  1.0       'Zkt' (Data Independent Execution Latency)
+// CHECK-NEXT:     zvbb                 1.0       'Zvbb' (Vector basic bit-manipulation instructions)
+// CHECK-NEXT:     zve32f               1.0       'Zve32f' (Vector Extensions for Embedded Processors with maximal 32 EEW and F extension)
+// CHECK-NEXT:     zve32x               1.0       'Zve32x' (Vector Extensions for Embedded Processors with maximal 32 EEW)
+// CHECK-NEXT:     zve64d               1.0       'Zve64d' (Vector Extensions for Embedded Processors with maximal 64 EEW, F and D extension)
+// CHECK-NEXT:     zve64f               1.0       'Zve64f' (Vector Extensions for Embedded Processors with maximal 64 EEW and F extension)
+// CHECK-NEXT:     zve64x               1.0       'Zve64x' (Vector Extensions for Embedded Processors with maximal 64 EEW)
+// CHECK-NEXT:     zvfbfmin             1.0       'Zvfbfmin' (Vector BF16 Converts)
+// CHECK-NEXT:     zvfbfwma             1.0       'Zvfbfwma' (Vector BF16 widening mul-add)
+// CHECK-NEXT:     zvfh                 1.0       'Zvfh' (Vector Half-Precision Floating-Point)
+// CHECK-NEXT:     zvfhmin              1.0       'Zvfhmin' (Vector Half-Precision Floating-Point Minimal)
+// CHECK-NEXT:     zvkb                 1.0       'Zvkb' (Vector Bit-manipulation used in Cryptography)
+// CHECK-NEXT:     zvkt                 1.0       'Zvkt' (Vector Data-Independent Execution Latency)
+// CHECK-NEXT:     zvl1024b             1.0       'Zvl1024b' (Minimum Vector Length 1024)
+// CHECK-NEXT:     zvl128b              1.0       'Zvl128b' (Minimum Vector Length 128)
+// CHECK-NEXT:     zvl256b              1.0       'Zvl256b' (Minimum Vector Length 256)
+// CHECK-NEXT:     zvl32b               1.0       'Zvl32b' (Minimum Vector Length 32)
+// CHECK-NEXT:     zvl512b              1.0       'Zvl512b' (Minimum Vector Length 512)
+// CHECK-NEXT:     zvl64b               1.0       'Zvl64b' (Minimum Vector Length 64)
+// CHECK-NEXT:     xsifivecdiscarddlone 1.0       'XSiFivecdiscarddlone' (SiFive sf.cdiscard.d.l1 Instruction)
+// CHECK-NEXT:     xsifivecflushdlone   1.0       'XSiFivecflushdlone' (SiFive sf.cflush.d.l1 Instruction)
+// CHECK-EMPTY:
+// CHECK-NEXT: Experimental extensions
+// CHECK-NEXT:     zicfilp              1.0       'Zicfilp' (Landing pad)
+// CHECK-NEXT:     zicfiss              1.0       'Zicfiss' (Shadow stack)
+// CHECK-EMPTY:
+// CHECK-NEXT: ISA String: rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_b1p0_v1p0_zic64b1p0_zicbom1p0_zicbop1p0_zicboz1p0_ziccamoa1p0_ziccif1p0_ziccrse1p0_zicfilp1p0_zicfiss1p0_zicntr2p0_zicond1p0_zicsr2p0_zifencei2p0_zihintntl1p0_zihintpause2p0_zihpm2p0_zimop1p0_zmmul1p0_za64rs1p0_zaamo1p0_zalrsc1p0_zawrs1p0_zfa1p0_zfbfmin1p0_zfh1p0_zfhmin1p0_zca1p0_zcb1p0_zcd1p0_zcmop1p0_zba1p0_zbb1p0_zbs1p0_zkr1p0_zkt1p0_zvbb1p0_zve32f1p0_zve32x1p0_zve64d1p0_zve64f1p0_zve64x1p0_zvfbfmin1p0_zvfbfwma1p0_zvfh1p0_zvfhmin1p0_zvkb1p0_zvkt1p0_zvl1024b1p0_zvl128b1p0_zvl256b1p0_zvl32b1p0_zvl512b1p0_zvl64b1p0_xsifivecdiscarddlone1p0_xsifivecflushdlone1p0
diff --git a/clang/test/Driver/riscv-cpus.c b/clang/test/Driver/riscv-cpus.c
index 9b29ea2d76c71..7605a3056d430 100644
--- a/clang/test/Driver/riscv-cpus.c
+++ b/clang/test/Driver/riscv-cpus.c
@@ -429,6 +429,11 @@
 // MCPU-SIFIVE-X280-SAME: "-target-feature" "+zvl512b" "-target-feature" "+zvl64b"
 // MCPU-SIFIVE-X280-SAME: "-target-abi" "lp64d"
 
+// RUN: %clang -target riscv64 -### -c %s 2>&1 -menable-experimental-extensions -mcpu=sifive-x390 | FileCheck -check-prefix=MCPU-SIFIVE-X390 %s
+// MCPU-SIFIVE-X390: "-target-cpu" "sifive-x390"
+// COM: The list of extensions are tested in `test/Driver/print-enabled-extensions/riscv-sifive-x390.c`
+// MCPU-SIFIVE-X390-SAME: "-target-abi" "lp64d"
+
 // RUN: %clang -target riscv64 -### -c %s 2>&1 -mcpu=sifive-p450 | FileCheck -check-prefix=MCPU-SIFIVE-P450 %s
 // MCPU-SIFIVE-P450: "-nostdsysteminc" "-target-cpu" "sifive-p450"
 // MCPU-SIFIVE-P450-SAME: "-target-feature" "+m"
diff --git a/clang/test/Misc/target-invalid-cpu-note/riscv.c b/clang/test/Misc/target-invalid-cpu-note/riscv.c
index c57bde8aa531a..66952755e9159 100644
--- a/clang/test/Misc/target-invalid-cpu-note/riscv.c
+++ b/clang/test/Misc/target-invalid-cpu-note/riscv.c
@@ -45,6 +45,7 @@
 // RISCV64-SAME: {{^}}, sifive-u54
 // RISCV64-SAME: {{^}}, sifive-u74
 // RISCV64-SAME: {{^}}, sifive-x280
+// RISCV64-SAME: {{^}}, sifive-x390
 // RISCV64-SAME: {{^}}, spacemit-x60
 // RISCV64-SAME: {{^}}, syntacore-scr3-rv64
 // RISCV64-SAME: {{^}}, syntacore-scr4-rv64
@@ -103,6 +104,7 @@
 // TUNE-RISCV64-SAME: {{^}}, sifive-u54
 // TUNE-RISCV64-SAME: {{^}}, sifive-u74
 // TUNE-RISCV64-SAME: {{^}}, sifive-x280
+// TUNE-RISCV64-SAME: {{^}}, sifive-x390
 // TUNE-RISCV64-SAME: {{^}}, spacemit-x60
 // TUNE-RISCV64-SAME: {{^}}, syntacore-scr3-rv64
 // TUNE-RISCV64-SAME: {{^}}, syntacore-scr4-rv64
diff --git a/llvm/docs/ReleaseNotes.md b/llvm/docs/ReleaseNotes.md
index 10efc889fcc7f..ab9c482c56b31 100644
--- a/llvm/docs/ReleaseNotes.md
+++ b/llvm/docs/ReleaseNotes.md
@@ -202,6 +202,7 @@ Changes to the RISC-V Backend
   Extensions.
 * `-mcpu=andes-a25` and `-mcpu=andes-ax25` were added.
 * The `Shlcofideleg` extension was added.
+* `-mcpu=sifive-x390` was added.
 
 Changes to the WebAssembly Backend
 ----------------------------------
diff --git a/llvm/lib/Target/RISCV/RISCVProcessors.td b/llvm/lib/Target/RISCV/RISCVProcessors.td
index dc0ae384d6b08..41d818f7d0fcd 100644
--- a/llvm/lib/Target/RISCV/RISCVProcessors.td
+++ b/llvm/lib/Target/RISCV/RISCVProcessors.td
@@ -271,10 +271,10 @@ def SIFIVE_U74 : RISCVProcessorModel<"sifive-u74",
                                       FeatureStdExtC],
                                      SiFive7TuneFeatures>;
 
-defvar SiFiveX280TuneFeatures = !listconcat(SiFive7TuneFeatures,
-                                            [TuneDLenFactor2,
-                                             TuneOptimizedZeroStrideLoad,
-                                             TuneOptimizedNF2SegmentLoadStore]);
+defvar SiFiveIntelligenceTuneFeatures = !listconcat(SiFive7TuneFeatures,
+                                                    [TuneDLenFactor2,
+                                                     TuneOptimizedZeroStrideLoad,
+                                                     TuneOptimizedNF2SegmentLoadStore]);
 def SIFIVE_X280 : RISCVProcessorModel<"sifive-x280", SiFive7Model,
                                       [Feature64Bit,
                                        FeatureStdExtI,
@@ -290,7 +290,51 @@ def SIFIVE_X280 : RISCVProcessorModel<"sifive-x280", SiFive7Model,
                                        FeatureStdExtZvfh,
                                        FeatureStdExtZba,
                                        FeatureStdExtZbb],
-                                      SiFiveX280TuneFeatures>;
+                                      SiFiveIntelligenceTuneFeatures>;
+
+def SIFIVE_X390 : RISCVProcessorModel<"sifive-x390", NoSchedModel,
+                                      [Feature64Bit,
+                                       FeatureStdExtI,
+                                       FeatureStdExtM,
+                                       FeatureStdExtA,
+                                       FeatureStdExtF,
+                                       FeatureStdExtD,
+                                       FeatureStdExtC,
+                                       FeatureStdExtB,
+                                       FeatureStdExtV,
+                                       FeatureStdExtZic64b,
+                                       FeatureStdExtZicbom,
+                                       FeatureStdExtZicbop,
+                                       FeatureStdExtZicboz,
+                                       FeatureStdExtZiccamoa,
+                                       FeatureStdExtZiccif,
+                                       FeatureStdExtZiccrse,
+                                       FeatureStdExtZicfilp,
+                                       FeatureStdExtZicfiss,
+                                       FeatureStdExtZicntr,
+                                       FeatureStdExtZicond,
+                                       FeatureStdExtZifencei,
+                                       FeatureStdExtZihintntl,
+                                       FeatureStdExtZihintpause,
+                                       FeatureStdExtZihpm,
+                                       FeatureStdExtZimop,
+                                       FeatureStdExtZa64rs,
+                                       FeatureStdExtZawrs,
+                                       FeatureStdExtZfa,
+                                       FeatureStdExtZfh,
+                                       FeatureStdExtZcb,
+                                       FeatureStdExtZcmop,
+                                       FeatureStdExtZkr,
+                                       FeatureStdExtZkt,
+                                       FeatureStdExtZvbb,
+                                       FeatureStdExtZvfbfmin,
+                                       FeatureStdExtZvfbfwma,
+                                       FeatureStdExtZvfh,
+                                       FeatureStdExtZvkt,
+                                       FeatureStdExtZvl1024b,
+                                       FeatureVendorXSiFivecdiscarddlone,
+                                       FeatureVendorXSiFivecflushdlone],
+                                      SiFiveIntelligenceTuneFeatures>;
 
 defvar SiFiveP400TuneFeatures = [TuneNoDefaultUnroll,
                                  TuneConditionalCompressedMoveFusion,

SiFiveIntelligenceTuneFeatures>;

def SIFIVE_X390 : RISCVProcessorModel<"sifive-x390", NoSchedModel,
[Feature64Bit,
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is X390 RVA23-compatible? It seems to be at the first glance.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Unfortunately it lacks Zicclsm (misaligned load/store), which is part of RVA20U64 and subsequent profiles.

@lenary
Copy link
Member

lenary commented Jun 3, 2025

I'm happy with this in that the test coverage looks adequate to me. I cannot really verify that the list of extensions are correct, but they look reasonable enough.

Copy link
Contributor

@tclin914 tclin914 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

Copy link
Collaborator

@topperc topperc left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@mshockwave mshockwave merged commit feb21e2 into llvm:main Jun 4, 2025
14 of 16 checks passed
@mshockwave mshockwave deleted the patch/riscv/sifive-x390 branch June 4, 2025 16:26
@llvm-ci
Copy link
Collaborator

llvm-ci commented Jun 4, 2025

LLVM Buildbot has detected a new failure on builder arc-builder running on arc-worker while building clang,llvm at step 6 "test-build-unified-tree-check-all".

Full details are available at: https://lab.llvm.org/buildbot/#/builders/3/builds/17001

Here is the relevant piece of the build log for the reference
Step 6 (test-build-unified-tree-check-all) failure: test (failure)
******************** TEST 'Clang :: Driver/riscv-cpus.c' FAILED ********************
Exit Code: 1

Command Output (stderr):
--
/buildbot/worker/arc-folder/build/bin/clang --target=riscv32 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c 2>&1 -mcpu=rocket-rv32 | /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MCPU-ROCKET32 /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c # RUN: at line 3
+ /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MCPU-ROCKET32 /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c
+ /buildbot/worker/arc-folder/build/bin/clang --target=riscv32 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c -mcpu=rocket-rv32
/buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c 2>&1 -mcpu=rocket-rv64 | /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MCPU-ROCKET64 /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c # RUN: at line 7
+ /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MCPU-ROCKET64 /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c
+ /buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c -mcpu=rocket-rv64
/buildbot/worker/arc-folder/build/bin/clang --target=riscv32 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c 2>&1 -mcpu=syntacore-scr1-base | /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MCPU-SYNTACORE-SCR1-BASE /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c # RUN: at line 11
+ /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MCPU-SYNTACORE-SCR1-BASE /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c
+ /buildbot/worker/arc-folder/build/bin/clang --target=riscv32 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c -mcpu=syntacore-scr1-base
/buildbot/worker/arc-folder/build/bin/clang --target=riscv32 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c 2>&1 -mcpu=syntacore-scr1-max | /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MCPU-SYNTACORE-SCR1-MAX /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c # RUN: at line 17
+ /buildbot/worker/arc-folder/build/bin/clang --target=riscv32 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c -mcpu=syntacore-scr1-max
+ /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MCPU-SYNTACORE-SCR1-MAX /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c
/buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c 2>&1 -mcpu=xiangshan-nanhu | /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MCPU-XIANGSHAN-NANHU /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c # RUN: at line 23
+ /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MCPU-XIANGSHAN-NANHU /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c
+ /buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c -mcpu=xiangshan-nanhu
/buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c 2>&1 -mcpu=xiangshan-kunminghu | /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MCPU-XIANGSHAN-KUNMINGHU /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c # RUN: at line 34
+ /buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c -mcpu=xiangshan-kunminghu
+ /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MCPU-XIANGSHAN-KUNMINGHU /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c
/buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c 2>&1 -mcpu=spacemit-x60 | /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MCPU-SPACEMIT-X60 /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c # RUN: at line 106
+ /buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c -mcpu=spacemit-x60
+ /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MCPU-SPACEMIT-X60 /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c
/buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c -mcpu=native 2> /buildbot/worker/arc-folder/build/tools/clang/test/Driver/Output/riscv-cpus.c.tmp.err || true # RUN: at line 163
+ /buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c -mcpu=native
+ true
/buildbot/worker/arc-folder/build/bin/FileCheck --input-file=/buildbot/worker/arc-folder/build/tools/clang/test/Driver/Output/riscv-cpus.c.tmp.err -check-prefix=MCPU-NATIVE /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c # RUN: at line 164
+ /buildbot/worker/arc-folder/build/bin/FileCheck --input-file=/buildbot/worker/arc-folder/build/tools/clang/test/Driver/Output/riscv-cpus.c.tmp.err -check-prefix=MCPU-NATIVE /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c
/buildbot/worker/arc-folder/build/bin/clang --target=riscv32 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c 2>&1 -mtune=rocket-rv32 | /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MTUNE-ROCKET32 /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c # RUN: at line 167
+ /buildbot/worker/arc-folder/build/bin/clang --target=riscv32 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c -mtune=rocket-rv32
+ /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MTUNE-ROCKET32 /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c
/buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c 2>&1 -mtune=rocket-rv64 | /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MTUNE-ROCKET64 /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c # RUN: at line 170
+ /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MTUNE-ROCKET64 /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c
+ /buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c -mtune=rocket-rv64
/buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c 2>&1 -mtune=mips-p8700 | /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MTUNE-MIPS-P8700 /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c # RUN: at line 173
+ /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MTUNE-MIPS-P8700 /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c
+ /buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c -mtune=mips-p8700
/buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c 2>&1 -mcpu=mips-p8700 | /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MCPU-MIPS-P8700 /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c # RUN: at line 176
+ /buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c -mcpu=mips-p8700
+ /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MCPU-MIPS-P8700 /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c
/buildbot/worker/arc-folder/build/bin/clang --target=riscv32 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c 2>&1 -mtune=syntacore-scr1-base | /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MTUNE-SYNTACORE-SCR1-BASE /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c # RUN: at line 190
+ /buildbot/worker/arc-folder/build/bin/clang --target=riscv32 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c -mtune=syntacore-scr1-base
+ /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MTUNE-SYNTACORE-SCR1-BASE /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c
/buildbot/worker/arc-folder/build/bin/clang --target=riscv32 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c 2>&1 -mtune=syntacore-scr1-max | /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MTUNE-SYNTACORE-SCR1-MAX /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c # RUN: at line 193
+ /buildbot/worker/arc-folder/build/bin/clang --target=riscv32 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c -mtune=syntacore-scr1-max
+ /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MTUNE-SYNTACORE-SCR1-MAX /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c
/buildbot/worker/arc-folder/build/bin/clang --target=riscv64 -### -c /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c 2>&1 -mtune=tt-ascalon-d8 | /buildbot/worker/arc-folder/build/bin/FileCheck -check-prefix=MTUNE-TT-ASCALON-D8 /buildbot/worker/arc-folder/llvm-project/clang/test/Driver/riscv-cpus.c # RUN: at line 196
...

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

backend:RISC-V clang:driver 'clang' and 'clang++' user-facing binaries. Not 'clang-cl' clang Clang issues not falling into any other category

Projects

None yet

Development

Successfully merging this pull request may close these issues.

7 participants