revert 76503 while I figure out what's going on
authorDale Johannesen <dalej@apple.com>
Tue, 21 Jul 2009 00:12:29 +0000 (00:12 +0000)
committerDale Johannesen <dalej@apple.com>
Tue, 21 Jul 2009 00:12:29 +0000 (00:12 +0000)
llvm-svn: 76517

llvm/lib/Target/X86/X86ISelLowering.cpp

index 7ce51b323ca7191927b03f64c264af615e1a8e5e..c20a62665854160bbe81b429228e8fe9a968c8c0 100644 (file)
@@ -4557,7 +4557,7 @@ X86TargetLowering::LowerGlobalAddress(const GlobalValue *GV, DebugLoc dl,
   SDValue Result;
   if (OpFlags == X86II::MO_NO_FLAG && isInt32(Offset)) {
     // A direct static reference to a global.
-    Result = DAG.getTargetGlobalAddress(GV, getPointerTy(), Offset, OpFlags);
+    Result = DAG.getTargetGlobalAddress(GV, getPointerTy(), Offset);
     Offset = 0;
   } else {
     Result = DAG.getTargetGlobalAddress(GV, getPointerTy(), 0, OpFlags);
@@ -8911,7 +8911,10 @@ void X86TargetLowering::LowerAsmOperandForConstraint(SDValue Op,
                                                         getTargetMachine())))
       return;
 
-    Op = LowerGlobalAddress(GV, Op.getDebugLoc(), Offset, DAG);
+    if (hasMemory)
+      Op = LowerGlobalAddress(GV, Op.getDebugLoc(), Offset, DAG);
+    else
+      Op = DAG.getTargetGlobalAddress(GV, GA->getValueType(0), Offset);
     Result = Op;
     break;
   }