forked from OSchip/llvm-project
Fix a problem on itanium with memset. The value to set has been promoted to
i64 before this code, so zero_ext doesn't work. llvm-svn: 26290
This commit is contained in:
parent
c2e3a7a4ce
commit
486d1bc5ed
|
@ -1661,8 +1661,12 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
|
|||
const char *FnName = 0;
|
||||
if (Node->getOpcode() == ISD::MEMSET) {
|
||||
Args.push_back(std::make_pair(Tmp2, IntPtrTy));
|
||||
// Extend the ubyte argument to be an int value for the call.
|
||||
Tmp3 = DAG.getNode(ISD::ZERO_EXTEND, MVT::i32, Tmp3);
|
||||
// Extend the (previously legalized) ubyte argument to be an int value
|
||||
// for the call.
|
||||
if (Tmp3.getValueType() > MVT::i32)
|
||||
Tmp3 = DAG.getNode(ISD::TRUNCATE, MVT::i32, Tmp3);
|
||||
else
|
||||
Tmp3 = DAG.getNode(ISD::ZERO_EXTEND, MVT::i32, Tmp3);
|
||||
Args.push_back(std::make_pair(Tmp3, Type::IntTy));
|
||||
Args.push_back(std::make_pair(Tmp4, IntPtrTy));
|
||||
|
||||
|
|
Loading…
Reference in New Issue