[clang] [llvm] [RISCV] Implement the implications of C extension (PR #132259)

Craig Topper via llvm-commits llvm-commits at lists.llvm.org
Fri Mar 21 10:12:05 PDT 2025


================
@@ -25,8 +25,8 @@ addi a0, a1, 0
 # CHECK: # encoding:  [0xe0,0x1f]
 addi s0, sp, 1020
 
-# CHECK: .option arch, -c
-.option arch, -c
+# CHECK: .option arch, -c, -zca
+.option arch, -c, -zca
----------------
topperc wrote:

The code for removing a feature doesn't even try to remove dependent features.

```
        assert(Type == RISCVOptionArchArgType::Minus);                           
        // It is invalid to disable an extension that there are other enabled    
        // extensions depend on it.                                              
        // TODO: Make use of RISCVISAInfo to handle this                         
        for (auto &Feature : RISCVFeatureKV) {                                   
          if (getSTI().hasFeature(Feature.Value) &&                              
              Feature.Implies.test(Ext->Value))                                  
            return Error(Loc, Twine("can't disable ") + Ext->Key +               
                                  " extension; " + Feature.Key +                 
                                  " extension requires " + Ext->Key +            
                                  " extension");
```

https://github.com/llvm/llvm-project/pull/132259


More information about the llvm-commits mailing list