[PATCH] D55305: [RISCV, WIP] Add initial lowering of global TLS addresses
Lewis Revill via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Dec 4 17:19:33 PST 2018
lewis-revill created this revision.
lewis-revill added reviewers: asb, rogfer01, jrtc27.
Herald added subscribers: llvm-commits, jocewei, PkmX, the_o, brucehoult, MartinMosbeck, mgrang, edward-jones, zzheng, shiva0217, kito-cheng, niosHD, sabuasal, apazos, simoncook, johnrusso, rbar.
This patch adds lowering for global TLS addresses for the TLS models of InitialExec, GlobalDynamic and LocalDynamic. LocalExec requires a special add instruction to be added which takes 4 arguments, with the addition of a symbol relocation for %tprel_add(sym). This argument corresponds to no bits but the relocation must be emitted. This is not straightforward in LLVM. LocalExec support follows in a separate patch.
Repository:
rL LLVM
https://reviews.llvm.org/D55305
Files:
lib/Target/RISCV/AsmParser/RISCVAsmParser.cpp
lib/Target/RISCV/MCTargetDesc/RISCVAsmBackend.cpp
lib/Target/RISCV/MCTargetDesc/RISCVAsmBackend.h
lib/Target/RISCV/MCTargetDesc/RISCVELFObjectWriter.cpp
lib/Target/RISCV/MCTargetDesc/RISCVFixupKinds.h
lib/Target/RISCV/MCTargetDesc/RISCVMCCodeEmitter.cpp
lib/Target/RISCV/MCTargetDesc/RISCVMCExpr.cpp
lib/Target/RISCV/MCTargetDesc/RISCVMCExpr.h
lib/Target/RISCV/RISCVISelLowering.cpp
lib/Target/RISCV/RISCVISelLowering.h
lib/Target/RISCV/RISCVInstrInfo.td
lib/Target/RISCV/RISCVMCInstLower.cpp
lib/Target/RISCV/Utils/RISCVBaseInfo.h
test/CodeGen/RISCV/tls-models.ll
test/MC/RISCV/rv32d-invalid.s
test/MC/RISCV/rv32f-invalid.s
test/MC/RISCV/rv32i-invalid.s
test/MC/RISCV/rv32i-valid.s
test/MC/RISCV/rv64i-invalid.s
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D55305.176745.patch
Type: text/x-patch
Size: 36000 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20181205/bab89d8d/attachment-0001.bin>
More information about the llvm-commits
mailing list