blob: a9ef0c876faed33c043ff427f2d7789c7405ba27 [file] [log] [blame]
Anders Carlsson610ee712008-01-26 01:36:00 +00001//===--- CGExprConstant.cpp - Emit LLVM Code from Constant Expressions ----===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This contains code to emit Constant Expr nodes as LLVM code.
11//
12//===----------------------------------------------------------------------===//
13
14#include "CodeGenFunction.h"
15#include "CodeGenModule.h"
John McCall5d865c322010-08-31 07:33:07 +000016#include "CGCXXABI.h"
Daniel Dunbar89da6ad2008-08-13 00:59:25 +000017#include "CGObjCRuntime.h"
Daniel Dunbar072d0bb2010-03-30 22:26:10 +000018#include "CGRecordLayout.h"
Chris Lattnere50e9012008-10-06 05:59:01 +000019#include "clang/AST/APValue.h"
Daniel Dunbarad319a72008-08-11 05:00:27 +000020#include "clang/AST/ASTContext.h"
Anders Carlssone1d5ca52009-07-24 15:20:52 +000021#include "clang/AST/RecordLayout.h"
Daniel Dunbarad319a72008-08-11 05:00:27 +000022#include "clang/AST/StmtVisitor.h"
Chris Lattner15ba9492009-06-14 01:54:56 +000023#include "clang/Basic/Builtins.h"
Anders Carlsson610ee712008-01-26 01:36:00 +000024#include "llvm/Constants.h"
25#include "llvm/Function.h"
26#include "llvm/GlobalVariable.h"
Eli Friedmana2eaffc2008-05-30 10:24:46 +000027#include "llvm/Target/TargetData.h"
Anders Carlsson610ee712008-01-26 01:36:00 +000028using namespace clang;
29using namespace CodeGen;
30
Chris Lattnercfa3e7a2010-04-13 17:45:57 +000031//===----------------------------------------------------------------------===//
32// ConstStructBuilder
33//===----------------------------------------------------------------------===//
34
35namespace {
Benjamin Kramer337e3a52009-11-28 19:45:26 +000036class ConstStructBuilder {
Anders Carlssone1d5ca52009-07-24 15:20:52 +000037 CodeGenModule &CGM;
38 CodeGenFunction *CGF;
39
Mike Stump11289f42009-09-09 15:08:12 +000040 bool Packed;
Ken Dyckdb205d12011-03-17 01:33:18 +000041 CharUnits NextFieldOffsetInChars;
Anders Carlsson39e3eb12009-10-02 02:15:20 +000042 unsigned LLVMStructAlignment;
Anders Carlssone1d5ca52009-07-24 15:20:52 +000043 std::vector<llvm::Constant *> Elements;
Chris Lattnercfa3e7a2010-04-13 17:45:57 +000044public:
45 static llvm::Constant *BuildStruct(CodeGenModule &CGM, CodeGenFunction *CGF,
46 InitListExpr *ILE);
47
48private:
Anders Carlssone1d5ca52009-07-24 15:20:52 +000049 ConstStructBuilder(CodeGenModule &CGM, CodeGenFunction *CGF)
Ken Dyckdb205d12011-03-17 01:33:18 +000050 : CGM(CGM), CGF(CGF), Packed(false),
51 NextFieldOffsetInChars(CharUnits::Zero()),
Anders Carlsson39e3eb12009-10-02 02:15:20 +000052 LLVMStructAlignment(1) { }
Anders Carlssone1d5ca52009-07-24 15:20:52 +000053
Mike Stump11289f42009-09-09 15:08:12 +000054 bool AppendField(const FieldDecl *Field, uint64_t FieldOffset,
Chris Lattnerff0e2a32010-04-13 18:16:19 +000055 llvm::Constant *InitExpr);
Mike Stump11289f42009-09-09 15:08:12 +000056
Chris Lattner9a3459f2010-07-05 17:04:23 +000057 void AppendBitField(const FieldDecl *Field, uint64_t FieldOffset,
58 llvm::ConstantInt *InitExpr);
Mike Stump11289f42009-09-09 15:08:12 +000059
Ken Dyck30a87e32011-03-11 23:42:54 +000060 void AppendPadding(CharUnits PadSize);
Mike Stump11289f42009-09-09 15:08:12 +000061
Ken Dyck327b77a2011-03-11 02:17:05 +000062 void AppendTailPadding(CharUnits RecordSize);
Anders Carlssonba4c6d12009-07-27 01:23:51 +000063
Chris Lattnercfa3e7a2010-04-13 17:45:57 +000064 void ConvertStructToPacked();
Anders Carlsson39e3eb12009-10-02 02:15:20 +000065
Chris Lattnercfa3e7a2010-04-13 17:45:57 +000066 bool Build(InitListExpr *ILE);
Mike Stump11289f42009-09-09 15:08:12 +000067
Anders Carlssone1d5ca52009-07-24 15:20:52 +000068 unsigned getAlignment(const llvm::Constant *C) const {
Chris Lattnercfa3e7a2010-04-13 17:45:57 +000069 if (Packed) return 1;
Anders Carlssone1d5ca52009-07-24 15:20:52 +000070 return CGM.getTargetData().getABITypeAlignment(C->getType());
71 }
Mike Stump11289f42009-09-09 15:08:12 +000072
Ken Dyck33fa9ee2011-03-18 01:12:13 +000073 CharUnits getSizeInChars(const llvm::Constant *C) const {
74 return CharUnits::fromQuantity(
75 CGM.getTargetData().getTypeAllocSize(C->getType()));
Anders Carlssone1d5ca52009-07-24 15:20:52 +000076 }
Anders Carlssone1d5ca52009-07-24 15:20:52 +000077};
Mike Stump11289f42009-09-09 15:08:12 +000078
Chris Lattnercfa3e7a2010-04-13 17:45:57 +000079bool ConstStructBuilder::
Chris Lattnerff0e2a32010-04-13 18:16:19 +000080AppendField(const FieldDecl *Field, uint64_t FieldOffset,
81 llvm::Constant *InitCst) {
Ken Dyck1c80fd12011-03-15 01:09:02 +000082
83 const ASTContext &Context = CGM.getContext();
84
85 CharUnits FieldOffsetInChars = Context.toCharUnitsFromBits(FieldOffset);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +000086
Ken Dyckdb205d12011-03-17 01:33:18 +000087 assert(NextFieldOffsetInChars <= FieldOffsetInChars
Chris Lattnercfa3e7a2010-04-13 17:45:57 +000088 && "Field offset mismatch!");
89
Chris Lattnerff0e2a32010-04-13 18:16:19 +000090 unsigned FieldAlignment = getAlignment(InitCst);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +000091
92 // Round up the field offset to the alignment of the field type.
Ken Dyckdb205d12011-03-17 01:33:18 +000093 CharUnits AlignedNextFieldOffsetInChars =
94 NextFieldOffsetInChars.RoundUpToAlignment(
95 CharUnits::fromQuantity(FieldAlignment));
Chris Lattnercfa3e7a2010-04-13 17:45:57 +000096
Ken Dyckdb205d12011-03-17 01:33:18 +000097 if (AlignedNextFieldOffsetInChars > FieldOffsetInChars) {
Chris Lattnercfa3e7a2010-04-13 17:45:57 +000098 assert(!Packed && "Alignment is wrong even with a packed struct!");
99
100 // Convert the struct to a packed struct.
101 ConvertStructToPacked();
102
Ken Dyckdb205d12011-03-17 01:33:18 +0000103 AlignedNextFieldOffsetInChars = NextFieldOffsetInChars;
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000104 }
105
Ken Dyckdb205d12011-03-17 01:33:18 +0000106 if (AlignedNextFieldOffsetInChars < FieldOffsetInChars) {
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000107 // We need to append padding.
Ken Dyck30a87e32011-03-11 23:42:54 +0000108 AppendPadding(
Ken Dyckdb205d12011-03-17 01:33:18 +0000109 FieldOffsetInChars - NextFieldOffsetInChars);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000110
Ken Dyckdb205d12011-03-17 01:33:18 +0000111 assert(NextFieldOffsetInChars == FieldOffsetInChars &&
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000112 "Did not add enough padding!");
113
Ken Dyckdb205d12011-03-17 01:33:18 +0000114 AlignedNextFieldOffsetInChars = NextFieldOffsetInChars;
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000115 }
116
117 // Add the field.
Chris Lattnerff0e2a32010-04-13 18:16:19 +0000118 Elements.push_back(InitCst);
Ken Dyckdb205d12011-03-17 01:33:18 +0000119 NextFieldOffsetInChars = AlignedNextFieldOffsetInChars +
Ken Dyck33fa9ee2011-03-18 01:12:13 +0000120 getSizeInChars(InitCst);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000121
122 if (Packed)
123 assert(LLVMStructAlignment == 1 && "Packed struct not byte-aligned!");
124 else
125 LLVMStructAlignment = std::max(LLVMStructAlignment, FieldAlignment);
126
127 return true;
128}
129
Chris Lattner9a3459f2010-07-05 17:04:23 +0000130void ConstStructBuilder::AppendBitField(const FieldDecl *Field,
131 uint64_t FieldOffset,
132 llvm::ConstantInt *CI) {
Ken Dycka862d952011-03-12 12:03:11 +0000133 const ASTContext &Context = CGM.getContext();
Ken Dyckdb205d12011-03-17 01:33:18 +0000134 uint64_t NextFieldOffsetInBits = Context.toBits(NextFieldOffsetInChars);
135 if (FieldOffset > NextFieldOffsetInBits) {
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000136 // We need to add padding.
Ken Dycka862d952011-03-12 12:03:11 +0000137 CharUnits PadSize = Context.toCharUnitsFromBits(
Ken Dyckdb205d12011-03-17 01:33:18 +0000138 llvm::RoundUpToAlignment(FieldOffset - NextFieldOffsetInBits,
Ken Dycka862d952011-03-12 12:03:11 +0000139 Context.Target.getCharAlign()));
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000140
Ken Dycka862d952011-03-12 12:03:11 +0000141 AppendPadding(PadSize);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000142 }
143
144 uint64_t FieldSize =
Ken Dycka862d952011-03-12 12:03:11 +0000145 Field->getBitWidth()->EvaluateAsInt(Context).getZExtValue();
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000146
147 llvm::APInt FieldValue = CI->getValue();
148
149 // Promote the size of FieldValue if necessary
150 // FIXME: This should never occur, but currently it can because initializer
151 // constants are cast to bool, and because clang is not enforcing bitfield
152 // width limits.
153 if (FieldSize > FieldValue.getBitWidth())
Jay Foad6d4db0c2010-12-07 08:25:34 +0000154 FieldValue = FieldValue.zext(FieldSize);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000155
156 // Truncate the size of FieldValue to the bit field size.
157 if (FieldSize < FieldValue.getBitWidth())
Jay Foad6d4db0c2010-12-07 08:25:34 +0000158 FieldValue = FieldValue.trunc(FieldSize);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000159
Ken Dyckdb205d12011-03-17 01:33:18 +0000160 NextFieldOffsetInBits = Context.toBits(NextFieldOffsetInChars);
161 if (FieldOffset < NextFieldOffsetInBits) {
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000162 // Either part of the field or the entire field can go into the previous
163 // byte.
164 assert(!Elements.empty() && "Elements can't be empty!");
165
Ken Dyckdb205d12011-03-17 01:33:18 +0000166 unsigned BitsInPreviousByte = NextFieldOffsetInBits - FieldOffset;
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000167
168 bool FitsCompletelyInPreviousByte =
169 BitsInPreviousByte >= FieldValue.getBitWidth();
170
171 llvm::APInt Tmp = FieldValue;
172
173 if (!FitsCompletelyInPreviousByte) {
174 unsigned NewFieldWidth = FieldSize - BitsInPreviousByte;
175
176 if (CGM.getTargetData().isBigEndian()) {
177 Tmp = Tmp.lshr(NewFieldWidth);
Jay Foad6d4db0c2010-12-07 08:25:34 +0000178 Tmp = Tmp.trunc(BitsInPreviousByte);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000179
180 // We want the remaining high bits.
Jay Foad6d4db0c2010-12-07 08:25:34 +0000181 FieldValue = FieldValue.trunc(NewFieldWidth);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000182 } else {
Jay Foad6d4db0c2010-12-07 08:25:34 +0000183 Tmp = Tmp.trunc(BitsInPreviousByte);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000184
185 // We want the remaining low bits.
186 FieldValue = FieldValue.lshr(BitsInPreviousByte);
Jay Foad6d4db0c2010-12-07 08:25:34 +0000187 FieldValue = FieldValue.trunc(NewFieldWidth);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000188 }
189 }
190
Jay Foad6d4db0c2010-12-07 08:25:34 +0000191 Tmp = Tmp.zext(8);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000192 if (CGM.getTargetData().isBigEndian()) {
193 if (FitsCompletelyInPreviousByte)
194 Tmp = Tmp.shl(BitsInPreviousByte - FieldValue.getBitWidth());
195 } else {
196 Tmp = Tmp.shl(8 - BitsInPreviousByte);
197 }
198
Chris Lattner53b479f2010-07-05 18:03:30 +0000199 // 'or' in the bits that go into the previous byte.
200 llvm::Value *LastElt = Elements.back();
201 if (llvm::ConstantInt *Val = dyn_cast<llvm::ConstantInt>(LastElt))
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000202 Tmp |= Val->getValue();
Chris Lattner53b479f2010-07-05 18:03:30 +0000203 else {
204 assert(isa<llvm::UndefValue>(LastElt));
205 // If there is an undef field that we're adding to, it can either be a
206 // scalar undef (in which case, we just replace it with our field) or it
207 // is an array. If it is an array, we have to pull one byte off the
208 // array so that the other undef bytes stay around.
209 if (!isa<llvm::IntegerType>(LastElt->getType())) {
210 // The undef padding will be a multibyte array, create a new smaller
211 // padding and then an hole for our i8 to get plopped into.
212 assert(isa<llvm::ArrayType>(LastElt->getType()) &&
213 "Expected array padding of undefs");
214 const llvm::ArrayType *AT = cast<llvm::ArrayType>(LastElt->getType());
215 assert(AT->getElementType()->isIntegerTy(8) &&
216 AT->getNumElements() != 0 &&
217 "Expected non-empty array padding of undefs");
218
219 // Remove the padding array.
Ken Dyckdb205d12011-03-17 01:33:18 +0000220 NextFieldOffsetInChars -= CharUnits::fromQuantity(AT->getNumElements());
Chris Lattner53b479f2010-07-05 18:03:30 +0000221 Elements.pop_back();
222
223 // Add the padding back in two chunks.
Ken Dyck30a87e32011-03-11 23:42:54 +0000224 AppendPadding(CharUnits::fromQuantity(AT->getNumElements()-1));
225 AppendPadding(CharUnits::One());
Chris Lattner53b479f2010-07-05 18:03:30 +0000226 assert(isa<llvm::UndefValue>(Elements.back()) &&
227 Elements.back()->getType()->isIntegerTy(8) &&
228 "Padding addition didn't work right");
229 }
230 }
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000231
232 Elements.back() = llvm::ConstantInt::get(CGM.getLLVMContext(), Tmp);
233
234 if (FitsCompletelyInPreviousByte)
Chris Lattner9a3459f2010-07-05 17:04:23 +0000235 return;
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000236 }
237
238 while (FieldValue.getBitWidth() > 8) {
239 llvm::APInt Tmp;
240
241 if (CGM.getTargetData().isBigEndian()) {
242 // We want the high bits.
Chris Lattnerfb59c7c2011-02-17 22:09:58 +0000243 Tmp = FieldValue.lshr(FieldValue.getBitWidth() - 8).trunc(8);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000244 } else {
245 // We want the low bits.
Jay Foad6d4db0c2010-12-07 08:25:34 +0000246 Tmp = FieldValue.trunc(8);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000247
248 FieldValue = FieldValue.lshr(8);
249 }
250
251 Elements.push_back(llvm::ConstantInt::get(CGM.getLLVMContext(), Tmp));
Ken Dyckdb205d12011-03-17 01:33:18 +0000252 NextFieldOffsetInChars += CharUnits::One();
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000253
Jay Foad6d4db0c2010-12-07 08:25:34 +0000254 FieldValue = FieldValue.trunc(FieldValue.getBitWidth() - 8);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000255 }
256
257 assert(FieldValue.getBitWidth() > 0 &&
258 "Should have at least one bit left!");
259 assert(FieldValue.getBitWidth() <= 8 &&
260 "Should not have more than a byte left!");
261
262 if (FieldValue.getBitWidth() < 8) {
263 if (CGM.getTargetData().isBigEndian()) {
264 unsigned BitWidth = FieldValue.getBitWidth();
265
Jay Foad6d4db0c2010-12-07 08:25:34 +0000266 FieldValue = FieldValue.zext(8) << (8 - BitWidth);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000267 } else
Jay Foad6d4db0c2010-12-07 08:25:34 +0000268 FieldValue = FieldValue.zext(8);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000269 }
270
271 // Append the last element.
272 Elements.push_back(llvm::ConstantInt::get(CGM.getLLVMContext(),
273 FieldValue));
Ken Dyckdb205d12011-03-17 01:33:18 +0000274 NextFieldOffsetInChars += CharUnits::One();
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000275}
276
Ken Dyck30a87e32011-03-11 23:42:54 +0000277void ConstStructBuilder::AppendPadding(CharUnits PadSize) {
278 if (PadSize.isZero())
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000279 return;
280
281 const llvm::Type *Ty = llvm::Type::getInt8Ty(CGM.getLLVMContext());
Ken Dyck30a87e32011-03-11 23:42:54 +0000282 if (PadSize > CharUnits::One())
283 Ty = llvm::ArrayType::get(Ty, PadSize.getQuantity());
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000284
Nuno Lopes5863c992010-04-16 20:56:35 +0000285 llvm::Constant *C = llvm::UndefValue::get(Ty);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000286 Elements.push_back(C);
287 assert(getAlignment(C) == 1 && "Padding must have 1 byte alignment!");
288
Ken Dyck33fa9ee2011-03-18 01:12:13 +0000289 NextFieldOffsetInChars += getSizeInChars(C);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000290}
291
Ken Dyck327b77a2011-03-11 02:17:05 +0000292void ConstStructBuilder::AppendTailPadding(CharUnits RecordSize) {
Ken Dyckdb205d12011-03-17 01:33:18 +0000293 assert(NextFieldOffsetInChars <= RecordSize &&
Ken Dyck327b77a2011-03-11 02:17:05 +0000294 "Size mismatch!");
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000295
Ken Dyckdb205d12011-03-17 01:33:18 +0000296 AppendPadding(RecordSize - NextFieldOffsetInChars);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000297}
298
299void ConstStructBuilder::ConvertStructToPacked() {
300 std::vector<llvm::Constant *> PackedElements;
Ken Dyck4e54dca2011-03-18 00:55:06 +0000301 CharUnits ElementOffsetInChars = CharUnits::Zero();
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000302
303 for (unsigned i = 0, e = Elements.size(); i != e; ++i) {
304 llvm::Constant *C = Elements[i];
305
306 unsigned ElementAlign =
307 CGM.getTargetData().getABITypeAlignment(C->getType());
Ken Dyck4e54dca2011-03-18 00:55:06 +0000308 CharUnits AlignedElementOffsetInChars =
309 ElementOffsetInChars.RoundUpToAlignment(
310 CharUnits::fromQuantity(ElementAlign));
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000311
Ken Dyck4e54dca2011-03-18 00:55:06 +0000312 if (AlignedElementOffsetInChars > ElementOffsetInChars) {
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000313 // We need some padding.
Ken Dyck4e54dca2011-03-18 00:55:06 +0000314 CharUnits NumChars =
315 AlignedElementOffsetInChars - ElementOffsetInChars;
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000316
317 const llvm::Type *Ty = llvm::Type::getInt8Ty(CGM.getLLVMContext());
Ken Dyck4e54dca2011-03-18 00:55:06 +0000318 if (NumChars > CharUnits::One())
319 Ty = llvm::ArrayType::get(Ty, NumChars.getQuantity());
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000320
Nuno Lopes5863c992010-04-16 20:56:35 +0000321 llvm::Constant *Padding = llvm::UndefValue::get(Ty);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000322 PackedElements.push_back(Padding);
Ken Dyck33fa9ee2011-03-18 01:12:13 +0000323 ElementOffsetInChars += getSizeInChars(Padding);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000324 }
325
326 PackedElements.push_back(C);
Ken Dyck33fa9ee2011-03-18 01:12:13 +0000327 ElementOffsetInChars += getSizeInChars(C);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000328 }
329
Ken Dyck4e54dca2011-03-18 00:55:06 +0000330 assert(ElementOffsetInChars == NextFieldOffsetInChars &&
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000331 "Packing the struct changed its size!");
332
333 Elements = PackedElements;
334 LLVMStructAlignment = 1;
335 Packed = true;
336}
337
338bool ConstStructBuilder::Build(InitListExpr *ILE) {
339 RecordDecl *RD = ILE->getType()->getAs<RecordType>()->getDecl();
340 const ASTRecordLayout &Layout = CGM.getContext().getASTRecordLayout(RD);
341
342 unsigned FieldNo = 0;
343 unsigned ElementNo = 0;
344 for (RecordDecl::field_iterator Field = RD->field_begin(),
Chris Lattnerff0e2a32010-04-13 18:16:19 +0000345 FieldEnd = RD->field_end(); Field != FieldEnd; ++Field, ++FieldNo) {
346
347 // If this is a union, skip all the fields that aren't being initialized.
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000348 if (RD->isUnion() && ILE->getInitializedFieldInUnion() != *Field)
349 continue;
350
Chris Lattnerff0e2a32010-04-13 18:16:19 +0000351 // Don't emit anonymous bitfields, they just affect layout.
352 if (Field->isBitField() && !Field->getIdentifier())
353 continue;
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000354
Chris Lattnerff0e2a32010-04-13 18:16:19 +0000355 // Get the initializer. A struct can include fields without initializers,
356 // we just use explicit null values for them.
357 llvm::Constant *EltInit;
358 if (ElementNo < ILE->getNumInits())
359 EltInit = CGM.EmitConstantExpr(ILE->getInit(ElementNo++),
360 Field->getType(), CGF);
361 else
362 EltInit = CGM.EmitNullConstant(Field->getType());
Eli Friedman3ee10222010-07-17 23:55:01 +0000363
364 if (!EltInit)
365 return false;
Chris Lattnerff0e2a32010-04-13 18:16:19 +0000366
367 if (!Field->isBitField()) {
368 // Handle non-bitfield members.
369 if (!AppendField(*Field, Layout.getFieldOffset(FieldNo), EltInit))
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000370 return false;
371 } else {
Chris Lattnerff0e2a32010-04-13 18:16:19 +0000372 // Otherwise we have a bitfield.
Chris Lattner9a3459f2010-07-05 17:04:23 +0000373 AppendBitField(*Field, Layout.getFieldOffset(FieldNo),
374 cast<llvm::ConstantInt>(EltInit));
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000375 }
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000376 }
377
Ken Dyckdb205d12011-03-17 01:33:18 +0000378 CharUnits LayoutSizeInChars = Layout.getSize();
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000379
Ken Dyckdb205d12011-03-17 01:33:18 +0000380 if (NextFieldOffsetInChars > LayoutSizeInChars) {
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000381 // If the struct is bigger than the size of the record type,
382 // we must have a flexible array member at the end.
383 assert(RD->hasFlexibleArrayMember() &&
384 "Must have flexible array member if struct is bigger than type!");
385
386 // No tail padding is necessary.
387 return true;
388 }
389
Ken Dyckdb205d12011-03-17 01:33:18 +0000390 CharUnits LLVMSizeInChars =
391 NextFieldOffsetInChars.RoundUpToAlignment(
392 CharUnits::fromQuantity(LLVMStructAlignment));
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000393
394 // Check if we need to convert the struct to a packed struct.
Ken Dyckdb205d12011-03-17 01:33:18 +0000395 if (NextFieldOffsetInChars <= LayoutSizeInChars &&
396 LLVMSizeInChars > LayoutSizeInChars) {
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000397 assert(!Packed && "Size mismatch!");
398
399 ConvertStructToPacked();
Ken Dyckdb205d12011-03-17 01:33:18 +0000400 assert(NextFieldOffsetInChars <= LayoutSizeInChars &&
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000401 "Converting to packed did not help!");
402 }
403
404 // Append tail padding if necessary.
Ken Dyckdb205d12011-03-17 01:33:18 +0000405 AppendTailPadding(LayoutSizeInChars);
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000406
Ken Dyckdb205d12011-03-17 01:33:18 +0000407 assert(LayoutSizeInChars == NextFieldOffsetInChars &&
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000408 "Tail padding mismatch!");
409
410 return true;
411}
412
413llvm::Constant *ConstStructBuilder::
414 BuildStruct(CodeGenModule &CGM, CodeGenFunction *CGF, InitListExpr *ILE) {
415 ConstStructBuilder Builder(CGM, CGF);
416
417 if (!Builder.Build(ILE))
418 return 0;
419
420 llvm::Constant *Result =
421 llvm::ConstantStruct::get(CGM.getLLVMContext(),
422 Builder.Elements, Builder.Packed);
423
Ken Dyck33fa9ee2011-03-18 01:12:13 +0000424 assert(Builder.NextFieldOffsetInChars.RoundUpToAlignment(
425 CharUnits::fromQuantity(Builder.getAlignment(Result))) ==
426 Builder.getSizeInChars(Result) && "Size mismatch!");
Chris Lattnercfa3e7a2010-04-13 17:45:57 +0000427
428 return Result;
429}
430
431
432//===----------------------------------------------------------------------===//
433// ConstExprEmitter
434//===----------------------------------------------------------------------===//
435
Benjamin Kramer337e3a52009-11-28 19:45:26 +0000436class ConstExprEmitter :
Anders Carlsson8a88c382008-01-26 04:30:23 +0000437 public StmtVisitor<ConstExprEmitter, llvm::Constant*> {
Anders Carlsson610ee712008-01-26 01:36:00 +0000438 CodeGenModule &CGM;
Lauro Ramos Venancio01a72ff2008-02-26 21:41:45 +0000439 CodeGenFunction *CGF;
Owen Anderson170229f2009-07-14 23:10:40 +0000440 llvm::LLVMContext &VMContext;
Anders Carlsson610ee712008-01-26 01:36:00 +0000441public:
Lauro Ramos Venancio01a72ff2008-02-26 21:41:45 +0000442 ConstExprEmitter(CodeGenModule &cgm, CodeGenFunction *cgf)
Owen Anderson170229f2009-07-14 23:10:40 +0000443 : CGM(cgm), CGF(cgf), VMContext(cgm.getLLVMContext()) {
Anders Carlsson610ee712008-01-26 01:36:00 +0000444 }
Mike Stump11289f42009-09-09 15:08:12 +0000445
Anders Carlsson610ee712008-01-26 01:36:00 +0000446 //===--------------------------------------------------------------------===//
447 // Visitor Methods
448 //===--------------------------------------------------------------------===//
Mike Stump11289f42009-09-09 15:08:12 +0000449
Anders Carlsson610ee712008-01-26 01:36:00 +0000450 llvm::Constant *VisitStmt(Stmt *S) {
Anders Carlsson24b14472009-03-03 16:43:34 +0000451 return 0;
Anders Carlsson610ee712008-01-26 01:36:00 +0000452 }
Mike Stump11289f42009-09-09 15:08:12 +0000453
454 llvm::Constant *VisitParenExpr(ParenExpr *PE) {
455 return Visit(PE->getSubExpr());
Anders Carlsson610ee712008-01-26 01:36:00 +0000456 }
Mike Stump11289f42009-09-09 15:08:12 +0000457
Anders Carlsson610ee712008-01-26 01:36:00 +0000458 llvm::Constant *VisitCompoundLiteralExpr(CompoundLiteralExpr *E) {
459 return Visit(E->getInitializer());
460 }
John McCallf3a88602011-02-03 08:15:49 +0000461
Anders Carlsson128a5d52009-10-03 15:02:02 +0000462 llvm::Constant *VisitUnaryAddrOf(UnaryOperator *E) {
John McCallf3a88602011-02-03 08:15:49 +0000463 if (E->getType()->isMemberPointerType())
464 return CGM.getMemberPointerConstant(E);
Anders Carlsson259688c2010-02-02 03:37:46 +0000465
Anders Carlsson128a5d52009-10-03 15:02:02 +0000466 return 0;
467 }
468
Chris Lattner3eb172a2009-10-13 07:14:16 +0000469 llvm::Constant *VisitBinSub(BinaryOperator *E) {
470 // This must be a pointer/pointer subtraction. This only happens for
471 // address of label.
472 if (!isa<AddrLabelExpr>(E->getLHS()->IgnoreParenNoopCasts(CGM.getContext())) ||
473 !isa<AddrLabelExpr>(E->getRHS()->IgnoreParenNoopCasts(CGM.getContext())))
474 return 0;
475
476 llvm::Constant *LHS = CGM.EmitConstantExpr(E->getLHS(),
477 E->getLHS()->getType(), CGF);
478 llvm::Constant *RHS = CGM.EmitConstantExpr(E->getRHS(),
479 E->getRHS()->getType(), CGF);
480
481 const llvm::Type *ResultType = ConvertType(E->getType());
482 LHS = llvm::ConstantExpr::getPtrToInt(LHS, ResultType);
483 RHS = llvm::ConstantExpr::getPtrToInt(RHS, ResultType);
484
485 // No need to divide by element size, since addr of label is always void*,
486 // which has size 1 in GNUish.
487 return llvm::ConstantExpr::getSub(LHS, RHS);
488 }
489
Argyrios Kyrtzidis3bab3d22008-08-18 23:01:59 +0000490 llvm::Constant *VisitCastExpr(CastExpr* E) {
John McCall2de87f62011-03-15 21:17:48 +0000491 Expr *subExpr = E->getSubExpr();
492 llvm::Constant *C = CGM.EmitConstantExpr(subExpr, subExpr->getType(), CGF);
493 if (!C) return 0;
494
495 const llvm::Type *destType = ConvertType(E->getType());
496
Anders Carlsson3b0c5dc2009-08-22 23:54:44 +0000497 switch (E->getCastKind()) {
John McCalle3027922010-08-25 11:45:40 +0000498 case CK_ToUnion: {
Anders Carlsson3b0c5dc2009-08-22 23:54:44 +0000499 // GCC cast to union extension
500 assert(E->getType()->isUnionType() &&
501 "Destination type is not union type!");
Mike Stump11289f42009-09-09 15:08:12 +0000502
Anders Carlssond65ab042009-07-31 21:38:39 +0000503 // Build a struct with the union sub-element as the first member,
504 // and padded to the appropriate size
505 std::vector<llvm::Constant*> Elts;
506 std::vector<const llvm::Type*> Types;
507 Elts.push_back(C);
508 Types.push_back(C->getType());
509 unsigned CurSize = CGM.getTargetData().getTypeAllocSize(C->getType());
John McCall2de87f62011-03-15 21:17:48 +0000510 unsigned TotalSize = CGM.getTargetData().getTypeAllocSize(destType);
Mike Stump11289f42009-09-09 15:08:12 +0000511
Anders Carlssond65ab042009-07-31 21:38:39 +0000512 assert(CurSize <= TotalSize && "Union size mismatch!");
513 if (unsigned NumPadBytes = TotalSize - CurSize) {
Owen Anderson41a75022009-08-13 21:57:51 +0000514 const llvm::Type *Ty = llvm::Type::getInt8Ty(VMContext);
Anders Carlssond65ab042009-07-31 21:38:39 +0000515 if (NumPadBytes > 1)
516 Ty = llvm::ArrayType::get(Ty, NumPadBytes);
Anders Carlsson3b0c5dc2009-08-22 23:54:44 +0000517
Nuno Lopes5863c992010-04-16 20:56:35 +0000518 Elts.push_back(llvm::UndefValue::get(Ty));
Anders Carlssond65ab042009-07-31 21:38:39 +0000519 Types.push_back(Ty);
520 }
Mike Stump11289f42009-09-09 15:08:12 +0000521
Anders Carlsson3b0c5dc2009-08-22 23:54:44 +0000522 llvm::StructType* STy =
523 llvm::StructType::get(C->getType()->getContext(), Types, false);
Anders Carlssond65ab042009-07-31 21:38:39 +0000524 return llvm::ConstantStruct::get(STy, Elts);
Nuno Lopes4d78cf02009-01-17 00:48:48 +0000525 }
John McCalle3027922010-08-25 11:45:40 +0000526 case CK_NullToMemberPointer: {
John McCalla1dee5302010-08-22 10:59:02 +0000527 const MemberPointerType *MPT = E->getType()->getAs<MemberPointerType>();
John McCall7a9aac22010-08-23 01:21:21 +0000528 return CGM.getCXXABI().EmitNullMemberPointer(MPT);
John McCalla1dee5302010-08-22 10:59:02 +0000529 }
Anders Carlsson3162e492009-10-03 15:13:22 +0000530
John McCall2de87f62011-03-15 21:17:48 +0000531 case CK_DerivedToBaseMemberPointer:
532 case CK_BaseToDerivedMemberPointer:
John McCall7a9aac22010-08-23 01:21:21 +0000533 return CGM.getCXXABI().EmitMemberPointerConversion(C, E);
Anders Carlsson9500ad12009-10-18 20:31:03 +0000534
John McCall2de87f62011-03-15 21:17:48 +0000535 case CK_LValueToRValue:
536 case CK_NoOp:
537 return C;
Anders Carlsson9500ad12009-10-18 20:31:03 +0000538
John McCall2de87f62011-03-15 21:17:48 +0000539 case CK_AnyPointerToObjCPointerCast:
540 case CK_AnyPointerToBlockPointerCast:
541 case CK_LValueBitCast:
542 case CK_BitCast:
543 if (C->getType() == destType) return C;
544 return llvm::ConstantExpr::getBitCast(C, destType);
Chris Lattnera2f9bd52009-10-13 22:12:09 +0000545
John McCall2de87f62011-03-15 21:17:48 +0000546 case CK_Dependent: llvm_unreachable("saw dependent cast!");
547
548 // These will never be supported.
549 case CK_ObjCObjectLValueCast:
550 case CK_GetObjCProperty:
551 case CK_ToVoid:
552 case CK_Dynamic:
Anders Carlsson3b0c5dc2009-08-22 23:54:44 +0000553 return 0;
John McCall2de87f62011-03-15 21:17:48 +0000554
555 // These might need to be supported for constexpr.
556 case CK_UserDefinedConversion:
557 case CK_ConstructorConversion:
558 return 0;
559
560 // These should eventually be supported.
561 case CK_ArrayToPointerDecay:
562 case CK_FunctionToPointerDecay:
563 case CK_BaseToDerived:
564 case CK_DerivedToBase:
565 case CK_UncheckedDerivedToBase:
566 case CK_MemberPointerToBoolean:
567 case CK_VectorSplat:
568 case CK_FloatingRealToComplex:
569 case CK_FloatingComplexToReal:
570 case CK_FloatingComplexToBoolean:
571 case CK_FloatingComplexCast:
572 case CK_FloatingComplexToIntegralComplex:
573 case CK_IntegralRealToComplex:
574 case CK_IntegralComplexToReal:
575 case CK_IntegralComplexToBoolean:
576 case CK_IntegralComplexCast:
577 case CK_IntegralComplexToFloatingComplex:
578 return 0;
579
580 case CK_PointerToIntegral:
581 if (!E->getType()->isBooleanType())
582 return llvm::ConstantExpr::getPtrToInt(C, destType);
583 // fallthrough
584
585 case CK_PointerToBoolean:
586 return llvm::ConstantExpr::getICmp(llvm::CmpInst::ICMP_EQ, C,
587 llvm::ConstantPointerNull::get(cast<llvm::PointerType>(C->getType())));
588
589 case CK_NullToPointer:
590 return llvm::ConstantPointerNull::get(cast<llvm::PointerType>(destType));
591
592 case CK_IntegralCast: {
593 bool isSigned = subExpr->getType()->isSignedIntegerType();
594 return llvm::ConstantExpr::getIntegerCast(C, destType, isSigned);
Eli Friedman825fe752009-02-22 07:29:04 +0000595 }
John McCall2de87f62011-03-15 21:17:48 +0000596
597 case CK_IntegralToPointer: {
598 bool isSigned = subExpr->getType()->isSignedIntegerType();
599 C = llvm::ConstantExpr::getIntegerCast(C, CGM.IntPtrTy, isSigned);
600 return llvm::ConstantExpr::getIntToPtr(C, destType);
601 }
602
603 case CK_IntegralToBoolean:
604 return llvm::ConstantExpr::getICmp(llvm::CmpInst::ICMP_EQ, C,
605 llvm::Constant::getNullValue(C->getType()));
606
607 case CK_IntegralToFloating:
608 if (subExpr->getType()->isSignedIntegerType())
609 return llvm::ConstantExpr::getSIToFP(C, destType);
610 else
611 return llvm::ConstantExpr::getUIToFP(C, destType);
612
613 case CK_FloatingToIntegral:
614 if (E->getType()->isSignedIntegerType())
615 return llvm::ConstantExpr::getFPToSI(C, destType);
616 else
617 return llvm::ConstantExpr::getFPToUI(C, destType);
618
619 case CK_FloatingToBoolean:
620 return llvm::ConstantExpr::getFCmp(llvm::CmpInst::FCMP_UNE, C,
621 llvm::Constant::getNullValue(C->getType()));
622
623 case CK_FloatingCast:
624 return llvm::ConstantExpr::getFPCast(C, destType);
Anders Carlsson3b0c5dc2009-08-22 23:54:44 +0000625 }
Matt Beaumont-Gay145e2eb2011-03-17 00:46:34 +0000626 llvm_unreachable("Invalid CastKind");
Anders Carlsson610ee712008-01-26 01:36:00 +0000627 }
Devang Patela703a672008-02-05 02:39:50 +0000628
Chris Lattneraa9c7ae2008-04-08 04:40:51 +0000629 llvm::Constant *VisitCXXDefaultArgExpr(CXXDefaultArgExpr *DAE) {
630 return Visit(DAE->getExpr());
631 }
632
Eli Friedmana2eaffc2008-05-30 10:24:46 +0000633 llvm::Constant *EmitArrayInitialization(InitListExpr *ILE) {
Nuno Lopes247a1382010-04-18 19:06:43 +0000634 unsigned NumInitElements = ILE->getNumInits();
Benjamin Kramer0f074df2011-03-02 21:27:44 +0000635 if (NumInitElements == 1 && ILE->getType() == ILE->getInit(0)->getType() &&
Nuno Lopes247a1382010-04-18 19:06:43 +0000636 (isa<StringLiteral>(ILE->getInit(0)) ||
637 isa<ObjCEncodeExpr>(ILE->getInit(0))))
638 return Visit(ILE->getInit(0));
639
Nuno Lopes74b59522010-04-16 23:19:41 +0000640 std::vector<llvm::Constant*> Elts;
641 const llvm::ArrayType *AType =
642 cast<llvm::ArrayType>(ConvertType(ILE->getType()));
Devang Patela703a672008-02-05 02:39:50 +0000643 const llvm::Type *ElemTy = AType->getElementType();
644 unsigned NumElements = AType->getNumElements();
645
Mike Stump11289f42009-09-09 15:08:12 +0000646 // Initialising an array requires us to automatically
Devang Patela703a672008-02-05 02:39:50 +0000647 // initialise any elements that have not been initialised explicitly
648 unsigned NumInitableElts = std::min(NumInitElements, NumElements);
649
650 // Copy initializer elements.
651 unsigned i = 0;
Eli Friedman34994cb2008-05-30 19:58:50 +0000652 bool RewriteType = false;
Devang Patela703a672008-02-05 02:39:50 +0000653 for (; i < NumInitableElts; ++i) {
Anders Carlsson80f97ab2009-04-08 04:48:15 +0000654 Expr *Init = ILE->getInit(i);
655 llvm::Constant *C = CGM.EmitConstantExpr(Init, Init->getType(), CGF);
Daniel Dunbar38ad1e62009-02-17 18:43:32 +0000656 if (!C)
657 return 0;
Eli Friedman34994cb2008-05-30 19:58:50 +0000658 RewriteType |= (C->getType() != ElemTy);
Devang Patela703a672008-02-05 02:39:50 +0000659 Elts.push_back(C);
660 }
Eli Friedman34994cb2008-05-30 19:58:50 +0000661
Devang Patela703a672008-02-05 02:39:50 +0000662 // Initialize remaining array elements.
Eli Friedman20bb5e02009-04-13 21:47:26 +0000663 // FIXME: This doesn't handle member pointers correctly!
Devang Patela703a672008-02-05 02:39:50 +0000664 for (; i < NumElements; ++i)
Owen Anderson0b75f232009-07-31 20:28:54 +0000665 Elts.push_back(llvm::Constant::getNullValue(ElemTy));
Devang Patela703a672008-02-05 02:39:50 +0000666
Eli Friedman34994cb2008-05-30 19:58:50 +0000667 if (RewriteType) {
668 // FIXME: Try to avoid packing the array
669 std::vector<const llvm::Type*> Types;
670 for (unsigned i = 0; i < Elts.size(); ++i)
671 Types.push_back(Elts[i]->getType());
Mike Stump11289f42009-09-09 15:08:12 +0000672 const llvm::StructType *SType = llvm::StructType::get(AType->getContext(),
Owen Anderson758428f2009-08-05 23:18:46 +0000673 Types, true);
Owen Anderson0e0189d2009-07-27 22:29:56 +0000674 return llvm::ConstantStruct::get(SType, Elts);
Eli Friedman34994cb2008-05-30 19:58:50 +0000675 }
676
Mike Stump11289f42009-09-09 15:08:12 +0000677 return llvm::ConstantArray::get(AType, Elts);
Devang Patela703a672008-02-05 02:39:50 +0000678 }
679
Eli Friedmana2eaffc2008-05-30 10:24:46 +0000680 llvm::Constant *EmitStructInitialization(InitListExpr *ILE) {
Anders Carlssonb7130ed2009-07-27 05:54:15 +0000681 return ConstStructBuilder::BuildStruct(CGM, CGF, ILE);
Devang Patela703a672008-02-05 02:39:50 +0000682 }
Mike Stump11289f42009-09-09 15:08:12 +0000683
Eli Friedmana2eaffc2008-05-30 10:24:46 +0000684 llvm::Constant *EmitUnionInitialization(InitListExpr *ILE) {
Anders Carlsson0d5f37b2009-07-31 21:34:04 +0000685 return ConstStructBuilder::BuildStruct(CGM, CGF, ILE);
Eli Friedmana2eaffc2008-05-30 10:24:46 +0000686 }
687
Anders Carlsson02714ed2009-01-30 06:13:25 +0000688 llvm::Constant *VisitImplicitValueInitExpr(ImplicitValueInitExpr* E) {
Eli Friedman20bb5e02009-04-13 21:47:26 +0000689 return CGM.EmitNullConstant(E->getType());
Anders Carlsson02714ed2009-01-30 06:13:25 +0000690 }
Mike Stump11289f42009-09-09 15:08:12 +0000691
Anders Carlsson610ee712008-01-26 01:36:00 +0000692 llvm::Constant *VisitInitListExpr(InitListExpr *ILE) {
Eli Friedmana2eaffc2008-05-30 10:24:46 +0000693 if (ILE->getType()->isScalarType()) {
694 // We have a scalar in braces. Just use the first element.
Anders Carlsson80f97ab2009-04-08 04:48:15 +0000695 if (ILE->getNumInits() > 0) {
696 Expr *Init = ILE->getInit(0);
697 return CGM.EmitConstantExpr(Init, Init->getType(), CGF);
698 }
Eli Friedman20bb5e02009-04-13 21:47:26 +0000699 return CGM.EmitNullConstant(ILE->getType());
Anders Carlsson610ee712008-01-26 01:36:00 +0000700 }
Mike Stump11289f42009-09-09 15:08:12 +0000701
Eli Friedmana2eaffc2008-05-30 10:24:46 +0000702 if (ILE->getType()->isArrayType())
703 return EmitArrayInitialization(ILE);
Devang Patel45a65d22008-01-29 23:23:18 +0000704
Anders Carlssone18e29e2009-11-21 23:56:04 +0000705 if (ILE->getType()->isRecordType())
Eli Friedmana2eaffc2008-05-30 10:24:46 +0000706 return EmitStructInitialization(ILE);
707
708 if (ILE->getType()->isUnionType())
709 return EmitUnionInitialization(ILE);
710
Eli Friedmanc52a9362010-01-02 23:43:59 +0000711 // If ILE was a constant vector, we would have handled it already.
Eli Friedmana2eaffc2008-05-30 10:24:46 +0000712 if (ILE->getType()->isVectorType())
Eli Friedmanc52a9362010-01-02 23:43:59 +0000713 return 0;
Eli Friedmana2eaffc2008-05-30 10:24:46 +0000714
Devang Patela703a672008-02-05 02:39:50 +0000715 assert(0 && "Unable to handle InitListExpr");
Chris Lattnera087ff92008-03-01 08:45:05 +0000716 // Get rid of control reaches end of void function warning.
717 // Not reached.
718 return 0;
Anders Carlsson610ee712008-01-26 01:36:00 +0000719 }
Eli Friedmana2433112008-02-21 17:57:49 +0000720
John McCall49786a62010-02-02 08:02:49 +0000721 llvm::Constant *VisitCXXConstructExpr(CXXConstructExpr *E) {
722 if (!E->getConstructor()->isTrivial())
723 return 0;
724
Anders Carlssoncb86e102010-02-05 18:38:45 +0000725 QualType Ty = E->getType();
726
727 // FIXME: We should not have to call getBaseElementType here.
728 const RecordType *RT =
729 CGM.getContext().getBaseElementType(Ty)->getAs<RecordType>();
730 const CXXRecordDecl *RD = cast<CXXRecordDecl>(RT->getDecl());
731
732 // If the class doesn't have a trivial destructor, we can't emit it as a
733 // constant expr.
734 if (!RD->hasTrivialDestructor())
735 return 0;
736
John McCall49786a62010-02-02 08:02:49 +0000737 // Only copy and default constructors can be trivial.
738
John McCall49786a62010-02-02 08:02:49 +0000739
740 if (E->getNumArgs()) {
741 assert(E->getNumArgs() == 1 && "trivial ctor with > 1 argument");
742 assert(E->getConstructor()->isCopyConstructor() &&
743 "trivial ctor has argument but isn't a copy ctor");
744
745 Expr *Arg = E->getArg(0);
746 assert(CGM.getContext().hasSameUnqualifiedType(Ty, Arg->getType()) &&
747 "argument to copy ctor is of wrong type");
748
Chandler Carruth173bfe42010-02-02 12:15:55 +0000749 return Visit(Arg);
John McCall49786a62010-02-02 08:02:49 +0000750 }
751
752 return CGM.EmitNullConstant(Ty);
753 }
754
Anders Carlsson610ee712008-01-26 01:36:00 +0000755 llvm::Constant *VisitStringLiteral(StringLiteral *E) {
Chris Lattner36fc8792008-02-11 00:02:17 +0000756 assert(!E->getType()->isPointerType() && "Strings are always arrays");
Mike Stump11289f42009-09-09 15:08:12 +0000757
Chris Lattnerd7e7b8e2009-02-24 22:18:39 +0000758 // This must be a string initializing an array in a static initializer.
759 // Don't emit it as the address of the string, emit the string data itself
760 // as an inline array.
Owen Anderson41a75022009-08-13 21:57:51 +0000761 return llvm::ConstantArray::get(VMContext,
762 CGM.GetStringForStringLiteral(E), false);
Anders Carlsson610ee712008-01-26 01:36:00 +0000763 }
764
Chris Lattnerd7e7b8e2009-02-24 22:18:39 +0000765 llvm::Constant *VisitObjCEncodeExpr(ObjCEncodeExpr *E) {
766 // This must be an @encode initializing an array in a static initializer.
767 // Don't emit it as the address of the string, emit the string data itself
768 // as an inline array.
769 std::string Str;
770 CGM.getContext().getObjCEncodingForType(E->getEncodedType(), Str);
771 const ConstantArrayType *CAT = cast<ConstantArrayType>(E->getType());
Mike Stump11289f42009-09-09 15:08:12 +0000772
Chris Lattnerd7e7b8e2009-02-24 22:18:39 +0000773 // Resize the string to the right size, adding zeros at the end, or
774 // truncating as needed.
775 Str.resize(CAT->getSize().getZExtValue(), '\0');
Owen Anderson41a75022009-08-13 21:57:51 +0000776 return llvm::ConstantArray::get(VMContext, Str, false);
Chris Lattnerd7e7b8e2009-02-24 22:18:39 +0000777 }
Mike Stump11289f42009-09-09 15:08:12 +0000778
Eli Friedman045bf4f2008-05-29 11:22:45 +0000779 llvm::Constant *VisitUnaryExtension(const UnaryOperator *E) {
780 return Visit(E->getSubExpr());
781 }
Mike Stumpa6703322009-02-19 22:01:56 +0000782
Anders Carlsson610ee712008-01-26 01:36:00 +0000783 // Utility methods
784 const llvm::Type *ConvertType(QualType T) {
785 return CGM.getTypes().ConvertType(T);
786 }
Anders Carlsson8a88c382008-01-26 04:30:23 +0000787
Anders Carlsson43088772008-11-16 06:23:45 +0000788public:
Anders Carlsson8a88c382008-01-26 04:30:23 +0000789 llvm::Constant *EmitLValue(Expr *E) {
Anders Carlssona4139112008-01-26 02:08:50 +0000790 switch (E->getStmtClass()) {
Eli Friedmana5b20232008-02-11 00:23:10 +0000791 default: break;
Anders Carlssona4139112008-01-26 02:08:50 +0000792 case Expr::CompoundLiteralExprClass: {
793 // Note that due to the nature of compound literals, this is guaranteed
794 // to be the only use of the variable, so we just generate it here.
Anders Carlsson8a88c382008-01-26 04:30:23 +0000795 CompoundLiteralExpr *CLE = cast<CompoundLiteralExpr>(E);
796 llvm::Constant* C = Visit(CLE->getInitializer());
Daniel Dunbar38ad1e62009-02-17 18:43:32 +0000797 // FIXME: "Leaked" on failure.
798 if (C)
Owen Andersonc10c8d32009-07-08 19:05:04 +0000799 C = new llvm::GlobalVariable(CGM.getModule(), C->getType(),
Eli Friedman95f89632009-08-26 20:01:39 +0000800 E->getType().isConstant(CGM.getContext()),
Daniel Dunbar38ad1e62009-02-17 18:43:32 +0000801 llvm::GlobalValue::InternalLinkage,
Eli Friedman95f89632009-08-26 20:01:39 +0000802 C, ".compoundliteral", 0, false,
803 E->getType().getAddressSpace());
Anders Carlssona4139112008-01-26 02:08:50 +0000804 return C;
Anders Carlsson8a88c382008-01-26 04:30:23 +0000805 }
Douglas Gregor4bd90e52009-10-23 18:54:35 +0000806 case Expr::DeclRefExprClass: {
Rafael Espindolabef98682010-03-04 21:26:03 +0000807 ValueDecl *Decl = cast<DeclRefExpr>(E)->getDecl();
808 if (Decl->hasAttr<WeakRefAttr>())
Eli Friedman04831922010-08-22 01:00:03 +0000809 return CGM.GetWeakRefReference(Decl);
Anders Carlssona4139112008-01-26 02:08:50 +0000810 if (const FunctionDecl *FD = dyn_cast<FunctionDecl>(Decl))
Anders Carlssonecf9bf02009-09-10 23:43:36 +0000811 return CGM.GetAddrOfFunction(FD);
Steve Naroff08899ff2008-04-15 22:42:06 +0000812 if (const VarDecl* VD = dyn_cast<VarDecl>(Decl)) {
Daniel Dunbard4ecca12009-02-24 18:41:57 +0000813 // We can never refer to a variable with local storage.
Mike Stump11289f42009-09-09 15:08:12 +0000814 if (!VD->hasLocalStorage()) {
Daniel Dunbard4ecca12009-02-24 18:41:57 +0000815 if (VD->isFileVarDecl() || VD->hasExternalStorage())
816 return CGM.GetAddrOfGlobalVar(VD);
John McCall1c9c3fd2010-10-15 04:57:14 +0000817 else if (VD->isLocalVarDecl()) {
Daniel Dunbard4ecca12009-02-24 18:41:57 +0000818 assert(CGF && "Can't access static local vars without CGF");
819 return CGF->GetAddrOfStaticLocalVar(VD);
820 }
Steve Naroff08899ff2008-04-15 22:42:06 +0000821 }
Lauro Ramos Venancio01a72ff2008-02-26 21:41:45 +0000822 }
Eli Friedmana5b20232008-02-11 00:23:10 +0000823 break;
Anders Carlssona4139112008-01-26 02:08:50 +0000824 }
Daniel Dunbarc4baa062008-08-13 23:20:05 +0000825 case Expr::StringLiteralClass:
826 return CGM.GetAddrOfConstantStringFromLiteral(cast<StringLiteral>(E));
Chris Lattnerd7e7b8e2009-02-24 22:18:39 +0000827 case Expr::ObjCEncodeExprClass:
828 return CGM.GetAddrOfConstantStringFromObjCEncode(cast<ObjCEncodeExpr>(E));
Anders Carlsson43088772008-11-16 06:23:45 +0000829 case Expr::ObjCStringLiteralClass: {
830 ObjCStringLiteral* SL = cast<ObjCStringLiteral>(E);
David Chisnall481e3a82010-01-23 02:40:42 +0000831 llvm::Constant *C =
832 CGM.getObjCRuntime().GenerateConstantString(SL->getString());
Owen Andersonade90fd2009-07-29 18:54:39 +0000833 return llvm::ConstantExpr::getBitCast(C, ConvertType(E->getType()));
Anders Carlsson43088772008-11-16 06:23:45 +0000834 }
Chris Lattnerb4396f42008-12-12 05:18:02 +0000835 case Expr::PredefinedExprClass: {
Eli Friedmanb210fc52009-11-14 08:37:13 +0000836 unsigned Type = cast<PredefinedExpr>(E)->getIdentType();
837 if (CGF) {
Daniel Dunbarb1d94a92010-08-21 03:01:12 +0000838 LValue Res = CGF->EmitPredefinedLValue(cast<PredefinedExpr>(E));
Eli Friedmanb210fc52009-11-14 08:37:13 +0000839 return cast<llvm::Constant>(Res.getAddress());
840 } else if (Type == PredefinedExpr::PrettyFunction) {
841 return CGM.GetAddrOfConstantCString("top level", ".tmp");
842 }
Mike Stump11289f42009-09-09 15:08:12 +0000843
Eli Friedmanb210fc52009-11-14 08:37:13 +0000844 return CGM.GetAddrOfConstantCString("", ".tmp");
Chris Lattnerb4396f42008-12-12 05:18:02 +0000845 }
Eli Friedman529a99b2009-01-25 01:21:06 +0000846 case Expr::AddrLabelExprClass: {
847 assert(CGF && "Invalid address of label expression outside function.");
Chris Lattner6c4d2552009-10-28 23:59:40 +0000848 llvm::Constant *Ptr =
849 CGF->GetAddrOfLabel(cast<AddrLabelExpr>(E)->getLabel());
850 return llvm::ConstantExpr::getBitCast(Ptr, ConvertType(E->getType()));
Eli Friedman529a99b2009-01-25 01:21:06 +0000851 }
Eli Friedmanc69d4542009-01-25 01:54:01 +0000852 case Expr::CallExprClass: {
853 CallExpr* CE = cast<CallExpr>(E);
David Chisnall481e3a82010-01-23 02:40:42 +0000854 unsigned builtin = CE->isBuiltinCall(CGM.getContext());
855 if (builtin !=
856 Builtin::BI__builtin___CFStringMakeConstantString &&
857 builtin !=
858 Builtin::BI__builtin___NSStringMakeConstantString)
Eli Friedmanc69d4542009-01-25 01:54:01 +0000859 break;
860 const Expr *Arg = CE->getArg(0)->IgnoreParenCasts();
861 const StringLiteral *Literal = cast<StringLiteral>(Arg);
David Chisnall481e3a82010-01-23 02:40:42 +0000862 if (builtin ==
863 Builtin::BI__builtin___NSStringMakeConstantString) {
864 return CGM.getObjCRuntime().GenerateConstantString(Literal);
865 }
Steve Naroff66afeb52009-03-31 16:53:37 +0000866 // FIXME: need to deal with UCN conversion issues.
Steve Naroffe14b3682009-04-01 13:55:36 +0000867 return CGM.GetAddrOfConstantCFString(Literal);
Eli Friedmanc69d4542009-01-25 01:54:01 +0000868 }
Mike Stump5d2534ad2009-02-19 01:01:04 +0000869 case Expr::BlockExprClass: {
Anders Carlssoned5e69f2009-03-01 01:09:12 +0000870 std::string FunctionName;
871 if (CGF)
872 FunctionName = CGF->CurFn->getName();
873 else
874 FunctionName = "global";
875
876 return CGM.GetAddrOfGlobalBlock(cast<BlockExpr>(E), FunctionName.c_str());
Mike Stump5d2534ad2009-02-19 01:01:04 +0000877 }
Eli Friedmana5b20232008-02-11 00:23:10 +0000878 }
Daniel Dunbar38ad1e62009-02-17 18:43:32 +0000879
880 return 0;
Anders Carlssona4139112008-01-26 02:08:50 +0000881 }
Anders Carlssona4139112008-01-26 02:08:50 +0000882};
Mike Stump11289f42009-09-09 15:08:12 +0000883
Anders Carlsson610ee712008-01-26 01:36:00 +0000884} // end anonymous namespace.
885
Lauro Ramos Venancio01a72ff2008-02-26 21:41:45 +0000886llvm::Constant *CodeGenModule::EmitConstantExpr(const Expr *E,
Anders Carlsson80f97ab2009-04-08 04:48:15 +0000887 QualType DestType,
Chris Lattner0f398c42008-07-26 22:37:01 +0000888 CodeGenFunction *CGF) {
Anders Carlsson38eef1d2008-12-01 02:42:14 +0000889 Expr::EvalResult Result;
Mike Stump11289f42009-09-09 15:08:12 +0000890
Anders Carlssond8e39bb2009-04-11 01:08:03 +0000891 bool Success = false;
Mike Stump11289f42009-09-09 15:08:12 +0000892
Eli Friedman751aa72b72009-05-27 06:04:58 +0000893 if (DestType->isReferenceType())
894 Success = E->EvaluateAsLValue(Result, Context);
Mike Stump11289f42009-09-09 15:08:12 +0000895 else
Anders Carlssond8e39bb2009-04-11 01:08:03 +0000896 Success = E->Evaluate(Result, Context);
Mike Stump11289f42009-09-09 15:08:12 +0000897
Eli Friedman274ab902009-11-14 08:51:33 +0000898 if (Success && !Result.HasSideEffects) {
Anders Carlsson38eef1d2008-12-01 02:42:14 +0000899 switch (Result.Val.getKind()) {
Daniel Dunbarf50e60b2009-01-28 22:24:07 +0000900 case APValue::Uninitialized:
Daniel Dunbar38ad1e62009-02-17 18:43:32 +0000901 assert(0 && "Constant expressions should be initialized.");
902 return 0;
Anders Carlssonee0d90f2008-11-15 20:45:50 +0000903 case APValue::LValue: {
Anders Carlssond8e39bb2009-04-11 01:08:03 +0000904 const llvm::Type *DestTy = getTypes().ConvertTypeForMem(DestType);
Mike Stump11289f42009-09-09 15:08:12 +0000905 llvm::Constant *Offset =
906 llvm::ConstantInt::get(llvm::Type::getInt64Ty(VMContext),
Ken Dyck02990832010-01-15 12:37:54 +0000907 Result.Val.getLValueOffset().getQuantity());
Mike Stump11289f42009-09-09 15:08:12 +0000908
Daniel Dunbar18e14442009-02-19 21:44:24 +0000909 llvm::Constant *C;
Anders Carlsson38eef1d2008-12-01 02:42:14 +0000910 if (const Expr *LVBase = Result.Val.getLValueBase()) {
Daniel Dunbar18e14442009-02-19 21:44:24 +0000911 C = ConstExprEmitter(*this, CGF).EmitLValue(const_cast<Expr*>(LVBase));
Anders Carlsson43088772008-11-16 06:23:45 +0000912
Daniel Dunbar18e14442009-02-19 21:44:24 +0000913 // Apply offset if necessary.
914 if (!Offset->isNullValue()) {
Benjamin Kramerabd5b902009-10-13 10:07:13 +0000915 const llvm::Type *Type = llvm::Type::getInt8PtrTy(VMContext);
Owen Andersonade90fd2009-07-29 18:54:39 +0000916 llvm::Constant *Casted = llvm::ConstantExpr::getBitCast(C, Type);
917 Casted = llvm::ConstantExpr::getGetElementPtr(Casted, &Offset, 1);
918 C = llvm::ConstantExpr::getBitCast(Casted, C->getType());
Daniel Dunbar18e14442009-02-19 21:44:24 +0000919 }
920
921 // Convert to the appropriate type; this could be an lvalue for
922 // an integer.
Anders Carlsson6ef4ea42009-04-10 04:59:59 +0000923 if (isa<llvm::PointerType>(DestTy))
Owen Andersonade90fd2009-07-29 18:54:39 +0000924 return llvm::ConstantExpr::getBitCast(C, DestTy);
Daniel Dunbar18e14442009-02-19 21:44:24 +0000925
Owen Andersonade90fd2009-07-29 18:54:39 +0000926 return llvm::ConstantExpr::getPtrToInt(C, DestTy);
Daniel Dunbar18e14442009-02-19 21:44:24 +0000927 } else {
928 C = Offset;
929
930 // Convert to the appropriate type; this could be an lvalue for
931 // an integer.
Anders Carlsson6ef4ea42009-04-10 04:59:59 +0000932 if (isa<llvm::PointerType>(DestTy))
Owen Andersonade90fd2009-07-29 18:54:39 +0000933 return llvm::ConstantExpr::getIntToPtr(C, DestTy);
Daniel Dunbar18e14442009-02-19 21:44:24 +0000934
935 // If the types don't match this should only be a truncate.
Anders Carlsson6ef4ea42009-04-10 04:59:59 +0000936 if (C->getType() != DestTy)
Owen Andersonade90fd2009-07-29 18:54:39 +0000937 return llvm::ConstantExpr::getTrunc(C, DestTy);
Daniel Dunbar18e14442009-02-19 21:44:24 +0000938
939 return C;
Anders Carlsson43088772008-11-16 06:23:45 +0000940 }
Anders Carlssonee0d90f2008-11-15 20:45:50 +0000941 }
Eli Friedmandcbcbb82008-11-17 03:57:28 +0000942 case APValue::Int: {
Mike Stump11289f42009-09-09 15:08:12 +0000943 llvm::Constant *C = llvm::ConstantInt::get(VMContext,
Owen Andersonb7a2fe62009-07-24 23:12:58 +0000944 Result.Val.getInt());
Mike Stump11289f42009-09-09 15:08:12 +0000945
Chris Lattnerfa20e952010-06-26 21:52:32 +0000946 if (C->getType()->isIntegerTy(1)) {
Anders Carlssonee0d90f2008-11-15 20:45:50 +0000947 const llvm::Type *BoolTy = getTypes().ConvertTypeForMem(E->getType());
Owen Andersonade90fd2009-07-29 18:54:39 +0000948 C = llvm::ConstantExpr::getZExt(C, BoolTy);
Anders Carlssonee0d90f2008-11-15 20:45:50 +0000949 }
950 return C;
Eli Friedmandcbcbb82008-11-17 03:57:28 +0000951 }
Daniel Dunbarf50e60b2009-01-28 22:24:07 +0000952 case APValue::ComplexInt: {
953 llvm::Constant *Complex[2];
Mike Stump11289f42009-09-09 15:08:12 +0000954
Owen Andersonb7a2fe62009-07-24 23:12:58 +0000955 Complex[0] = llvm::ConstantInt::get(VMContext,
956 Result.Val.getComplexIntReal());
Mike Stump11289f42009-09-09 15:08:12 +0000957 Complex[1] = llvm::ConstantInt::get(VMContext,
Owen Andersonb7a2fe62009-07-24 23:12:58 +0000958 Result.Val.getComplexIntImag());
Mike Stump11289f42009-09-09 15:08:12 +0000959
Nick Lewycky41eaf0a2009-09-19 20:00:52 +0000960 // FIXME: the target may want to specify that this is packed.
961 return llvm::ConstantStruct::get(VMContext, Complex, 2, false);
Daniel Dunbarf50e60b2009-01-28 22:24:07 +0000962 }
Anders Carlssonee0d90f2008-11-15 20:45:50 +0000963 case APValue::Float:
Owen Andersone05f2ed2009-07-27 21:00:51 +0000964 return llvm::ConstantFP::get(VMContext, Result.Val.getFloat());
Anders Carlsson4425d8e2008-11-17 01:58:55 +0000965 case APValue::ComplexFloat: {
966 llvm::Constant *Complex[2];
Mike Stump11289f42009-09-09 15:08:12 +0000967
968 Complex[0] = llvm::ConstantFP::get(VMContext,
Owen Andersone05f2ed2009-07-27 21:00:51 +0000969 Result.Val.getComplexFloatReal());
970 Complex[1] = llvm::ConstantFP::get(VMContext,
971 Result.Val.getComplexFloatImag());
Mike Stump11289f42009-09-09 15:08:12 +0000972
Nick Lewycky41eaf0a2009-09-19 20:00:52 +0000973 // FIXME: the target may want to specify that this is packed.
974 return llvm::ConstantStruct::get(VMContext, Complex, 2, false);
Anders Carlsson4425d8e2008-11-17 01:58:55 +0000975 }
Nate Begeman1e31b162009-01-18 01:01:34 +0000976 case APValue::Vector: {
977 llvm::SmallVector<llvm::Constant *, 4> Inits;
978 unsigned NumElts = Result.Val.getVectorLength();
Mike Stump11289f42009-09-09 15:08:12 +0000979
Nate Begeman1e31b162009-01-18 01:01:34 +0000980 for (unsigned i = 0; i != NumElts; ++i) {
981 APValue &Elt = Result.Val.getVectorElt(i);
982 if (Elt.isInt())
Owen Andersonb7a2fe62009-07-24 23:12:58 +0000983 Inits.push_back(llvm::ConstantInt::get(VMContext, Elt.getInt()));
Nate Begeman1e31b162009-01-18 01:01:34 +0000984 else
Owen Andersone05f2ed2009-07-27 21:00:51 +0000985 Inits.push_back(llvm::ConstantFP::get(VMContext, Elt.getFloat()));
Nate Begeman1e31b162009-01-18 01:01:34 +0000986 }
Chris Lattner91c08ad2011-02-15 00:14:06 +0000987 return llvm::ConstantVector::get(Inits);
Nate Begeman1e31b162009-01-18 01:01:34 +0000988 }
Anders Carlssonee0d90f2008-11-15 20:45:50 +0000989 }
990 }
Eli Friedman10c24172008-06-01 15:31:44 +0000991
992 llvm::Constant* C = ConstExprEmitter(*this, CGF).Visit(const_cast<Expr*>(E));
Chris Lattnerfa20e952010-06-26 21:52:32 +0000993 if (C && C->getType()->isIntegerTy(1)) {
Eli Friedman10c24172008-06-01 15:31:44 +0000994 const llvm::Type *BoolTy = getTypes().ConvertTypeForMem(E->getType());
Owen Andersonade90fd2009-07-29 18:54:39 +0000995 C = llvm::ConstantExpr::getZExt(C, BoolTy);
Eli Friedman10c24172008-06-01 15:31:44 +0000996 }
997 return C;
Anders Carlsson610ee712008-01-26 01:36:00 +0000998}
Eli Friedman20bb5e02009-04-13 21:47:26 +0000999
John McCallf3a88602011-02-03 08:15:49 +00001000static uint64_t getFieldOffset(ASTContext &C, const FieldDecl *field) {
1001 const ASTRecordLayout &layout = C.getASTRecordLayout(field->getParent());
1002 return layout.getFieldOffset(field->getFieldIndex());
1003}
1004
1005llvm::Constant *
1006CodeGenModule::getMemberPointerConstant(const UnaryOperator *uo) {
1007 // Member pointer constants always have a very particular form.
1008 const MemberPointerType *type = cast<MemberPointerType>(uo->getType());
1009 const ValueDecl *decl = cast<DeclRefExpr>(uo->getSubExpr())->getDecl();
1010
1011 // A member function pointer.
1012 if (const CXXMethodDecl *method = dyn_cast<CXXMethodDecl>(decl))
1013 return getCXXABI().EmitMemberPointer(method);
1014
1015 // Otherwise, a member data pointer.
1016 uint64_t fieldOffset;
1017 if (const FieldDecl *field = dyn_cast<FieldDecl>(decl))
1018 fieldOffset = getFieldOffset(getContext(), field);
1019 else {
1020 const IndirectFieldDecl *ifield = cast<IndirectFieldDecl>(decl);
1021
1022 fieldOffset = 0;
1023 for (IndirectFieldDecl::chain_iterator ci = ifield->chain_begin(),
1024 ce = ifield->chain_end(); ci != ce; ++ci)
1025 fieldOffset += getFieldOffset(getContext(), cast<FieldDecl>(*ci));
1026 }
1027
1028 CharUnits chars = getContext().toCharUnitsFromBits((int64_t) fieldOffset);
1029 return getCXXABI().EmitMemberDataPointer(type, chars);
1030}
1031
Anders Carlssonbe48c542010-05-18 16:51:41 +00001032static void
1033FillInNullDataMemberPointers(CodeGenModule &CGM, QualType T,
1034 std::vector<llvm::Constant *> &Elements,
1035 uint64_t StartOffset) {
1036 assert(StartOffset % 8 == 0 && "StartOffset not byte aligned!");
1037
John McCall614dbdc2010-08-22 21:01:12 +00001038 if (CGM.getTypes().isZeroInitializable(T))
Anders Carlssonbe48c542010-05-18 16:51:41 +00001039 return;
1040
1041 if (const ConstantArrayType *CAT =
1042 CGM.getContext().getAsConstantArrayType(T)) {
1043 QualType ElementTy = CAT->getElementType();
1044 uint64_t ElementSize = CGM.getContext().getTypeSize(ElementTy);
1045
1046 for (uint64_t I = 0, E = CAT->getSize().getZExtValue(); I != E; ++I) {
1047 FillInNullDataMemberPointers(CGM, ElementTy, Elements,
1048 StartOffset + I * ElementSize);
1049 }
1050 } else if (const RecordType *RT = T->getAs<RecordType>()) {
1051 const CXXRecordDecl *RD = cast<CXXRecordDecl>(RT->getDecl());
1052 const ASTRecordLayout &Layout = CGM.getContext().getASTRecordLayout(RD);
1053
1054 // Go through all bases and fill in any null pointer to data members.
1055 for (CXXRecordDecl::base_class_const_iterator I = RD->bases_begin(),
1056 E = RD->bases_end(); I != E; ++I) {
Anders Carlssonda265b82010-05-27 18:51:01 +00001057 if (I->isVirtual()) {
Anders Carlsson849ea412010-11-22 18:42:14 +00001058 // Ignore virtual bases.
Anders Carlssonda265b82010-05-27 18:51:01 +00001059 continue;
1060 }
Anders Carlssonbe48c542010-05-18 16:51:41 +00001061
1062 const CXXRecordDecl *BaseDecl =
1063 cast<CXXRecordDecl>(I->getType()->getAs<RecordType>()->getDecl());
1064
1065 // Ignore empty bases.
1066 if (BaseDecl->isEmpty())
1067 continue;
1068
1069 // Ignore bases that don't have any pointer to data members.
John McCall614dbdc2010-08-22 21:01:12 +00001070 if (CGM.getTypes().isZeroInitializable(BaseDecl))
Anders Carlssonbe48c542010-05-18 16:51:41 +00001071 continue;
1072
Anders Carlssonfd88a612010-10-31 23:22:37 +00001073 uint64_t BaseOffset = Layout.getBaseClassOffsetInBits(BaseDecl);
Anders Carlssonbe48c542010-05-18 16:51:41 +00001074 FillInNullDataMemberPointers(CGM, I->getType(),
1075 Elements, StartOffset + BaseOffset);
1076 }
1077
1078 // Visit all fields.
1079 unsigned FieldNo = 0;
1080 for (RecordDecl::field_iterator I = RD->field_begin(),
1081 E = RD->field_end(); I != E; ++I, ++FieldNo) {
1082 QualType FieldType = I->getType();
1083
John McCall614dbdc2010-08-22 21:01:12 +00001084 if (CGM.getTypes().isZeroInitializable(FieldType))
Anders Carlssonbe48c542010-05-18 16:51:41 +00001085 continue;
1086
1087 uint64_t FieldOffset = StartOffset + Layout.getFieldOffset(FieldNo);
1088 FillInNullDataMemberPointers(CGM, FieldType, Elements, FieldOffset);
1089 }
1090 } else {
1091 assert(T->isMemberPointerType() && "Should only see member pointers here!");
1092 assert(!T->getAs<MemberPointerType>()->getPointeeType()->isFunctionType() &&
1093 "Should only see pointers to data members here!");
1094
1095 uint64_t StartIndex = StartOffset / 8;
1096 uint64_t EndIndex = StartIndex + CGM.getContext().getTypeSize(T) / 8;
1097
John McCallf3a88602011-02-03 08:15:49 +00001098 // FIXME: hardcodes Itanium member pointer representation!
Anders Carlssonbe48c542010-05-18 16:51:41 +00001099 llvm::Constant *NegativeOne =
1100 llvm::ConstantInt::get(llvm::Type::getInt8Ty(CGM.getLLVMContext()),
John McCallf3a88602011-02-03 08:15:49 +00001101 -1ULL, /*isSigned*/true);
Anders Carlssonbe48c542010-05-18 16:51:41 +00001102
1103 // Fill in the null data member pointer.
1104 for (uint64_t I = StartIndex; I != EndIndex; ++I)
1105 Elements[I] = NegativeOne;
1106 }
1107}
1108
John McCall0217dfc22011-02-15 06:40:56 +00001109static llvm::Constant *EmitNullConstantForBase(CodeGenModule &CGM,
1110 const llvm::Type *baseType,
1111 const CXXRecordDecl *base);
1112
Anders Carlsson849ea412010-11-22 18:42:14 +00001113static llvm::Constant *EmitNullConstant(CodeGenModule &CGM,
John McCall0217dfc22011-02-15 06:40:56 +00001114 const CXXRecordDecl *record,
1115 bool asCompleteObject) {
1116 const CGRecordLayout &layout = CGM.getTypes().getCGRecordLayout(record);
1117 const llvm::StructType *structure =
1118 (asCompleteObject ? layout.getLLVMType()
1119 : layout.getBaseSubobjectLLVMType());
Anders Carlsson849ea412010-11-22 18:42:14 +00001120
John McCall0217dfc22011-02-15 06:40:56 +00001121 unsigned numElements = structure->getNumElements();
1122 std::vector<llvm::Constant *> elements(numElements);
Anders Carlsson849ea412010-11-22 18:42:14 +00001123
John McCall0217dfc22011-02-15 06:40:56 +00001124 // Fill in all the bases.
1125 for (CXXRecordDecl::base_class_const_iterator
1126 I = record->bases_begin(), E = record->bases_end(); I != E; ++I) {
Anders Carlsson849ea412010-11-22 18:42:14 +00001127 if (I->isVirtual()) {
John McCall0217dfc22011-02-15 06:40:56 +00001128 // Ignore virtual bases; if we're laying out for a complete
1129 // object, we'll lay these out later.
Anders Carlsson849ea412010-11-22 18:42:14 +00001130 continue;
1131 }
1132
John McCall0217dfc22011-02-15 06:40:56 +00001133 const CXXRecordDecl *base =
1134 cast<CXXRecordDecl>(I->getType()->castAs<RecordType>()->getDecl());
Anders Carlsson849ea412010-11-22 18:42:14 +00001135
1136 // Ignore empty bases.
John McCall0217dfc22011-02-15 06:40:56 +00001137 if (base->isEmpty())
Anders Carlsson849ea412010-11-22 18:42:14 +00001138 continue;
1139
John McCall0217dfc22011-02-15 06:40:56 +00001140 unsigned fieldIndex = layout.getNonVirtualBaseLLVMFieldNo(base);
1141 const llvm::Type *baseType = structure->getElementType(fieldIndex);
1142 elements[fieldIndex] = EmitNullConstantForBase(CGM, baseType, base);
Anders Carlsson849ea412010-11-22 18:42:14 +00001143 }
1144
John McCall0217dfc22011-02-15 06:40:56 +00001145 // Fill in all the fields.
1146 for (RecordDecl::field_iterator I = record->field_begin(),
1147 E = record->field_end(); I != E; ++I) {
1148 const FieldDecl *field = *I;
Anders Carlsson849ea412010-11-22 18:42:14 +00001149
1150 // Ignore bit fields.
John McCall0217dfc22011-02-15 06:40:56 +00001151 if (field->isBitField())
Anders Carlsson849ea412010-11-22 18:42:14 +00001152 continue;
1153
John McCall0217dfc22011-02-15 06:40:56 +00001154 unsigned fieldIndex = layout.getLLVMFieldNo(field);
1155 elements[fieldIndex] = CGM.EmitNullConstant(field->getType());
1156 }
1157
1158 // Fill in the virtual bases, if we're working with the complete object.
1159 if (asCompleteObject) {
1160 for (CXXRecordDecl::base_class_const_iterator
1161 I = record->vbases_begin(), E = record->vbases_end(); I != E; ++I) {
1162 const CXXRecordDecl *base =
1163 cast<CXXRecordDecl>(I->getType()->castAs<RecordType>()->getDecl());
1164
1165 // Ignore empty bases.
1166 if (base->isEmpty())
1167 continue;
1168
1169 unsigned fieldIndex = layout.getVirtualBaseIndex(base);
1170
1171 // We might have already laid this field out.
1172 if (elements[fieldIndex]) continue;
1173
1174 const llvm::Type *baseType = structure->getElementType(fieldIndex);
1175 elements[fieldIndex] = EmitNullConstantForBase(CGM, baseType, base);
1176 }
Anders Carlsson849ea412010-11-22 18:42:14 +00001177 }
1178
1179 // Now go through all other fields and zero them out.
John McCall0217dfc22011-02-15 06:40:56 +00001180 for (unsigned i = 0; i != numElements; ++i) {
1181 if (!elements[i])
1182 elements[i] = llvm::Constant::getNullValue(structure->getElementType(i));
Anders Carlsson849ea412010-11-22 18:42:14 +00001183 }
1184
John McCall0217dfc22011-02-15 06:40:56 +00001185 return llvm::ConstantStruct::get(structure, elements);
1186}
1187
1188/// Emit the null constant for a base subobject.
1189static llvm::Constant *EmitNullConstantForBase(CodeGenModule &CGM,
1190 const llvm::Type *baseType,
1191 const CXXRecordDecl *base) {
1192 const CGRecordLayout &baseLayout = CGM.getTypes().getCGRecordLayout(base);
1193
1194 // Just zero out bases that don't have any pointer to data members.
1195 if (baseLayout.isZeroInitializableAsBase())
1196 return llvm::Constant::getNullValue(baseType);
1197
1198 // If the base type is a struct, we can just use its null constant.
1199 if (isa<llvm::StructType>(baseType)) {
1200 return EmitNullConstant(CGM, base, /*complete*/ false);
1201 }
1202
1203 // Otherwise, some bases are represented as arrays of i8 if the size
1204 // of the base is smaller than its corresponding LLVM type. Figure
1205 // out how many elements this base array has.
1206 const llvm::ArrayType *baseArrayType = cast<llvm::ArrayType>(baseType);
1207 unsigned numBaseElements = baseArrayType->getNumElements();
1208
1209 // Fill in null data member pointers.
1210 std::vector<llvm::Constant *> baseElements(numBaseElements);
1211 FillInNullDataMemberPointers(CGM, CGM.getContext().getTypeDeclType(base),
1212 baseElements, 0);
1213
1214 // Now go through all other elements and zero them out.
1215 if (numBaseElements) {
1216 const llvm::Type *i8 = llvm::Type::getInt8Ty(CGM.getLLVMContext());
1217 llvm::Constant *i8_zero = llvm::Constant::getNullValue(i8);
1218 for (unsigned i = 0; i != numBaseElements; ++i) {
1219 if (!baseElements[i])
1220 baseElements[i] = i8_zero;
1221 }
1222 }
1223
1224 return llvm::ConstantArray::get(baseArrayType, baseElements);
Anders Carlsson849ea412010-11-22 18:42:14 +00001225}
1226
Eli Friedman20bb5e02009-04-13 21:47:26 +00001227llvm::Constant *CodeGenModule::EmitNullConstant(QualType T) {
John McCall614dbdc2010-08-22 21:01:12 +00001228 if (getTypes().isZeroInitializable(T))
Anders Carlsson867b48f2009-08-24 17:16:23 +00001229 return llvm::Constant::getNullValue(getTypes().ConvertTypeForMem(T));
Anders Carlssone8bfe412010-02-02 05:17:25 +00001230
Anders Carlssonf48123b2009-08-09 18:26:27 +00001231 if (const ConstantArrayType *CAT = Context.getAsConstantArrayType(T)) {
Mike Stump11289f42009-09-09 15:08:12 +00001232
Anders Carlssonf48123b2009-08-09 18:26:27 +00001233 QualType ElementTy = CAT->getElementType();
1234
Anders Carlssone8bfe412010-02-02 05:17:25 +00001235 llvm::Constant *Element = EmitNullConstant(ElementTy);
1236 unsigned NumElements = CAT->getSize().getZExtValue();
1237 std::vector<llvm::Constant *> Array(NumElements);
1238 for (unsigned i = 0; i != NumElements; ++i)
1239 Array[i] = Element;
Mike Stump11289f42009-09-09 15:08:12 +00001240
Anders Carlssone8bfe412010-02-02 05:17:25 +00001241 const llvm::ArrayType *ATy =
1242 cast<llvm::ArrayType>(getTypes().ConvertTypeForMem(T));
1243 return llvm::ConstantArray::get(ATy, Array);
Anders Carlssonf48123b2009-08-09 18:26:27 +00001244 }
Anders Carlssond606de72009-08-23 01:25:01 +00001245
1246 if (const RecordType *RT = T->getAs<RecordType>()) {
Anders Carlssone8bfe412010-02-02 05:17:25 +00001247 const CXXRecordDecl *RD = cast<CXXRecordDecl>(RT->getDecl());
John McCall0217dfc22011-02-15 06:40:56 +00001248 return ::EmitNullConstant(*this, RD, /*complete object*/ true);
Anders Carlssond606de72009-08-23 01:25:01 +00001249 }
Mike Stump11289f42009-09-09 15:08:12 +00001250
Anders Carlssonbe48c542010-05-18 16:51:41 +00001251 assert(T->isMemberPointerType() && "Should only see member pointers here!");
Anders Carlssone8bfe412010-02-02 05:17:25 +00001252 assert(!T->getAs<MemberPointerType>()->getPointeeType()->isFunctionType() &&
1253 "Should only see pointers to data members here!");
1254
1255 // Itanium C++ ABI 2.3:
1256 // A NULL pointer is represented as -1.
John McCallf3a88602011-02-03 08:15:49 +00001257 return getCXXABI().EmitNullMemberPointer(T->castAs<MemberPointerType>());
Eli Friedman20bb5e02009-04-13 21:47:26 +00001258}