The assembler will generate nop for alignment. For the riscv target support C extension, it may need to generate c.nop to fix up alignment.
Details
Diff Detail
- Repository
- rL LLVM
Event Timeline
| lib/Target/RISCV/MCTargetDesc/RISCVAsmBackend.cpp | ||
|---|---|---|
| 37 ↗ | (On Diff #126887) | Is there any way we can avoid spreading parsing logic throughout the backend? Can we get hold of an MCSubtargetInfo and check for STI.getFeatureBits()[RISCV::FeatureStdExtC]? The change to Triple.cpp then wouldn't be necessary in this patch (though might be something we want to look at, to make arguments more uniform between clang and the llvm tools). | 
| 103 ↗ | (On Diff #126887) | I think it's kind of confusing define i here, then using it below, but also shadowing it with a new i in the NumOps loop. Would it be clearer to just calculate Nop16Count and Nop32Count, then decrement those values directly? | 
| 111 ↗ | (On Diff #126887) | Indentation. | 
| lib/Target/RISCV/MCTargetDesc/RISCVAsmBackend.cpp | ||
|---|---|---|
| 37 ↗ | (On Diff #126887) | The latest revision will: 
 | 
| 103 ↗ | (On Diff #126887) | Yes, define Nop32Count and Nop16Count would be more readable. | 
Creating a TgtMCSubtargetInfo without passing CPUName and FeatureString is what ARM does in ARMAsmBackend, but it seems pretty confusing. The fact that the desired behaviour doesn't work with -triple riscv32 -mattr=+c indicates to me that something is wrong.
D20830 added an MCSubtargetInfo parameter to relaxInstruction. I could see that the same justification could be used to add MCSubtargetInfo to writeNopData.
Does anyone else have views on this? It's been a while since I stepped through the TargetRegistry code - if feasible, having a properly initialised RISCVMCSubtargetInfo (with cpustring and featurestring set correctly) as a field of RISCVAsmBackend seems ideal, but from an initial look it might be difficult.
Hi Alex, I think https://reviews.llvm.org/D41349 is the right thing to do, then we could get correct MCSubtargetInfo by -mattr in MCAsmBackend class, thanks for your work.
We could remove the parsing logic in this patch once https://reviews.llvm.org/D41349 landing.
Remove parsing logic and get MCSubtargetInfo directly due to https://reviews.llvm.org/D41349 has been landing.
Thanks for the update Shiva - a few minor comments in-line
| lib/Target/RISCV/MCTargetDesc/RISCVAsmBackend.cpp | ||
|---|---|---|
| 94–100 ↗ | (On Diff #128496) | This has slightly more nesting than normal LLVM style prefers. It could may be rewritten as: // Nops in the base RISC-V ISA must be 4 bytes, but the compressed extension // introduces 2 byte nops. if (!HasStdExtC && (Count % 4) != 0) return false; if (HasStdExtC && (Count % 2) != 0) return false; Probably better would be to change the function entry to this: bool HasStdExtC = STI.getFeatureBits()[RISCV::FeatureStdExtC]; unsigned MinNopLen = HasStdExtC ? 2 : 4; if ((Count % MinNopLen) != 0) return false; | 
| 101 ↗ | (On Diff #128496) | Nit: end comment with full stop. | 
| 104 ↗ | (On Diff #128496) | Should have two spaces of indentation rather than four. | 
| 106 ↗ | (On Diff #128496) | Nit: end comment with full stop. |