[RISCV] Compress instructions based on function features
authorSimon Cook <simon.cook@embecosm.com>
Fri, 28 Feb 2020 11:52:55 +0000 (11:52 +0000)
committerSimon Cook <simon.cook@embecosm.com>
Fri, 28 Feb 2020 11:52:55 +0000 (11:52 +0000)
commitca950a6bb1972d142a8f6932f33f61386aabd949
tree9b198469cc825323b68517719fd35e047b892fe2
parent29fb0b1310049718dffe7523d7e97fc6d9307c92
[RISCV] Compress instructions based on function features

When running under LTO, it is common to not specify the architecture
spec, which is used for setting up the target machine, and instead rely
on features specified in each function to generate the correct
instructions.

This works for the code generator, but the RISC-V backend uses the
AsmPrinter to do instruction compression, which does not see these
features but instead uses a MCSubtargetInfo object to see whether
compression is enabled. Since this is configured based on the
TargetMachine at startup, it will result in compressed instructions not
being emitted when it has not been given the 'c' TargetFeature, but the
function has it.

This changes the RISCVAsmPrinter to re-initialize the STI feature set
based on the current MachineFunction, such that compressed instructions
are now correctly emitted regardless of the method used to enable them.

Differential revision: https://reviews.llvm.org/D73339
llvm/lib/Target/RISCV/RISCVAsmPrinter.cpp
llvm/test/CodeGen/RISCV/compress-float.ll [new file with mode: 0644]
llvm/test/CodeGen/RISCV/compress.ll