ARMLoadStoreOptimizer: Rewrite LDM/STM matching logic.
authorMatthias Braun <matze@braunis.de>
Fri, 10 Jul 2015 18:08:49 +0000 (18:08 +0000)
committerMatthias Braun <matze@braunis.de>
Fri, 10 Jul 2015 18:08:49 +0000 (18:08 +0000)
commit892af54a915f82701c3bd39849452266852610a1
treeee7b9c6d7b7e9a1e09f337621b4104d4ee105bcf
parent98da4704dde8d2cd36bcdf9281cf167fddf1edb7
ARMLoadStoreOptimizer: Rewrite LDM/STM matching logic.

This improves the logic in several ways and is a preparation for
followup patches:
- First perform an analysis and create a list of merge candidates, then
  transform. This simplifies the code in that you have don't have to
  care to much anymore that you may be holding iterators to
  MachineInstrs that get removed.
- Analyze/Transform basic blocks in reverse order. This allows to use
  LivePhysRegs to find free registers instead of the RegisterScavenger.
  The RegisterScavenger will become less precise in the future as it
  relies on the deprecated kill-flags.
- Return the newly created node in MergeOps so there's no need to look
  around in the schedule to find it.
- Rename some MBBI iterators to InsertBefore to make their role clear.
- General code cleanup.

Differential Revision: http://reviews.llvm.org/D10140

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@241920 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Target/ARM/ARMLoadStoreOptimizer.cpp
test/CodeGen/ARM/2013-05-13-AAPCS-byval-padding2.ll