From: Matt Arsenault Date: Thu, 17 Apr 2014 17:45:37 +0000 (+0000) Subject: Bug 18567: Fix constantexpr pointer casts with address spaces. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=de001b34b094cc6a6b6fa35becd8ef726b6c906c;p=clang Bug 18567: Fix constantexpr pointer casts with address spaces. Getting a pointer into a struct at a non-zero offset would try to use the default address space. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@206478 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGExprConstant.cpp b/lib/CodeGen/CGExprConstant.cpp index 82382ddf68..bce0475cbc 100644 --- a/lib/CodeGen/CGExprConstant.cpp +++ b/lib/CodeGen/CGExprConstant.cpp @@ -1063,7 +1063,9 @@ llvm::Constant *CodeGenModule::EmitConstantValue(const APValue &Value, // Apply offset if necessary. if (!Offset->isNullValue()) { - llvm::Constant *Casted = llvm::ConstantExpr::getBitCast(C, Int8PtrTy); + unsigned AS = C->getType()->getPointerAddressSpace(); + llvm::Type *CharPtrTy = Int8Ty->getPointerTo(AS); + llvm::Constant *Casted = llvm::ConstantExpr::getBitCast(C, CharPtrTy); Casted = llvm::ConstantExpr::getGetElementPtr(Casted, Offset); C = llvm::ConstantExpr::getPointerCast(Casted, C->getType()); } diff --git a/test/CodeGenOpenCL/address-space-constant-initializers.cl b/test/CodeGenOpenCL/address-space-constant-initializers.cl new file mode 100644 index 0000000000..ae8cedc1ca --- /dev/null +++ b/test/CodeGenOpenCL/address-space-constant-initializers.cl @@ -0,0 +1,20 @@ +// RUN: %clang_cc1 %s -ffake-address-space-map -emit-llvm -o - | FileCheck %s + +typedef struct { + int i; + float f; // At non-zero offset. +} ArrayStruct; + +__constant ArrayStruct constant_array_struct = { 0, 0.0f }; + +typedef struct { + __constant float* constant_float_ptr; +} ConstantArrayPointerStruct; + +// CHECK: %struct.ConstantArrayPointerStruct = type { float addrspace(3)* } +// CHECK: addrspace(3) global %struct.ConstantArrayPointerStruct { float addrspace(3)* bitcast (i8 addrspace(3)* getelementptr (i8 addrspace(3)* bitcast (%struct.ArrayStruct addrspace(3)* @constant_array_struct to i8 addrspace(3)*), i64 4) to float addrspace(3)*) } +// Bug 18567 +__constant ConstantArrayPointerStruct constant_array_pointer_struct = { + &constant_array_struct.f +}; +