mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-22 03:48:57 +00:00
Legalize the shift amount operand of SRL_PARTS, SHL_PARTS, and
SRA_PARTS, as is done for SRL, SHL, and SRA. llvm-svn: 79380
This commit is contained in:
parent
85b15d8e71
commit
56c2c54a37
@ -898,6 +898,13 @@ SDValue SelectionDAGLegalize::LegalizeOp(SDValue Op) {
|
||||
if (!Ops[1].getValueType().isVector())
|
||||
Ops[1] = LegalizeOp(DAG.getShiftAmountOperand(Ops[1]));
|
||||
break;
|
||||
case ISD::SRL_PARTS:
|
||||
case ISD::SRA_PARTS:
|
||||
case ISD::SHL_PARTS:
|
||||
// Legalizing shifts/rotates requires adjusting the shift amount
|
||||
// to the appropriate width.
|
||||
if (!Ops[2].getValueType().isVector())
|
||||
Ops[2] = LegalizeOp(DAG.getShiftAmountOperand(Ops[2]));
|
||||
}
|
||||
|
||||
Result = DAG.UpdateNodeOperands(Result.getValue(0), Ops.data(),
|
||||
|
22
test/CodeGen/X86/shift-parts.ll
Normal file
22
test/CodeGen/X86/shift-parts.ll
Normal file
@ -0,0 +1,22 @@
|
||||
; RUN: llvm-as < %s | llc -march=x86-64 | grep shrdq
|
||||
; PR4736
|
||||
|
||||
%0 = type { i32, i8, [35 x i8] }
|
||||
|
||||
@g_144 = external global %0, align 8 ; <%0*> [#uses=1]
|
||||
|
||||
define i32 @int87(i32 %uint64p_8) nounwind {
|
||||
entry:
|
||||
%srcval4 = load i320* bitcast (%0* @g_144 to i320*), align 8 ; <i320> [#uses=1]
|
||||
br label %for.cond
|
||||
|
||||
for.cond: ; preds = %for.cond, %entry
|
||||
%call3.in.in.in.v = select i1 undef, i320 192, i320 128 ; <i320> [#uses=1]
|
||||
%call3.in.in.in = lshr i320 %srcval4, %call3.in.in.in.v ; <i320> [#uses=1]
|
||||
%call3.in = trunc i320 %call3.in.in.in to i32 ; <i32> [#uses=1]
|
||||
%tobool = icmp eq i32 %call3.in, 0 ; <i1> [#uses=1]
|
||||
br i1 %tobool, label %for.cond, label %if.then
|
||||
|
||||
if.then: ; preds = %for.cond
|
||||
ret i32 1
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user