From 3f5f0fb15823b0b81c213a4c968865ab1998b541 Mon Sep 17 00:00:00 2001 From: Conner Bradley Date: Fri, 9 Jun 2023 20:36:57 -0400 Subject: [PATCH 1/3] Add target mapping for riscv32imc and riscv32imac Similar problem as the one mentioned in #2136, just continuing by adding the 32 bit risc tuple mappings. Tuples like riscv32imc- and riscv32imac- should map to the clang riscv32- tuple. Fixed by adding mappings and tests for the mappings. Projects that now failed to build the "riscv32imac-unknown-none-elf" target tuple now build without issue. --- bindgen/lib.rs | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/bindgen/lib.rs b/bindgen/lib.rs index be0cd8266a..ec53865dcb 100644 --- a/bindgen/lib.rs +++ b/bindgen/lib.rs @@ -686,6 +686,14 @@ fn rust_to_clang_target(rust_target: &str) -> String { clang_target.strip_prefix("riscv32imc-").unwrap(); } return clang_target; + } else if rust_target.starts_with("riscv32imc-") { + let mut clang_target = "riscv32-".to_owned(); + clang_target.push_str(rust_target.strip_prefix("riscv32imc-").unwrap()); + return clang_target; + } else if rust_target.starts_with("riscv32imac-") { + let mut clang_target = "riscv32-".to_owned(); + clang_target.push_str(rust_target.strip_prefix("riscv32imac-").unwrap()); + return clang_target; } rust_target.to_owned() } @@ -1285,7 +1293,15 @@ fn test_rust_to_clang_target_riscv() { assert_eq!( rust_to_clang_target("riscv64gc-unknown-linux-gnu"), "riscv64-unknown-linux-gnu" - ) + ); + assert_eq!( + rust_to_clang_target("riscv32imc-unknown-none-elf"), + "riscv32-unknown-none-elf" + ); + assert_eq!( + rust_to_clang_target("riscv32imac-unknown-none-elf"), + "riscv32-unknown-none-elf" + ); } #[test] From 6d4a497fb9164c4b9efcbc8406cac077227027f1 Mon Sep 17 00:00:00 2001 From: Conner Bradley Date: Fri, 9 Jun 2023 20:48:22 -0400 Subject: [PATCH 2/3] Formatting fixes --- bindgen/lib.rs | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/bindgen/lib.rs b/bindgen/lib.rs index ec53865dcb..9d1ebb4599 100644 --- a/bindgen/lib.rs +++ b/bindgen/lib.rs @@ -692,7 +692,8 @@ fn rust_to_clang_target(rust_target: &str) -> String { return clang_target; } else if rust_target.starts_with("riscv32imac-") { let mut clang_target = "riscv32-".to_owned(); - clang_target.push_str(rust_target.strip_prefix("riscv32imac-").unwrap()); + clang_target + .push_str(rust_target.strip_prefix("riscv32imac-").unwrap()); return clang_target; } rust_target.to_owned() From 57f696fadbdd30fbe7d61498f640621b8402d9ef Mon Sep 17 00:00:00 2001 From: Conner Bradley Date: Sat, 10 Jun 2023 08:51:23 -0400 Subject: [PATCH 3/3] Add #2551 to changelog --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 2a78cb26c9..650d055cd6 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -196,6 +196,7 @@ + `log` removed in favor of `logging` + `which` removed in favor of `which-logging` + `annotate-snippets` removed in favor of `experimental` +* Add target mappings for riscv32imc and riscv32imac. ## Removed