From ab5d0ac02c4174078fed4fed2e3da36eeb8c8807 Mon Sep 17 00:00:00 2001 From: Chris Lattner <sabre@nondot.org> Date: Mon, 26 Feb 2007 02:56:58 +0000 Subject: [PATCH] track signedness of formal argument, though we have a fixme here. llvm-svn: 34620 --- llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp index 69aa6aedf868..3842db5d9d09 100644 --- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp @@ -3111,8 +3111,16 @@ TargetLowering::LowerArguments(Function &F, SelectionDAG &DAG) { // Flags[31:27] -> OriginalAlignment // Flags[2] -> isSRet // Flags[1] -> isInReg + // Flags[0] -> isSigned unsigned Flags = (isInReg << 1) | (isSRet << 2) | (OriginalAlignment << 27); + // FIXME: Distinguish between a formal with no [sz]ext attribute from one + // that is zero extended! + if (FTy->paramHasAttr(j, FunctionType::ZExtAttribute)) + Flags |= 0; + if (FTy->paramHasAttr(j, FunctionType::SExtAttribute)) + Flags |= 1; + switch (getTypeAction(VT)) { default: assert(0 && "Unknown type action!"); case Legal: