diff --git a/lib/CodeGen/CGExprConstant.cpp b/lib/CodeGen/CGExprConstant.cpp index d64c5876ee2d6a280c6ad4f79b1f3ae4d0face02..8ad1a4d29cd5c74f9c411d1f1ad12b0a49409968 100644 --- a/lib/CodeGen/CGExprConstant.cpp +++ b/lib/CodeGen/CGExprConstant.cpp @@ -1314,8 +1314,14 @@ llvm::Constant *CodeGenModule::EmitConstantValue(const APValue &Value, // Convert to the appropriate type; this could be an lvalue for // an integer. - if (isa<llvm::PointerType>(DestTy)) + if (isa<llvm::PointerType>(DestTy)) { + // Convert the integer to a pointer-sized integer before converting it + // to a pointer. + C = llvm::ConstantExpr::getIntegerCast( + C, getDataLayout().getIntPtrType(DestTy), + /*isSigned=*/false); return llvm::ConstantExpr::getIntToPtr(C, DestTy); + } // If the types don't match this should only be a truncate. if (C->getType() != DestTy) diff --git a/test/CodeGen/const-init.c b/test/CodeGen/const-init.c index 9434f1d1b24b3a1b8b74b29d330155e8ceef5fae..3fd231b630ee7d1286770544c79c4599b674bcef 100644 --- a/test/CodeGen/const-init.c +++ b/test/CodeGen/const-init.c @@ -84,7 +84,7 @@ struct g13_s0 g13[] = { { (long) &g12_tmp } }; -// CHECK: @g14 = global i8* inttoptr (i64 100 to i8*) +// CHECK: @g14 = global i8* inttoptr (i32 100 to i8*) void *g14 = (void*) 100; // CHECK: @g15 = global i32 -1