diff options
| author | Jacob Pratt <jacob@jhpratt.dev> | 2025-08-21 01:12:18 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-08-21 01:12:18 -0400 | 
| commit | 03aa3b8489144e306adddc29217fbf8359404620 (patch) | |
| tree | 83bb11f8beee865473764d0f0dc64ca1797a9c77 | |
| parent | 62582eb78ed097cfaee941faef36c2de4a41ca41 (diff) | |
| parent | ee7627ee409b1f2a3ebbf6c868adbc0d75a1f43b (diff) | |
| download | rust-03aa3b8489144e306adddc29217fbf8359404620.tar.gz rust-03aa3b8489144e306adddc29217fbf8359404620.zip | |
Rollup merge of #145415 - a4lg:riscv-implication-to-c, r=Amanieu
std_detect: RISC-V: implement implication to "C" Just like we implemented relatively complex rules to imply other extensions **from** "C" (and some others), this commit implements implication **to** the "C" extension from others, complying the following text in the ISA Manual (although there's no direct imply/depend references). > The C extension is the superset of the following extensions: > > - Zca > - Zcf if F is specified (RV32 only) > - Zcd if D is specified This is formally verified so that no other extension combinations (*not* in this implementation) can (currently) imply the "C" extension. Note: this is a `std_detect` change and not main target feature handling.
| -rw-r--r-- | library/std_detect/src/detect/os/riscv.rs | 22 | 
1 files changed, 21 insertions, 1 deletions
| diff --git a/library/std_detect/src/detect/os/riscv.rs b/library/std_detect/src/detect/os/riscv.rs index c6acbd3525b..9b9e0cba09d 100644 --- a/library/std_detect/src/detect/os/riscv.rs +++ b/library/std_detect/src/detect/os/riscv.rs @@ -119,11 +119,31 @@ pub(crate) fn imply_features(mut value: cache::Initializer) -> cache::Initialize imply!(d | zfhmin | zfa => f); imply!(zfbfmin => f); // and some of (not all) "Zfh" instructions. - // Relatively complex implication rules from the "C" extension. + // Relatively complex implication rules around the "C" extension. + // (from "C" and some others) imply!(c => zca); imply!(c & d => zcd); #[cfg(target_arch = "riscv32")] imply!(c & f => zcf); + // (to "C"; defined as superset) + cfg_select! { + target_arch = "riscv32" => { + if value.test(Feature::d as u32) { + imply!(zcf & zcd => c); + } else if value.test(Feature::f as u32) { + imply!(zcf => c); + } else { + imply!(zca => c); + } + } + _ => { + if value.test(Feature::d as u32) { + imply!(zcd => c); + } else { + imply!(zca => c); + } + } + } imply!(zicntr | zihpm | f | zfinx | zve32x => zicsr); | 
