[llvm] r350695 - GlobalISel: Implement widenScalar for implicit_def
Matt Arsenault via llvm-commits
llvm-commits at lists.llvm.org
Tue Jan 8 23:34:14 PST 2019
Author: arsenm
Date: Tue Jan 8 23:34:14 2019
New Revision: 350695
URL: http://llvm.org/viewvc/llvm-project?rev=350695&view=rev
Log:
GlobalISel: Implement widenScalar for implicit_def
Modified:
llvm/trunk/lib/CodeGen/GlobalISel/LegalizerHelper.cpp
llvm/trunk/test/CodeGen/AArch64/GlobalISel/legalize-undef.mir
Modified: llvm/trunk/lib/CodeGen/GlobalISel/LegalizerHelper.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/GlobalISel/LegalizerHelper.cpp?rev=350695&r1=350694&r2=350695&view=diff
==============================================================================
--- llvm/trunk/lib/CodeGen/GlobalISel/LegalizerHelper.cpp (original)
+++ llvm/trunk/lib/CodeGen/GlobalISel/LegalizerHelper.cpp Tue Jan 8 23:34:14 2019
@@ -884,6 +884,12 @@ LegalizerHelper::widenScalar(MachineInst
Observer.changedInstr(MI);
return Legalized;
}
+ case TargetOpcode::G_IMPLICIT_DEF: {
+ Observer.changingInstr(MI);
+ widenScalarDst(MI, WideTy);
+ Observer.changedInstr(MI);
+ return Legalized;
+ }
case TargetOpcode::G_BRCOND:
Observer.changingInstr(MI);
widenScalarSrc(MI, WideTy, 0, TargetOpcode::G_ANYEXT);
Modified: llvm/trunk/test/CodeGen/AArch64/GlobalISel/legalize-undef.mir
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/AArch64/GlobalISel/legalize-undef.mir?rev=350695&r1=350694&r2=350695&view=diff
==============================================================================
--- llvm/trunk/test/CodeGen/AArch64/GlobalISel/legalize-undef.mir (original)
+++ llvm/trunk/test/CodeGen/AArch64/GlobalISel/legalize-undef.mir Tue Jan 8 23:34:14 2019
@@ -1,5 +1,5 @@
# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
-# RUN: llc -march=aarch64 -run-pass=legalizer %s -o - | FileCheck %s
+# RUN: llc -march=aarch64 -run-pass=legalizer -O0 %s -o - | FileCheck %s
---
name: test_implicit_def
body: |
@@ -16,3 +16,22 @@ body: |
%1:_(s64) = G_TRUNC %0(s128)
$x0 = COPY %1(s64)
...
+
+---
+name: test_implicit_def_s3
+body: |
+ bb.0:
+ liveins:
+
+ ; CHECK-LABEL: name: test_implicit_def_s3
+ ; CHECK: [[C:%[0-9]+]]:_(s64) = G_CONSTANT i64 61
+ ; CHECK: [[DEF:%[0-9]+]]:_(s64) = G_IMPLICIT_DEF
+ ; CHECK: [[SHL:%[0-9]+]]:_(s64) = G_SHL [[DEF]], [[C]]
+ ; CHECK: [[ASHR:%[0-9]+]]:_(s64) = G_ASHR [[SHL]], [[C]]
+ ; CHECK: $x0 = COPY [[ASHR]](s64)
+ %0:_(s3) = G_IMPLICIT_DEF
+ %1:_(s64) = G_SEXT %0
+ $x0 = COPY %1(s64)
+...
+
+# FIXME: s2 not correctly handled
More information about the llvm-commits
mailing list