Fix the PowerPC JIT-only failure on UnitTests/Vector/sumarray-dbl, which is
authorChris Lattner <sabre@nondot.org>
Wed, 10 May 2006 06:38:32 +0000 (06:38 +0000)
committerChris Lattner <sabre@nondot.org>
Wed, 10 May 2006 06:38:32 +0000 (06:38 +0000)
really a bad codegen bug that LLC happens to get lucky with. I must chat with
Nate for the proper fix.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@28213 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/PowerPC/PPCRegisterInfo.cpp

index 36cb869abda341951a9b31c4bd9a02c990b9820f..0b961cb8074e37ac1a2afb144452addce57ac248 100644 (file)
@@ -506,11 +506,11 @@ void PPCRegisterInfo::emitPrologue(MachineFunction &MF) const {
   // If there is a preferred stack alignment, align R1 now
   if (MaxAlign > TargetAlign) {
     assert(isPowerOf2_32(MaxAlign) && MaxAlign < 32767 && "Invalid alignment!");
-    assert(isInt16(MaxAlign-NumBytes) && "Unhandled stack size and alignment!");
+    assert(isInt16(0-NumBytes) && "Unhandled stack size and alignment!");
     BuildMI(MBB, MBBI, PPC::RLWINM, 4, PPC::R0)
       .addReg(PPC::R1).addImm(0).addImm(32-Log2_32(MaxAlign)).addImm(31);
     BuildMI(MBB, MBBI, PPC::SUBFIC,2,PPC::R0).addReg(PPC::R0)
-      .addImm(MaxAlign-NumBytes);
+      .addImm(0-NumBytes);
     BuildMI(MBB, MBBI, PPC::STWUX, 3)
       .addReg(PPC::R1).addReg(PPC::R1).addReg(PPC::R0);
   } else if (NumBytes <= 32768) {