Check early if this is an unsupported opcode, so that we can avoid needlessly instant...
authorOwen Anderson <resistor@mac.com>
Tue, 29 Mar 2011 20:27:38 +0000 (20:27 +0000)
committerOwen Anderson <resistor@mac.com>
Tue, 29 Mar 2011 20:27:38 +0000 (20:27 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@128481 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/ARM/ARMLoadStoreOptimizer.cpp

index 0dab835f7c81231b12d80c5226ad2e3609218e43..838f20f4b77f24199f8565540b28f047eef861a2 100644 (file)
@@ -308,6 +308,10 @@ ARMLoadStoreOpt::MergeOps(MachineBasicBlock &MBB,
     // VLDM/VSTM do not support DB mode without also updating the base reg.
     Mode = ARM_AM::db;
   else if (Offset != 0) {
+    // Check if this is a supported opcode before we insert instructions to
+    // calculate a new base register.
+    if (!getLoadStoreMultipleOpcode(Opcode, Mode)) return false;
+
     // If starting offset isn't zero, insert a MI to materialize a new base.
     // But only do so if it is cost effective, i.e. merging more than two
     // loads / stores.