Skip to content

Commit eae6835

Browse files
Add support for targeting riscv32im-unknown-none-elf
Update riscv32im-unknown-none-elf to Tier2 support. Downgrade to Tier 3 platform support.
1 parent 10dccdc commit eae6835

File tree

4 files changed

+29
-0
lines changed

4 files changed

+29
-0
lines changed

compiler/rustc_target/src/spec/mod.rs

+1
Original file line numberDiff line numberDiff line change
@@ -975,6 +975,7 @@ supported_targets! {
975975
("x86_64-unknown-none-hermitkernel", x86_64_unknown_none_hermitkernel),
976976

977977
("riscv32i-unknown-none-elf", riscv32i_unknown_none_elf),
978+
("riscv32im-unknown-none-elf", riscv32im_unknown_none_elf),
978979
("riscv32imc-unknown-none-elf", riscv32imc_unknown_none_elf),
979980
("riscv32imc-esp-espidf", riscv32imc_esp_espidf),
980981
("riscv32imac-unknown-none-elf", riscv32imac_unknown_none_elf),
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
1+
use crate::spec::{LinkerFlavor, LldFlavor, PanicStrategy, RelocModel};
2+
use crate::spec::{Target, TargetOptions};
3+
4+
pub fn target() -> Target {
5+
Target {
6+
data_layout: "e-m:e-p:32:32-i64:64-n32-S128".to_string(),
7+
llvm_target: "riscv32".to_string(),
8+
pointer_width: 32,
9+
arch: "riscv32".to_string(),
10+
11+
options: TargetOptions {
12+
linker_flavor: LinkerFlavor::Lld(LldFlavor::Ld),
13+
linker: Some("rust-lld".to_string()),
14+
cpu: "generic-rv32".to_string(),
15+
max_atomic_width: Some(0),
16+
atomic_cas: false,
17+
features: "+m".to_string(),
18+
executables: true,
19+
panic_strategy: PanicStrategy::Abort,
20+
relocation_model: RelocModel::Static,
21+
emit_debug_gdb_scripts: false,
22+
eh_frame_header: false,
23+
..Default::default()
24+
},
25+
}
26+
}

src/doc/rustc/src/platform-support.md

+1
Original file line numberDiff line numberDiff line change
@@ -271,6 +271,7 @@ target | std | host | notes
271271
`powerpc64le-unknown-linux-musl` | ? | |
272272
`riscv32gc-unknown-linux-gnu` | | | RISC-V Linux (kernel 5.4, glibc 2.33)
273273
`riscv32gc-unknown-linux-musl` | | | RISC-V Linux (kernel 5.4, musl + RISCV32 support patches)
274+
`riscv32im-unknown-none-elf` | * | | Bare RISC-V (RV32IM ISA)
274275
`riscv32imc-esp-espidf` | ✓ | | RISC-V ESP-IDF
275276
`riscv64gc-unknown-freebsd` | | | RISC-V FreeBSD
276277
`riscv64gc-unknown-linux-musl` | | | RISC-V Linux (kernel 4.20, musl 1.2.0)

src/tools/build-manifest/src/main.rs

+1
Original file line numberDiff line numberDiff line change
@@ -117,6 +117,7 @@ static TARGETS: &[&str] = &[
117117
"powerpc64-unknown-linux-gnu",
118118
"powerpc64le-unknown-linux-gnu",
119119
"riscv32i-unknown-none-elf",
120+
"riscv32im-unknown-none-elf",
120121
"riscv32imc-unknown-none-elf",
121122
"riscv32imac-unknown-none-elf",
122123
"riscv32gc-unknown-linux-gnu",

0 commit comments

Comments
 (0)