Skip to content

Commit feb21e2

Browse files
authored
[RISCV] Add SiFive X390 processor definition (#142517)
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.
1 parent 4b23d4c commit feb21e2

File tree

5 files changed

+128
-5
lines changed

5 files changed

+128
-5
lines changed
Lines changed: 71 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,71 @@
1+
// RUN: %clang --target=riscv64 -mcpu=sifive-x390 -menable-experimental-extensions --print-enabled-extensions | FileCheck %s
2+
// REQUIRES: riscv-registered-target
3+
4+
// CHECK: Name Version Description
5+
// CHECK-NEXT: i 2.1 'I' (Base Integer Instruction Set)
6+
// CHECK-NEXT: m 2.0 'M' (Integer Multiplication and Division)
7+
// CHECK-NEXT: a 2.1 'A' (Atomic Instructions)
8+
// CHECK-NEXT: f 2.2 'F' (Single-Precision Floating-Point)
9+
// CHECK-NEXT: d 2.2 'D' (Double-Precision Floating-Point)
10+
// CHECK-NEXT: c 2.0 'C' (Compressed Instructions)
11+
// CHECK-NEXT: b 1.0 'B' (the collection of the Zba, Zbb, Zbs extensions)
12+
// CHECK-NEXT: v 1.0 'V' (Vector Extension for Application Processors)
13+
// CHECK-NEXT: zic64b 1.0 'Zic64b' (Cache Block Size Is 64 Bytes)
14+
// CHECK-NEXT: zicbom 1.0 'Zicbom' (Cache-Block Management Instructions)
15+
// CHECK-NEXT: zicbop 1.0 'Zicbop' (Cache-Block Prefetch Instructions)
16+
// CHECK-NEXT: zicboz 1.0 'Zicboz' (Cache-Block Zero Instructions)
17+
// CHECK-NEXT: ziccamoa 1.0 'Ziccamoa' (Main Memory Supports All Atomics in A)
18+
// CHECK-NEXT: ziccif 1.0 'Ziccif' (Main Memory Supports Instruction Fetch with Atomicity Requirement)
19+
// CHECK-NEXT: ziccrse 1.0 'Ziccrse' (Main Memory Supports Forward Progress on LR/SC Sequences)
20+
// CHECK-NEXT: zicntr 2.0 'Zicntr' (Base Counters and Timers)
21+
// CHECK-NEXT: zicond 1.0 'Zicond' (Integer Conditional Operations)
22+
// CHECK-NEXT: zicsr 2.0 'Zicsr' (CSRs)
23+
// CHECK-NEXT: zifencei 2.0 'Zifencei' (fence.i)
24+
// CHECK-NEXT: zihintntl 1.0 'Zihintntl' (Non-Temporal Locality Hints)
25+
// CHECK-NEXT: zihintpause 2.0 'Zihintpause' (Pause Hint)
26+
// CHECK-NEXT: zihpm 2.0 'Zihpm' (Hardware Performance Counters)
27+
// CHECK-NEXT: zimop 1.0 'Zimop' (May-Be-Operations)
28+
// CHECK-NEXT: zmmul 1.0 'Zmmul' (Integer Multiplication)
29+
// CHECK-NEXT: za64rs 1.0 'Za64rs' (Reservation Set Size of at Most 64 Bytes)
30+
// CHECK-NEXT: zaamo 1.0 'Zaamo' (Atomic Memory Operations)
31+
// CHECK-NEXT: zalrsc 1.0 'Zalrsc' (Load-Reserved/Store-Conditional)
32+
// CHECK-NEXT: zawrs 1.0 'Zawrs' (Wait on Reservation Set)
33+
// CHECK-NEXT: zfa 1.0 'Zfa' (Additional Floating-Point)
34+
// CHECK-NEXT: zfbfmin 1.0 'Zfbfmin' (Scalar BF16 Converts)
35+
// CHECK-NEXT: zfh 1.0 'Zfh' (Half-Precision Floating-Point)
36+
// CHECK-NEXT: zfhmin 1.0 'Zfhmin' (Half-Precision Floating-Point Minimal)
37+
// CHECK-NEXT: zca 1.0 'Zca' (part of the C extension, excluding compressed floating point loads/stores)
38+
// CHECK-NEXT: zcb 1.0 'Zcb' (Compressed basic bit manipulation instructions)
39+
// CHECK-NEXT: zcd 1.0 'Zcd' (Compressed Double-Precision Floating-Point Instructions)
40+
// CHECK-NEXT: zcmop 1.0 'Zcmop' (Compressed May-Be-Operations)
41+
// CHECK-NEXT: zba 1.0 'Zba' (Address Generation Instructions)
42+
// CHECK-NEXT: zbb 1.0 'Zbb' (Basic Bit-Manipulation)
43+
// CHECK-NEXT: zbs 1.0 'Zbs' (Single-Bit Instructions)
44+
// CHECK-NEXT: zkr 1.0 'Zkr' (Entropy Source Extension)
45+
// CHECK-NEXT: zkt 1.0 'Zkt' (Data Independent Execution Latency)
46+
// CHECK-NEXT: zvbb 1.0 'Zvbb' (Vector basic bit-manipulation instructions)
47+
// CHECK-NEXT: zve32f 1.0 'Zve32f' (Vector Extensions for Embedded Processors with maximal 32 EEW and F extension)
48+
// CHECK-NEXT: zve32x 1.0 'Zve32x' (Vector Extensions for Embedded Processors with maximal 32 EEW)
49+
// CHECK-NEXT: zve64d 1.0 'Zve64d' (Vector Extensions for Embedded Processors with maximal 64 EEW, F and D extension)
50+
// CHECK-NEXT: zve64f 1.0 'Zve64f' (Vector Extensions for Embedded Processors with maximal 64 EEW and F extension)
51+
// CHECK-NEXT: zve64x 1.0 'Zve64x' (Vector Extensions for Embedded Processors with maximal 64 EEW)
52+
// CHECK-NEXT: zvfbfmin 1.0 'Zvfbfmin' (Vector BF16 Converts)
53+
// CHECK-NEXT: zvfbfwma 1.0 'Zvfbfwma' (Vector BF16 widening mul-add)
54+
// CHECK-NEXT: zvfh 1.0 'Zvfh' (Vector Half-Precision Floating-Point)
55+
// CHECK-NEXT: zvfhmin 1.0 'Zvfhmin' (Vector Half-Precision Floating-Point Minimal)
56+
// CHECK-NEXT: zvkb 1.0 'Zvkb' (Vector Bit-manipulation used in Cryptography)
57+
// CHECK-NEXT: zvkt 1.0 'Zvkt' (Vector Data-Independent Execution Latency)
58+
// CHECK-NEXT: zvl1024b 1.0 'Zvl1024b' (Minimum Vector Length 1024)
59+
// CHECK-NEXT: zvl128b 1.0 'Zvl128b' (Minimum Vector Length 128)
60+
// CHECK-NEXT: zvl256b 1.0 'Zvl256b' (Minimum Vector Length 256)
61+
// CHECK-NEXT: zvl32b 1.0 'Zvl32b' (Minimum Vector Length 32)
62+
// CHECK-NEXT: zvl512b 1.0 'Zvl512b' (Minimum Vector Length 512)
63+
// CHECK-NEXT: zvl64b 1.0 'Zvl64b' (Minimum Vector Length 64)
64+
// CHECK-NEXT: xsifivecdiscarddlone 1.0 'XSiFivecdiscarddlone' (SiFive sf.cdiscard.d.l1 Instruction)
65+
// CHECK-NEXT: xsifivecflushdlone 1.0 'XSiFivecflushdlone' (SiFive sf.cflush.d.l1 Instruction)
66+
// CHECK-EMPTY:
67+
// CHECK-NEXT: Experimental extensions
68+
// CHECK-NEXT: zicfilp 1.0 'Zicfilp' (Landing pad)
69+
// CHECK-NEXT: zicfiss 1.0 'Zicfiss' (Shadow stack)
70+
// CHECK-EMPTY:
71+
// 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

clang/test/Driver/riscv-cpus.c

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -429,6 +429,11 @@
429429
// MCPU-SIFIVE-X280-SAME: "-target-feature" "+zvl512b" "-target-feature" "+zvl64b"
430430
// MCPU-SIFIVE-X280-SAME: "-target-abi" "lp64d"
431431

432+
// RUN: %clang -target riscv64 -### -c %s 2>&1 -menable-experimental-extensions -mcpu=sifive-x390 | FileCheck -check-prefix=MCPU-SIFIVE-X390 %s
433+
// MCPU-SIFIVE-X390: "-target-cpu" "sifive-x390"
434+
// COM: The list of extensions are tested in `test/Driver/print-enabled-extensions/riscv-sifive-x390.c`
435+
// MCPU-SIFIVE-X390-SAME: "-target-abi" "lp64d"
436+
432437
// RUN: %clang -target riscv64 -### -c %s 2>&1 -mcpu=sifive-p450 | FileCheck -check-prefix=MCPU-SIFIVE-P450 %s
433438
// MCPU-SIFIVE-P450: "-nostdsysteminc" "-target-cpu" "sifive-p450"
434439
// MCPU-SIFIVE-P450-SAME: "-target-feature" "+m"

clang/test/Misc/target-invalid-cpu-note/riscv.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -45,6 +45,7 @@
4545
// RISCV64-SAME: {{^}}, sifive-u54
4646
// RISCV64-SAME: {{^}}, sifive-u74
4747
// RISCV64-SAME: {{^}}, sifive-x280
48+
// RISCV64-SAME: {{^}}, sifive-x390
4849
// RISCV64-SAME: {{^}}, spacemit-x60
4950
// RISCV64-SAME: {{^}}, syntacore-scr3-rv64
5051
// RISCV64-SAME: {{^}}, syntacore-scr4-rv64
@@ -103,6 +104,7 @@
103104
// TUNE-RISCV64-SAME: {{^}}, sifive-u54
104105
// TUNE-RISCV64-SAME: {{^}}, sifive-u74
105106
// TUNE-RISCV64-SAME: {{^}}, sifive-x280
107+
// TUNE-RISCV64-SAME: {{^}}, sifive-x390
106108
// TUNE-RISCV64-SAME: {{^}}, spacemit-x60
107109
// TUNE-RISCV64-SAME: {{^}}, syntacore-scr3-rv64
108110
// TUNE-RISCV64-SAME: {{^}}, syntacore-scr4-rv64

llvm/docs/ReleaseNotes.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -208,6 +208,7 @@ Changes to the RISC-V Backend
208208
Extensions.
209209
* `-mcpu=andes-a25` and `-mcpu=andes-ax25` were added.
210210
* The `Shlcofideleg` extension was added.
211+
* `-mcpu=sifive-x390` was added.
211212

212213
Changes to the WebAssembly Backend
213214
----------------------------------

llvm/lib/Target/RISCV/RISCVProcessors.td

Lines changed: 49 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -271,10 +271,10 @@ def SIFIVE_U74 : RISCVProcessorModel<"sifive-u74",
271271
FeatureStdExtC],
272272
SiFive7TuneFeatures>;
273273

274-
defvar SiFiveX280TuneFeatures = !listconcat(SiFive7TuneFeatures,
275-
[TuneDLenFactor2,
276-
TuneOptimizedZeroStrideLoad,
277-
TuneOptimizedNF2SegmentLoadStore]);
274+
defvar SiFiveIntelligenceTuneFeatures = !listconcat(SiFive7TuneFeatures,
275+
[TuneDLenFactor2,
276+
TuneOptimizedZeroStrideLoad,
277+
TuneOptimizedNF2SegmentLoadStore]);
278278
def SIFIVE_X280 : RISCVProcessorModel<"sifive-x280", SiFive7Model,
279279
[Feature64Bit,
280280
FeatureStdExtI,
@@ -290,7 +290,51 @@ def SIFIVE_X280 : RISCVProcessorModel<"sifive-x280", SiFive7Model,
290290
FeatureStdExtZvfh,
291291
FeatureStdExtZba,
292292
FeatureStdExtZbb],
293-
SiFiveX280TuneFeatures>;
293+
SiFiveIntelligenceTuneFeatures>;
294+
295+
def SIFIVE_X390 : RISCVProcessorModel<"sifive-x390", NoSchedModel,
296+
[Feature64Bit,
297+
FeatureStdExtI,
298+
FeatureStdExtM,
299+
FeatureStdExtA,
300+
FeatureStdExtF,
301+
FeatureStdExtD,
302+
FeatureStdExtC,
303+
FeatureStdExtB,
304+
FeatureStdExtV,
305+
FeatureStdExtZic64b,
306+
FeatureStdExtZicbom,
307+
FeatureStdExtZicbop,
308+
FeatureStdExtZicboz,
309+
FeatureStdExtZiccamoa,
310+
FeatureStdExtZiccif,
311+
FeatureStdExtZiccrse,
312+
FeatureStdExtZicfilp,
313+
FeatureStdExtZicfiss,
314+
FeatureStdExtZicntr,
315+
FeatureStdExtZicond,
316+
FeatureStdExtZifencei,
317+
FeatureStdExtZihintntl,
318+
FeatureStdExtZihintpause,
319+
FeatureStdExtZihpm,
320+
FeatureStdExtZimop,
321+
FeatureStdExtZa64rs,
322+
FeatureStdExtZawrs,
323+
FeatureStdExtZfa,
324+
FeatureStdExtZfh,
325+
FeatureStdExtZcb,
326+
FeatureStdExtZcmop,
327+
FeatureStdExtZkr,
328+
FeatureStdExtZkt,
329+
FeatureStdExtZvbb,
330+
FeatureStdExtZvfbfmin,
331+
FeatureStdExtZvfbfwma,
332+
FeatureStdExtZvfh,
333+
FeatureStdExtZvkt,
334+
FeatureStdExtZvl1024b,
335+
FeatureVendorXSiFivecdiscarddlone,
336+
FeatureVendorXSiFivecflushdlone],
337+
SiFiveIntelligenceTuneFeatures>;
294338

295339
defvar SiFiveP400TuneFeatures = [TuneNoDefaultUnroll,
296340
TuneConditionalCompressedMoveFusion,

0 commit comments

Comments
 (0)