[llvm] r279526 - [Hexagon] Packetize return value setup with the return instruction

Krzysztof Parzyszek via llvm-commits llvm-commits at lists.llvm.org
Tue Aug 23 09:01:01 PDT 2016


Author: kparzysz
Date: Tue Aug 23 11:01:01 2016
New Revision: 279526

URL: http://llvm.org/viewvc/llvm-project?rev=279526&view=rev
Log:
[Hexagon] Packetize return value setup with the return instruction

Commit r279241 unintentionally reverted that ability.

Added:
    llvm/trunk/test/CodeGen/Hexagon/packetize-return-arg.ll
Modified:
    llvm/trunk/lib/Target/Hexagon/HexagonVLIWPacketizer.cpp

Modified: llvm/trunk/lib/Target/Hexagon/HexagonVLIWPacketizer.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/Hexagon/HexagonVLIWPacketizer.cpp?rev=279526&r1=279525&r2=279526&view=diff
==============================================================================
--- llvm/trunk/lib/Target/Hexagon/HexagonVLIWPacketizer.cpp (original)
+++ llvm/trunk/lib/Target/Hexagon/HexagonVLIWPacketizer.cpp Tue Aug 23 11:01:01 2016
@@ -339,7 +339,8 @@ bool HexagonPacketizerList::isNewifiable
   if (NewRC == &Hexagon::PredRegsRegClass)
     if (HII->isV60VectorInstruction(MI) && MI.mayStore())
       return false;
-  return HII->isCondInst(MI) || HII->isJumpR(MI) || HII->mayBeNewStore(MI);
+  return HII->isCondInst(MI) || HII->isJumpR(MI) || MI.isReturn() ||
+         HII->mayBeNewStore(MI);
 }
 
 // Promote an instructiont to its .cur form.
@@ -805,7 +806,7 @@ bool HexagonPacketizerList::canPromoteTo
 
   // predicate .new
   if (RC == &Hexagon::PredRegsRegClass)
-    if (HII->isCondInst(MI) || HII->isJumpR(MI))
+    if (HII->isCondInst(MI) || HII->isJumpR(MI) || MI.isReturn())
       return HII->predCanBeUsedAsDotNew(PI, DepReg);
 
   if (RC != &Hexagon::PredRegsRegClass && !HII->mayBeNewStore(MI))
@@ -1307,7 +1308,7 @@ bool HexagonPacketizerList::isLegalToPac
       RC = HRI->getMinimalPhysRegClass(DepReg);
     }
 
-    if (I.isCall() || HII->isJumpR(I) || HII->isTailCall(I)) {
+    if (I.isCall() || HII->isJumpR(I) || I.isReturn() || HII->isTailCall(I)) {
       if (!isRegDependence(DepType))
         continue;
       if (!isCallDependent(I, DepType, SUJ->Succs[i].getReg()))

Added: llvm/trunk/test/CodeGen/Hexagon/packetize-return-arg.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/Hexagon/packetize-return-arg.ll?rev=279526&view=auto
==============================================================================
--- llvm/trunk/test/CodeGen/Hexagon/packetize-return-arg.ll (added)
+++ llvm/trunk/test/CodeGen/Hexagon/packetize-return-arg.ll Tue Aug 23 11:01:01 2016
@@ -0,0 +1,37 @@
+; RUN: llc -march=hexagon < %s | FileCheck %s
+; Check that "r0 = rN" is packetized together with dealloc_return.
+; CHECK: r0 = r
+; CHECK-NOT: {
+; CHECK: dealloc_return
+
+target triple = "hexagon-unknown--elf"
+
+; Function Attrs: nounwind
+define i8* @fred(i8* %user_context, i32 %x) #0 {
+entry:
+  %and14 = add i32 %x, 255
+  %add1 = and i32 %and14, -128
+  %call = tail call i8* @malloc(i32 %add1) #1
+  %cmp = icmp eq i8* %call, null
+  br i1 %cmp, label %cleanup, label %if.end
+
+if.end:                                           ; preds = %entry
+  %0 = ptrtoint i8* %call to i32
+  %sub4 = add i32 %0, 131
+  %and5 = and i32 %sub4, -128
+  %1 = inttoptr i32 %and5 to i8*
+  %2 = inttoptr i32 %and5 to i8**
+  %arrayidx = getelementptr inbounds i8*, i8** %2, i32 -1
+  store i8* %call, i8** %arrayidx, align 4
+  br label %cleanup
+
+cleanup:                                          ; preds = %if.end, %entry
+  %retval.0 = phi i8* [ %1, %if.end ], [ null, %entry ]
+  ret i8* %retval.0
+}
+
+; Function Attrs: nounwind
+declare noalias i8* @malloc(i32) local_unnamed_addr #1
+
+attributes #0 = { nounwind }
+attributes #1 = { nobuiltin nounwind }




More information about the llvm-commits mailing list