Skip to content

Commit 4c43379

Browse files
asi-scdnpetrov-scaaa-sc
committed
[RISCV] Add Syntacore SCR5 RV32/64 processors definition
Syntacore SCR5 is an entry-level Linux-capable 32/64-bit RISC-V processor core. Overview: https://syntacore.com/products/scr5 Co-authored-by: Dmitrii Petrov <[email protected]> Co-authored-by: Anton Afanasyev <[email protected]>
1 parent 199c400 commit 4c43379

File tree

4 files changed

+59
-5
lines changed

4 files changed

+59
-5
lines changed

clang/test/Driver/riscv-cpus.c

Lines changed: 28 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -408,3 +408,31 @@
408408

409409
// RUN: %clang --target=riscv64 -### -c %s 2>&1 -mtune=syntacore-scr4-rv64 | FileCheck -check-prefix=MTUNE-SYNTACORE-SCR4-RV64 %s
410410
// MTUNE-SYNTACORE-SCR4-RV64: "-tune-cpu" "syntacore-scr4-rv64"
411+
412+
// RUN: %clang --target=riscv32 -### -c %s 2>&1 -mcpu=syntacore-scr5-rv32 | FileCheck -check-prefix=MCPU-SYNTACORE-SCR5-RV32 %s
413+
// MCPU-SYNTACORE-SCR5-RV32: "-target-cpu" "syntacore-scr5-rv32"
414+
// MCPU-SYNTACORE-SCR5-RV32-SAME: "-target-feature" "+m"
415+
// MCPU-SYNTACORE-SCR5-RV32-SAME: "-target-feature" "+a"
416+
// MCPU-SYNTACORE-SCR5-RV32-SAME: "-target-feature" "+f"
417+
// MCPU-SYNTACORE-SCR5-RV32-SAME: "-target-feature" "+d"
418+
// MCPU-SYNTACORE-SCR5-RV32-SAME: "-target-feature" "+c"
419+
// MCPU-SYNTACORE-SCR5-RV32-SAME: "-target-feature" "+zicsr"
420+
// MCPU-SYNTACORE-SCR5-RV32-SAME: "-target-feature" "+zifencei"
421+
// MCPU-SYNTACORE-SCR5-RV32-SAME: "-target-abi" "ilp32d"
422+
423+
// RUN: %clang --target=riscv32 -### -c %s 2>&1 -mtune=syntacore-scr5-rv32 | FileCheck -check-prefix=MTUNE-SYNTACORE-SCR5-RV32 %s
424+
// MTUNE-SYNTACORE-SCR5-RV32: "-tune-cpu" "syntacore-scr5-rv32"
425+
426+
// RUN: %clang --target=riscv64 -### -c %s 2>&1 -mcpu=syntacore-scr5-rv64 | FileCheck -check-prefix=MCPU-SYNTACORE-SCR5-RV64 %s
427+
// MCPU-SYNTACORE-SCR5-RV64: "-target-cpu" "syntacore-scr5-rv64"
428+
// MCPU-SYNTACORE-SCR5-RV64-SAME: "-target-feature" "+m"
429+
// MCPU-SYNTACORE-SCR5-RV64-SAME: "-target-feature" "+a"
430+
// MCPU-SYNTACORE-SCR5-RV64-SAME: "-target-feature" "+f"
431+
// MCPU-SYNTACORE-SCR5-RV64-SAME: "-target-feature" "+d"
432+
// MCPU-SYNTACORE-SCR5-RV64-SAME: "-target-feature" "+c"
433+
// MCPU-SYNTACORE-SCR5-RV64-SAME: "-target-feature" "+zicsr"
434+
// MCPU-SYNTACORE-SCR5-RV64-SAME: "-target-feature" "+zifencei"
435+
// MCPU-SYNTACORE-SCR5-RV64-SAME: "-target-abi" "lp64d"
436+
437+
// RUN: %clang --target=riscv64 -### -c %s 2>&1 -mtune=syntacore-scr5-rv64 | FileCheck -check-prefix=MTUNE-SYNTACORE-SCR5-RV64 %s
438+
// MTUNE-SYNTACORE-SCR5-RV64: "-tune-cpu" "syntacore-scr5-rv64"

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

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -81,16 +81,16 @@
8181

8282
// RUN: not %clang_cc1 -triple riscv32 -target-cpu not-a-cpu -fsyntax-only %s 2>&1 | FileCheck %s --check-prefix RISCV32
8383
// RISCV32: error: unknown target CPU 'not-a-cpu'
84-
// RISCV32-NEXT: note: valid target CPU values are: generic-rv32, rocket-rv32, sifive-e20, sifive-e21, sifive-e24, sifive-e31, sifive-e34, sifive-e76, syntacore-scr1-base, syntacore-scr1-max, syntacore-scr3-rv32, syntacore-scr4-rv32{{$}}
84+
// RISCV32-NEXT: note: valid target CPU values are: generic-rv32, rocket-rv32, sifive-e20, sifive-e21, sifive-e24, sifive-e31, sifive-e34, sifive-e76, syntacore-scr1-base, syntacore-scr1-max, syntacore-scr3-rv32, syntacore-scr4-rv32, syntacore-scr5-rv32{{$}}
8585

8686
// RUN: not %clang_cc1 -triple riscv64 -target-cpu not-a-cpu -fsyntax-only %s 2>&1 | FileCheck %s --check-prefix RISCV64
8787
// RISCV64: error: unknown target CPU 'not-a-cpu'
88-
// RISCV64-NEXT: note: valid target CPU values are: generic-rv64, rocket-rv64, sifive-p450, sifive-p670, sifive-s21, sifive-s51, sifive-s54, sifive-s76, sifive-u54, sifive-u74, sifive-x280, spacemit-x60, syntacore-scr3-rv64, syntacore-scr4-rv64, veyron-v1, xiangshan-nanhu{{$}}
88+
// RISCV64-NEXT: note: valid target CPU values are: generic-rv64, rocket-rv64, sifive-p450, sifive-p670, sifive-s21, sifive-s51, sifive-s54, sifive-s76, sifive-u54, sifive-u74, sifive-x280, spacemit-x60, syntacore-scr3-rv64, syntacore-scr4-rv64, syntacore-scr5-rv64, veyron-v1, xiangshan-nanhu{{$}}
8989

9090
// RUN: not %clang_cc1 -triple riscv32 -tune-cpu not-a-cpu -fsyntax-only %s 2>&1 | FileCheck %s --check-prefix TUNE-RISCV32
9191
// TUNE-RISCV32: error: unknown target CPU 'not-a-cpu'
92-
// TUNE-RISCV32-NEXT: note: valid target CPU values are: generic-rv32, rocket-rv32, sifive-e20, sifive-e21, sifive-e24, sifive-e31, sifive-e34, sifive-e76, syntacore-scr1-base, syntacore-scr1-max, syntacore-scr3-rv32, syntacore-scr4-rv32, generic, rocket, sifive-7-series{{$}}
92+
// TUNE-RISCV32-NEXT: note: valid target CPU values are: generic-rv32, rocket-rv32, sifive-e20, sifive-e21, sifive-e24, sifive-e31, sifive-e34, sifive-e76, syntacore-scr1-base, syntacore-scr1-max, syntacore-scr3-rv32, syntacore-scr4-rv32, syntacore-scr5-rv32, generic, rocket, sifive-7-series{{$}}
9393

9494
// RUN: not %clang_cc1 -triple riscv64 -tune-cpu not-a-cpu -fsyntax-only %s 2>&1 | FileCheck %s --check-prefix TUNE-RISCV64
9595
// TUNE-RISCV64: error: unknown target CPU 'not-a-cpu'
96-
// TUNE-RISCV64-NEXT: note: valid target CPU values are: generic-rv64, rocket-rv64, sifive-p450, sifive-p670, sifive-s21, sifive-s51, sifive-s54, sifive-s76, sifive-u54, sifive-u74, sifive-x280, spacemit-x60, syntacore-scr3-rv64, syntacore-scr4-rv64, veyron-v1, xiangshan-nanhu, generic, rocket, sifive-7-series{{$}}
96+
// TUNE-RISCV64-NEXT: note: valid target CPU values are: generic-rv64, rocket-rv64, sifive-p450, sifive-p670, sifive-s21, sifive-s51, sifive-s54, sifive-s76, sifive-u54, sifive-u74, sifive-x280, spacemit-x60, syntacore-scr3-rv64, syntacore-scr4-rv64, syntacore-scr5-rv64, veyron-v1, xiangshan-nanhu, generic, rocket, sifive-7-series{{$}}

llvm/docs/ReleaseNotes.rst

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -106,7 +106,7 @@ Changes to the RISC-V Backend
106106
* `.balign N, 0`, `.p2align N, 0`, `.align N, 0` in code sections will now fill
107107
the required alignment space with a sequence of `0x0` bytes (the requested
108108
fill value) rather than NOPs.
109-
* Added Syntacore SCR4 CPUs: ``-mcpu=syntacore-scr4-rv32/64``
109+
* Added Syntacore SCR4 and SCR5 CPUs: ``-mcpu=syntacore-scr4/5-rv32/64``
110110

111111
Changes to the WebAssembly Backend
112112
----------------------------------

llvm/lib/Target/RISCV/RISCVProcessors.td

Lines changed: 26 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -378,6 +378,32 @@ def SYNTACORE_SCR4_RV64 : RISCVProcessorModel<"syntacore-scr4-rv64",
378378
FeatureStdExtC],
379379
[TuneNoDefaultUnroll, FeaturePostRAScheduler]>;
380380

381+
def SYNTACORE_SCR5_RV32 : RISCVProcessorModel<"syntacore-scr5-rv32",
382+
NoSchedModel,
383+
[Feature32Bit,
384+
FeatureStdExtI,
385+
FeatureStdExtZicsr,
386+
FeatureStdExtZifencei,
387+
FeatureStdExtM,
388+
FeatureStdExtA,
389+
FeatureStdExtF,
390+
FeatureStdExtD,
391+
FeatureStdExtC],
392+
[TuneNoDefaultUnroll, FeaturePostRAScheduler]>;
393+
394+
def SYNTACORE_SCR5_RV64 : RISCVProcessorModel<"syntacore-scr5-rv64",
395+
NoSchedModel,
396+
[Feature64Bit,
397+
FeatureStdExtI,
398+
FeatureStdExtZicsr,
399+
FeatureStdExtZifencei,
400+
FeatureStdExtM,
401+
FeatureStdExtA,
402+
FeatureStdExtF,
403+
FeatureStdExtD,
404+
FeatureStdExtC],
405+
[TuneNoDefaultUnroll, FeaturePostRAScheduler]>;
406+
381407
def VENTANA_VEYRON_V1 : RISCVProcessorModel<"veyron-v1",
382408
NoSchedModel,
383409
[Feature64Bit,

0 commit comments

Comments
 (0)