mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-16 12:24:03 +00:00
Swift: Only build vldm/vstm with q register aligned register lists
Unaligned vldm/vstm need more uops and therefore are slower in general on swift. radar://14522102 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@189961 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -489,7 +489,10 @@ ARMLoadStoreOpt::MergeLDR_STR(MachineBasicBlock &MBB, unsigned SIndex,
|
||||
if (Reg != ARM::SP &&
|
||||
NewOffset == Offset + (int)Size &&
|
||||
((isNotVFP && RegNum > PRegNum) ||
|
||||
((Count < Limit) && RegNum == PRegNum+1))) {
|
||||
((Count < Limit) && RegNum == PRegNum+1)) &&
|
||||
// On Swift we don't want vldm/vstm to start with a odd register num
|
||||
// because Q register unaligned vldm/vstm need more uops.
|
||||
(!STI->isSwift() || isNotVFP || Count != 1 || !(PRegNum & 0x1))) {
|
||||
Offset += Size;
|
||||
PRegNum = RegNum;
|
||||
++Count;
|
||||
|
Reference in New Issue
Block a user