Skip to content

Commit 0a508ce

Browse files
authored
Unrolled build for rust-lang#119738
Rollup merge of rust-lang#119738 - esp-rs:esp32p4-espidf, r=Nilstrieb Add `riscv32imafc-esp-espidf` tier 3 target for the ESP32-P4. The tier 3 target answers in the original PR are still relevant, so please review them here: rust-lang#87666 (comment) cc: ``@ivmarkov``
2 parents ca663b0 + 43ce533 commit 0a508ce

File tree

4 files changed

+34
-0
lines changed

4 files changed

+34
-0
lines changed

compiler/rustc_target/src/spec/mod.rs

+2
Original file line numberDiff line numberDiff line change
@@ -1601,6 +1601,8 @@ supported_targets! {
16011601
("riscv32imc-unknown-none-elf", riscv32imc_unknown_none_elf),
16021602
("riscv32imc-esp-espidf", riscv32imc_esp_espidf),
16031603
("riscv32imac-esp-espidf", riscv32imac_esp_espidf),
1604+
("riscv32imafc-esp-espidf", riscv32imafc_esp_espidf),
1605+
16041606
("riscv32imac-unknown-none-elf", riscv32imac_unknown_none_elf),
16051607
("riscv32imafc-unknown-none-elf", riscv32imafc_unknown_none_elf),
16061608
("riscv32imac-unknown-xous-elf", riscv32imac_unknown_xous_elf),
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,30 @@
1+
use crate::spec::{cvs, PanicStrategy, RelocModel, Target, TargetOptions};
2+
3+
pub fn target() -> Target {
4+
Target {
5+
data_layout: "e-m:e-p:32:32-i64:64-n32-S128".into(),
6+
llvm_target: "riscv32".into(),
7+
pointer_width: 32,
8+
arch: "riscv32".into(),
9+
10+
options: TargetOptions {
11+
families: cvs!["unix"],
12+
os: "espidf".into(),
13+
env: "newlib".into(),
14+
vendor: "espressif".into(),
15+
linker: Some("riscv32-esp-elf-gcc".into()),
16+
cpu: "generic-rv32".into(),
17+
18+
max_atomic_width: Some(32),
19+
atomic_cas: true,
20+
21+
llvm_abiname: "ilp32f".into(),
22+
features: "+m,+a,+c,+f".into(),
23+
panic_strategy: PanicStrategy::Abort,
24+
relocation_model: RelocModel::Static,
25+
emit_debug_gdb_scripts: false,
26+
eh_frame_header: false,
27+
..Default::default()
28+
},
29+
}
30+
}

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

+1
Original file line numberDiff line numberDiff line change
@@ -323,6 +323,7 @@ target | std | host | notes
323323
[`riscv32imac-unknown-xous-elf`](platform-support/riscv32imac-unknown-xous-elf.md) | ? | | RISC-V Xous (RV32IMAC ISA)
324324
[`riscv32imc-esp-espidf`](platform-support/esp-idf.md) | ✓ | | RISC-V ESP-IDF
325325
[`riscv32imac-esp-espidf`](platform-support/esp-idf.md) | ✓ | | RISC-V ESP-IDF
326+
[`riscv32imafc-esp-espidf`](platform-support/esp-idf.md) | ✓ | | RISC-V ESP-IDF
326327
[`riscv64gc-unknown-hermit`](platform-support/hermit.md) | ✓ | | RISC-V Hermit
327328
`riscv64gc-unknown-freebsd` | | | RISC-V FreeBSD
328329
`riscv64gc-unknown-fuchsia` | | | RISC-V Fuchsia

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

+1
Original file line numberDiff line numberDiff line change
@@ -19,6 +19,7 @@ The target names follow this format: `$ARCH-esp-espidf`, where `$ARCH` specifies
1919
| `riscv32imc-esp-espidf` | [ESP32-C3](https://www.espressif.com/en/products/socs/esp32-c3) | `v4.3` |
2020
| `riscv32imac-esp-espidf` | [ESP32-C6](https://www.espressif.com/en/products/socs/esp32-c6) | `v5.1` |
2121
| `riscv32imac-esp-espidf` | [ESP32-H2](https://www.espressif.com/en/products/socs/esp32-h2) | `v5.1` |
22+
| `riscv32imafc-esp-espidf`| [ESP32-P4](https://www.espressif.com/en/news/ESP32-P4) | `v5.2` |
2223

2324
It is recommended to use the latest ESP-IDF stable release if possible.
2425

0 commit comments

Comments
 (0)