r232496 - Revert r232454 and r232456: "Fix the LLVM type used when lowering initializer list reference temporaries to global variables."
Hans Wennborg
hans at hanshq.net
Tue Mar 17 09:38:58 PDT 2015
Author: hans
Date: Tue Mar 17 11:38:58 2015
New Revision: 232496
URL: http://llvm.org/viewvc/llvm-project?rev=232496&view=rev
Log:
Revert r232454 and r232456: "Fix the LLVM type used when lowering initializer list reference temporaries to global variables."
This caused PR22940.
Modified:
cfe/trunk/lib/CodeGen/CGExpr.cpp
cfe/trunk/test/CodeGenCXX/cxx0x-initializer-stdinitializerlist.cpp
Modified: cfe/trunk/lib/CodeGen/CGExpr.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CGExpr.cpp?rev=232496&r1=232495&r2=232496&view=diff
==============================================================================
--- cfe/trunk/lib/CodeGen/CGExpr.cpp (original)
+++ cfe/trunk/lib/CodeGen/CGExpr.cpp Tue Mar 17 11:38:58 2015
@@ -316,16 +316,13 @@ createReferenceTemporary(CodeGenFunction
GV->setAlignment(
CGF.getContext().getTypeAlignInChars(M->getType()).getQuantity());
// FIXME: Should we put the new global into a COMDAT?
- return llvm::ConstantExpr::getBitCast(
- GV, CGF.ConvertTypeForMem(Inner->getType())->getPointerTo());
+ return GV;
}
return CGF.CreateMemTemp(Inner->getType(), "ref.tmp");
case SD_Thread:
case SD_Static:
- return llvm::ConstantExpr::getBitCast(
- CGF.CGM.GetAddrOfGlobalTemporary(M, Inner),
- CGF.ConvertTypeForMem(Inner->getType())->getPointerTo());
+ return CGF.CGM.GetAddrOfGlobalTemporary(M, Inner);
case SD_Dynamic:
llvm_unreachable("temporary can't have dynamic storage duration");
Modified: cfe/trunk/test/CodeGenCXX/cxx0x-initializer-stdinitializerlist.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGenCXX/cxx0x-initializer-stdinitializerlist.cpp?rev=232496&r1=232495&r2=232496&view=diff
==============================================================================
--- cfe/trunk/test/CodeGenCXX/cxx0x-initializer-stdinitializerlist.cpp (original)
+++ cfe/trunk/test/CodeGenCXX/cxx0x-initializer-stdinitializerlist.cpp Tue Mar 17 11:38:58 2015
@@ -482,27 +482,3 @@ namespace ConstExpr {
f({C(1), C(2), C(3)});
}
}
-
-namespace B19773010 {
- template <class T1, class T2> struct pair {
- T1 first;
- T2 second;
- constexpr pair(T1 a, T2 b) : first(a), second(b) {}
- };
-
- enum E { ENUM_CONSTANT };
- struct testcase {
- testcase(std::initializer_list<pair<const char *, E>>);
- };
- void f1() {
- // CHECK-LABEL: @_ZN9B197730102f1Ev
- testcase a{{"", ENUM_CONSTANT}};
- // CHECK: store %"struct.B19773010::pair"* getelementptr inbounds ([1 x %"struct.B19773010::pair"], [1 x %"struct.B19773010::pair"]* bitcast ([1 x { i8*, i32 }]* @.ref.tmp{{.*}} to [1 x %"struct.B19773010::pair"]*), i64 0, i64 0), %"struct.B19773010::pair"** %{{.*}}, align 8
- }
- void f2() {
- // CHECK-LABEL: @_ZN9B197730102f2Ev
- // CHECK: store %"struct.B19773010::pair"* getelementptr inbounds ([1 x %"struct.B19773010::pair"], [1 x %"struct.B19773010::pair"]* bitcast ([1 x { i8*, i32 }]* @_ZGRZN9B197730102f2EvE1p_ to [1 x %"struct.B19773010::pair"]*), i64 0, i64 0), %"struct.B19773010::pair"** getelementptr inbounds ([2 x %"class.std::initializer_list.10"], [2 x %"class.std::initializer_list.10"]* @_ZZN9B197730102f2EvE1p, i64 0, i64 1, i32 0), align 8
- static std::initializer_list<pair<const char *, E>> a, p[2] =
- {a, {{"", ENUM_CONSTANT}}};
- }
-}
More information about the cfe-commits
mailing list