diff options
| author | Sameer AbuAsal <sabuasal@codeaurora.org> | 2018-05-17 18:14:53 +0000 |
|---|---|---|
| committer | Sameer AbuAsal <sabuasal@codeaurora.org> | 2018-05-17 18:14:53 +0000 |
| commit | 1dc0a8fb18289dae8536c39d579e7e0064290833 (patch) | |
| tree | 08ac0c63e1fe4d057d567a983b964670713524c9 /llvm/test/DebugInfo/debugify.ll | |
| parent | 87621174ac58bca485f00bf59771abf2830ca9b1 (diff) | |
| download | bcm5719-llvm-1dc0a8fb18289dae8536c39d579e7e0064290833.tar.gz bcm5719-llvm-1dc0a8fb18289dae8536c39d579e7e0064290833.zip | |
[RISCV] Separate base from offset in lowerGlobalAddress
Summary:
When lowering global address, lower the base as a TargetGlobal first then
create an SDNode for the offset separately and chain it to the address calculation
This optimization will create a DAG where the base address of a global access will
be reused between different access. The offset can later be folded into the immediate
part of the memory access instruction.
With this optimization we generate:
lui a0, %hi(s)
addi a0, a0, %lo(s) ; shared base address.
addi a1, zero, 20 ; 2 instructions per access.
sw a1, 44(a0)
addi a1, zero, 10
sw a1, 8(a0)
addi a1, zero, 30
sw a1, 80(a0)
Instead of:
lui a0, %hi(s+44) ; 3 instructions per access.
addi a1, zero, 20
sw a1, %lo(s+44)(a0)
lui a0, %hi(s+8)
addi a1, zero, 10
sw a1, %lo(s+8)(a0)
lui a0, %hi(s+80)
addi a1, zero, 30
sw a1, %lo(s+80)(a0)
Which will save one instruction per access.
Reviewers: asb, apazos
Reviewed By: asb
Subscribers: rbar, johnrusso, simoncook, jordy.potman.lists, niosHD, kito-cheng, shiva0217, zzheng, edward-jones, mgrang, apazos, asb, llvm-commits
Differential Revision: https://reviews.llvm.org/D46989
llvm-svn: 332641
Diffstat (limited to 'llvm/test/DebugInfo/debugify.ll')
0 files changed, 0 insertions, 0 deletions

