diff options
author | github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> | 2023-01-25 22:54:47 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-01-25 22:54:47 +0000 |
commit | 65a9af508e6f551a48e8f4ed921684ca34307c00 (patch) | |
tree | f9933e21fe479de1a9d1501d8902d45c628fb4cc | |
parent | 036ac90dd079bfc7c89e2683070355df200c4148 (diff) | |
parent | a7ff8e136027c9542f65eca97a7ff3c0b870518d (diff) |
-rw-r--r-- | bindgen/lib.rs | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/bindgen/lib.rs b/bindgen/lib.rs index cf1486c2..8c8ffe5c 100644 --- a/bindgen/lib.rs +++ b/bindgen/lib.rs @@ -2428,6 +2428,15 @@ fn rust_to_clang_target(rust_target: &str) -> String { let mut clang_target = "riscv64-".to_owned(); clang_target.push_str(rust_target.strip_prefix("riscv64gc-").unwrap()); return clang_target; + } else if rust_target.ends_with("-espidf") { + let mut clang_target = + rust_target.strip_suffix("-espidf").unwrap().to_owned(); + clang_target.push_str("-elf"); + if clang_target.starts_with("riscv32imc-") { + clang_target = "riscv32-".to_owned() + + clang_target.strip_prefix("riscv32imc-").unwrap(); + } + return clang_target; } rust_target.to_owned() } @@ -3011,3 +3020,15 @@ fn test_rust_to_clang_target_riscv() { "riscv64-unknown-linux-gnu" ) } + +#[test] +fn test_rust_to_clang_target_espidf() { + assert_eq!( + rust_to_clang_target("riscv32imc-esp-espidf"), + "riscv32-esp-elf" + ); + assert_eq!( + rust_to_clang_target("xtensa-esp32-espidf"), + "xtensa-esp32-elf" + ); +} |