From: Brian Gaeke Date: Mon, 23 Jun 2003 20:00:51 +0000 (+0000) Subject: Fix 2003-06-23-PromotedExprs.llx -- if we are adding two bytes we better X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=031a112747a480a4dea1cd5a02de88d42b091225;p=oota-llvm.git Fix 2003-06-23-PromotedExprs.llx -- if we are adding two bytes we better explicitly cast the result to be a byte, or C will gleefully promote it to int. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@6869 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Target/CBackend/CBackend.cpp b/lib/Target/CBackend/CBackend.cpp index ce44f3ce308..9e10d5bc782 100644 --- a/lib/Target/CBackend/CBackend.cpp +++ b/lib/Target/CBackend/CBackend.cpp @@ -1029,6 +1029,16 @@ void CWriter::visitPHINode(PHINode &I) { void CWriter::visitBinaryOperator(Instruction &I) { // binary instructions, shift instructions, setCond instructions. assert(!isa(I.getType())); + + // We must cast the results of binary operations which might be promoted. + bool needsCast = false; + if ((I.getType() == Type::UByteTy) || (I.getType() == Type::SByteTy) + || (I.getType() == Type::UShortTy) || (I.getType() == Type::ShortTy)) { + needsCast = true; + Out << "(("; + printType(Out, I.getType(), "", false, false); + Out << ")("; + } writeOperand(I.getOperand(0)); @@ -1053,6 +1063,10 @@ void CWriter::visitBinaryOperator(Instruction &I) { } writeOperand(I.getOperand(1)); + + if (needsCast) { + Out << "))"; + } } void CWriter::visitCastInst(CastInst &I) { diff --git a/lib/Target/CBackend/Writer.cpp b/lib/Target/CBackend/Writer.cpp index ce44f3ce308..9e10d5bc782 100644 --- a/lib/Target/CBackend/Writer.cpp +++ b/lib/Target/CBackend/Writer.cpp @@ -1029,6 +1029,16 @@ void CWriter::visitPHINode(PHINode &I) { void CWriter::visitBinaryOperator(Instruction &I) { // binary instructions, shift instructions, setCond instructions. assert(!isa(I.getType())); + + // We must cast the results of binary operations which might be promoted. + bool needsCast = false; + if ((I.getType() == Type::UByteTy) || (I.getType() == Type::SByteTy) + || (I.getType() == Type::UShortTy) || (I.getType() == Type::ShortTy)) { + needsCast = true; + Out << "(("; + printType(Out, I.getType(), "", false, false); + Out << ")("; + } writeOperand(I.getOperand(0)); @@ -1053,6 +1063,10 @@ void CWriter::visitBinaryOperator(Instruction &I) { } writeOperand(I.getOperand(1)); + + if (needsCast) { + Out << "))"; + } } void CWriter::visitCastInst(CastInst &I) {