Daniel Dunbar | bd012ff | 2008-07-29 23:18:29 +0000 | [diff] [blame] | 1 | //===-- CodeGenFunction.h - Per-Function state for LLVM CodeGen -*- C++ -*-===// |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 2 | // |
| 3 | // The LLVM Compiler Infrastructure |
| 4 | // |
Chris Lattner | 0bc735f | 2007-12-29 19:59:25 +0000 | [diff] [blame] | 5 | // This file is distributed under the University of Illinois Open Source |
| 6 | // License. See LICENSE.TXT for details. |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 7 | // |
| 8 | //===----------------------------------------------------------------------===// |
| 9 | // |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 10 | // This is the internal per-function state used for llvm translation. |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 11 | // |
| 12 | //===----------------------------------------------------------------------===// |
| 13 | |
Chris Lattner | ef52a2f | 2008-02-29 17:10:38 +0000 | [diff] [blame] | 14 | #ifndef CLANG_CODEGEN_CODEGENFUNCTION_H |
| 15 | #define CLANG_CODEGEN_CODEGENFUNCTION_H |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 16 | |
Chris Lattner | 391d77a | 2008-03-30 23:03:07 +0000 | [diff] [blame] | 17 | #include "clang/AST/Type.h" |
Argyrios Kyrtzidis | e3a09e6 | 2008-09-10 02:36:38 +0000 | [diff] [blame] | 18 | #include "clang/AST/ExprCXX.h" |
Ted Kremenek | 5549976 | 2008-06-17 02:43:46 +0000 | [diff] [blame] | 19 | #include "clang/AST/ExprObjC.h" |
Ken Dyck | 199c3d6 | 2010-01-11 17:06:35 +0000 | [diff] [blame] | 20 | #include "clang/AST/CharUnits.h" |
Chris Lattner | 481769b | 2009-03-31 22:17:44 +0000 | [diff] [blame] | 21 | #include "clang/Basic/TargetInfo.h" |
| 22 | #include "llvm/ADT/DenseMap.h" |
| 23 | #include "llvm/ADT/SmallVector.h" |
| 24 | #include "llvm/Support/ValueHandle.h" |
Owen Anderson | 6924382 | 2009-07-13 04:10:07 +0000 | [diff] [blame] | 25 | #include "CodeGenModule.h" |
Mike Stump | 96bd13a | 2009-03-04 15:32:52 +0000 | [diff] [blame] | 26 | #include "CGBlocks.h" |
Daniel Dunbar | 45d196b | 2008-11-01 01:53:16 +0000 | [diff] [blame] | 27 | #include "CGBuilder.h" |
Daniel Dunbar | 0dbe227 | 2008-09-08 21:33:45 +0000 | [diff] [blame] | 28 | #include "CGCall.h" |
Anders Carlsson | b14095a | 2009-04-17 00:06:03 +0000 | [diff] [blame] | 29 | #include "CGCXX.h" |
Daniel Dunbar | 8f2926b | 2008-08-23 03:46:30 +0000 | [diff] [blame] | 30 | #include "CGValue.h" |
| 31 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 32 | namespace llvm { |
Daniel Dunbar | c4a1dea | 2008-08-11 05:35:13 +0000 | [diff] [blame] | 33 | class BasicBlock; |
Benjamin Kramer | f21efe9 | 2009-08-11 17:46:57 +0000 | [diff] [blame] | 34 | class LLVMContext; |
David Chisnall | dd5c98f | 2010-05-01 11:15:56 +0000 | [diff] [blame] | 35 | class MDNode; |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 36 | class Module; |
Daniel Dunbar | 898d508 | 2008-09-30 01:06:03 +0000 | [diff] [blame] | 37 | class SwitchInst; |
Daniel Dunbar | 259e9cc | 2009-10-19 01:21:05 +0000 | [diff] [blame] | 38 | class Twine; |
Daniel Dunbar | ed3849b | 2008-11-19 09:36:46 +0000 | [diff] [blame] | 39 | class Value; |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 40 | class CallSite; |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 41 | } |
| 42 | |
| 43 | namespace clang { |
| 44 | class ASTContext; |
Anders Carlsson | 7267c16 | 2009-05-29 21:03:38 +0000 | [diff] [blame] | 45 | class CXXDestructorDecl; |
Anders Carlsson | 6815e94 | 2009-09-27 18:58:34 +0000 | [diff] [blame] | 46 | class CXXTryStmt; |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 47 | class Decl; |
Daniel Dunbar | c4a1dea | 2008-08-11 05:35:13 +0000 | [diff] [blame] | 48 | class EnumConstantDecl; |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 49 | class FunctionDecl; |
Douglas Gregor | 72564e7 | 2009-02-26 23:50:07 +0000 | [diff] [blame] | 50 | class FunctionProtoType; |
Daniel Dunbar | c4a1dea | 2008-08-11 05:35:13 +0000 | [diff] [blame] | 51 | class LabelStmt; |
Fariborz Jahanian | 679a502 | 2009-01-10 21:06:09 +0000 | [diff] [blame] | 52 | class ObjCContainerDecl; |
Daniel Dunbar | 29e0bcc | 2008-09-24 04:00:38 +0000 | [diff] [blame] | 53 | class ObjCInterfaceDecl; |
| 54 | class ObjCIvarDecl; |
Chris Lattner | 391d77a | 2008-03-30 23:03:07 +0000 | [diff] [blame] | 55 | class ObjCMethodDecl; |
Fariborz Jahanian | fef30b5 | 2008-12-09 20:23:04 +0000 | [diff] [blame] | 56 | class ObjCImplementationDecl; |
Daniel Dunbar | af05bb9 | 2008-08-26 08:29:31 +0000 | [diff] [blame] | 57 | class ObjCPropertyImplDecl; |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 58 | class TargetInfo; |
John McCall | 492c4f9 | 2010-03-03 04:15:11 +0000 | [diff] [blame] | 59 | class TargetCodeGenInfo; |
Daniel Dunbar | c4a1dea | 2008-08-11 05:35:13 +0000 | [diff] [blame] | 60 | class VarDecl; |
Chris Lattner | 16f0049 | 2009-04-26 01:32:48 +0000 | [diff] [blame] | 61 | class ObjCForCollectionStmt; |
| 62 | class ObjCAtTryStmt; |
| 63 | class ObjCAtThrowStmt; |
| 64 | class ObjCAtSynchronizedStmt; |
Devang Patel | b84a06e | 2007-10-23 02:10:49 +0000 | [diff] [blame] | 65 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 66 | namespace CodeGen { |
Devang Patel | b84a06e | 2007-10-23 02:10:49 +0000 | [diff] [blame] | 67 | class CodeGenTypes; |
Anders Carlsson | e896d98 | 2009-02-13 08:11:52 +0000 | [diff] [blame] | 68 | class CGDebugInfo; |
Daniel Dunbar | bb36d33 | 2009-02-02 21:43:58 +0000 | [diff] [blame] | 69 | class CGFunctionInfo; |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 70 | class CGRecordLayout; |
John McCall | ee50429 | 2010-05-21 04:11:14 +0000 | [diff] [blame] | 71 | class CGBlockInfo; |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 72 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 73 | /// A branch fixup. These are required when emitting a goto to a |
| 74 | /// label which hasn't been emitted yet. The goto is optimistically |
| 75 | /// emitted as a branch to the basic block for the label, and (if it |
| 76 | /// occurs in a scope with non-trivial cleanups) a fixup is added to |
| 77 | /// the innermost cleanup. When a (normal) cleanup is popped, any |
| 78 | /// unresolved fixups in that scope are threaded through the cleanup. |
| 79 | struct BranchFixup { |
| 80 | /// The origin of the branch. Any switch-index stores required by |
| 81 | /// cleanup threading are added before this instruction. |
| 82 | llvm::Instruction *Origin; |
| 83 | |
| 84 | /// The destination of the branch. |
| 85 | /// |
| 86 | /// This can be set to null to indicate that this fixup was |
| 87 | /// successfully resolved. |
| 88 | llvm::BasicBlock *Destination; |
| 89 | |
| 90 | /// The last branch of the fixup. It is an invariant that |
| 91 | /// LatestBranch->getSuccessor(LatestBranchIndex) == Destination. |
| 92 | /// |
| 93 | /// The branch is always either a BranchInst or a SwitchInst. |
| 94 | llvm::TerminatorInst *LatestBranch; |
| 95 | unsigned LatestBranchIndex; |
| 96 | }; |
| 97 | |
John McCall | da65ea8 | 2010-07-13 20:32:21 +0000 | [diff] [blame] | 98 | enum CleanupKind { NormalAndEHCleanup, EHCleanup, NormalCleanup }; |
| 99 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 100 | /// A stack of scopes which respond to exceptions, including cleanups |
| 101 | /// and catch blocks. |
| 102 | class EHScopeStack { |
| 103 | public: |
| 104 | /// A saved depth on the scope stack. This is necessary because |
| 105 | /// pushing scopes onto the stack invalidates iterators. |
| 106 | class stable_iterator { |
| 107 | friend class EHScopeStack; |
| 108 | |
| 109 | /// Offset from StartOfData to EndOfBuffer. |
| 110 | ptrdiff_t Size; |
| 111 | |
| 112 | stable_iterator(ptrdiff_t Size) : Size(Size) {} |
| 113 | |
| 114 | public: |
| 115 | static stable_iterator invalid() { return stable_iterator(-1); } |
| 116 | stable_iterator() : Size(-1) {} |
| 117 | |
| 118 | bool isValid() const { return Size >= 0; } |
| 119 | |
| 120 | friend bool operator==(stable_iterator A, stable_iterator B) { |
| 121 | return A.Size == B.Size; |
| 122 | } |
| 123 | friend bool operator!=(stable_iterator A, stable_iterator B) { |
| 124 | return A.Size != B.Size; |
| 125 | } |
| 126 | }; |
| 127 | |
John McCall | 3e29f96 | 2010-07-13 23:19:49 +0000 | [diff] [blame] | 128 | /// A lazy cleanup. Subclasses must be POD-like: cleanups will |
| 129 | /// not be destructed, and they will be allocated on the cleanup |
| 130 | /// stack and freely copied and moved around. |
John McCall | da65ea8 | 2010-07-13 20:32:21 +0000 | [diff] [blame] | 131 | /// |
| 132 | /// LazyCleanup implementations should generally be declared in an |
| 133 | /// anonymous namespace. |
| 134 | class LazyCleanup { |
John McCall | da65ea8 | 2010-07-13 20:32:21 +0000 | [diff] [blame] | 135 | public: |
John McCall | 3e29f96 | 2010-07-13 23:19:49 +0000 | [diff] [blame] | 136 | // Anchor the construction vtable. We use the destructor because |
| 137 | // gcc gives an obnoxious warning if there are virtual methods |
| 138 | // with an accessible non-virtual destructor. Unfortunately, |
| 139 | // declaring this destructor makes it non-trivial, but there |
| 140 | // doesn't seem to be any other way around this warning. |
| 141 | // |
| 142 | // This destructor will never be called. |
| 143 | virtual ~LazyCleanup(); |
| 144 | |
John McCall | da65ea8 | 2010-07-13 20:32:21 +0000 | [diff] [blame] | 145 | /// Emit the cleanup. For normal cleanups, this is run in the |
| 146 | /// same EH context as when the cleanup was pushed, i.e. the |
| 147 | /// immediately-enclosing context of the cleanup scope. For |
| 148 | /// EH cleanups, this is run in a terminate context. |
| 149 | /// |
| 150 | // \param IsForEHCleanup true if this is for an EH cleanup, false |
| 151 | /// if for a normal cleanup. |
| 152 | virtual void Emit(CodeGenFunction &CGF, bool IsForEHCleanup) = 0; |
| 153 | }; |
| 154 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 155 | private: |
| 156 | // The implementation for this class is in CGException.h and |
| 157 | // CGException.cpp; the definition is here because it's used as a |
| 158 | // member of CodeGenFunction. |
| 159 | |
| 160 | /// The start of the scope-stack buffer, i.e. the allocated pointer |
| 161 | /// for the buffer. All of these pointers are either simultaneously |
| 162 | /// null or simultaneously valid. |
| 163 | char *StartOfBuffer; |
| 164 | |
| 165 | /// The end of the buffer. |
| 166 | char *EndOfBuffer; |
| 167 | |
| 168 | /// The first valid entry in the buffer. |
| 169 | char *StartOfData; |
| 170 | |
| 171 | /// The innermost normal cleanup on the stack. |
| 172 | stable_iterator InnermostNormalCleanup; |
| 173 | |
| 174 | /// The innermost EH cleanup on the stack. |
| 175 | stable_iterator InnermostEHCleanup; |
| 176 | |
| 177 | /// The number of catches on the stack. |
| 178 | unsigned CatchDepth; |
| 179 | |
| 180 | /// The current set of branch fixups. A branch fixup is a jump to |
| 181 | /// an as-yet unemitted label, i.e. a label for which we don't yet |
| 182 | /// know the EH stack depth. Whenever we pop a cleanup, we have |
| 183 | /// to thread all the current branch fixups through it. |
| 184 | /// |
| 185 | /// Fixups are recorded as the Use of the respective branch or |
| 186 | /// switch statement. The use points to the final destination. |
| 187 | /// When popping out of a cleanup, these uses are threaded through |
| 188 | /// the cleanup and adjusted to point to the new cleanup. |
| 189 | /// |
| 190 | /// Note that branches are allowed to jump into protected scopes |
| 191 | /// in certain situations; e.g. the following code is legal: |
| 192 | /// struct A { ~A(); }; // trivial ctor, non-trivial dtor |
| 193 | /// goto foo; |
| 194 | /// A a; |
| 195 | /// foo: |
| 196 | /// bar(); |
| 197 | llvm::SmallVector<BranchFixup, 8> BranchFixups; |
| 198 | |
| 199 | char *allocate(size_t Size); |
| 200 | |
| 201 | void popNullFixups(); |
| 202 | |
John McCall | da65ea8 | 2010-07-13 20:32:21 +0000 | [diff] [blame] | 203 | void *pushLazyCleanup(CleanupKind K, size_t DataSize); |
| 204 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 205 | public: |
| 206 | EHScopeStack() : StartOfBuffer(0), EndOfBuffer(0), StartOfData(0), |
| 207 | InnermostNormalCleanup(stable_end()), |
| 208 | InnermostEHCleanup(stable_end()), |
| 209 | CatchDepth(0) {} |
| 210 | ~EHScopeStack() { delete[] StartOfBuffer; } |
| 211 | |
John McCall | da65ea8 | 2010-07-13 20:32:21 +0000 | [diff] [blame] | 212 | // Variadic templates would make this not terrible. |
| 213 | |
| 214 | /// Push a lazily-created cleanup on the stack. |
John McCall | 8e3f861 | 2010-07-13 22:12:14 +0000 | [diff] [blame] | 215 | template <class T> |
| 216 | void pushLazyCleanup(CleanupKind Kind) { |
| 217 | void *Buffer = pushLazyCleanup(Kind, sizeof(T)); |
| 218 | LazyCleanup *Obj = new(Buffer) T(); |
| 219 | (void) Obj; |
| 220 | } |
| 221 | |
| 222 | /// Push a lazily-created cleanup on the stack. |
| 223 | template <class T, class A0> |
| 224 | void pushLazyCleanup(CleanupKind Kind, A0 a0) { |
| 225 | void *Buffer = pushLazyCleanup(Kind, sizeof(T)); |
| 226 | LazyCleanup *Obj = new(Buffer) T(a0); |
| 227 | (void) Obj; |
| 228 | } |
| 229 | |
| 230 | /// Push a lazily-created cleanup on the stack. |
John McCall | da65ea8 | 2010-07-13 20:32:21 +0000 | [diff] [blame] | 231 | template <class T, class A0, class A1> |
| 232 | void pushLazyCleanup(CleanupKind Kind, A0 a0, A1 a1) { |
| 233 | void *Buffer = pushLazyCleanup(Kind, sizeof(T)); |
| 234 | LazyCleanup *Obj = new(Buffer) T(a0, a1); |
| 235 | (void) Obj; |
| 236 | } |
| 237 | |
| 238 | /// Push a lazily-created cleanup on the stack. |
| 239 | template <class T, class A0, class A1, class A2> |
| 240 | void pushLazyCleanup(CleanupKind Kind, A0 a0, A1 a1, A2 a2) { |
| 241 | void *Buffer = pushLazyCleanup(Kind, sizeof(T)); |
| 242 | LazyCleanup *Obj = new(Buffer) T(a0, a1, a2); |
| 243 | (void) Obj; |
| 244 | } |
| 245 | |
| 246 | /// Push a lazily-created cleanup on the stack. |
| 247 | template <class T, class A0, class A1, class A2, class A3> |
| 248 | void pushLazyCleanup(CleanupKind Kind, A0 a0, A1 a1, A2 a2, A3 a3) { |
| 249 | void *Buffer = pushLazyCleanup(Kind, sizeof(T)); |
| 250 | LazyCleanup *Obj = new(Buffer) T(a0, a1, a2, a3); |
| 251 | (void) Obj; |
| 252 | } |
| 253 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 254 | /// Push a cleanup on the stack. |
| 255 | void pushCleanup(llvm::BasicBlock *NormalEntry, |
| 256 | llvm::BasicBlock *NormalExit, |
| 257 | llvm::BasicBlock *EHEntry, |
| 258 | llvm::BasicBlock *EHExit); |
| 259 | |
| 260 | /// Pops a cleanup scope off the stack. This should only be called |
| 261 | /// by CodeGenFunction::PopCleanupBlock. |
| 262 | void popCleanup(); |
| 263 | |
| 264 | /// Push a set of catch handlers on the stack. The catch is |
| 265 | /// uninitialized and will need to have the given number of handlers |
| 266 | /// set on it. |
| 267 | class EHCatchScope *pushCatch(unsigned NumHandlers); |
| 268 | |
| 269 | /// Pops a catch scope off the stack. |
| 270 | void popCatch(); |
| 271 | |
| 272 | /// Push an exceptions filter on the stack. |
| 273 | class EHFilterScope *pushFilter(unsigned NumFilters); |
| 274 | |
| 275 | /// Pops an exceptions filter off the stack. |
| 276 | void popFilter(); |
| 277 | |
| 278 | /// Push a terminate handler on the stack. |
| 279 | void pushTerminate(); |
| 280 | |
| 281 | /// Pops a terminate handler off the stack. |
| 282 | void popTerminate(); |
| 283 | |
| 284 | /// Determines whether the exception-scopes stack is empty. |
| 285 | bool empty() const { return StartOfData == EndOfBuffer; } |
| 286 | |
| 287 | bool requiresLandingPad() const { |
| 288 | return (CatchDepth || hasEHCleanups()); |
| 289 | } |
| 290 | |
| 291 | /// Determines whether there are any normal cleanups on the stack. |
| 292 | bool hasNormalCleanups() const { |
| 293 | return InnermostNormalCleanup != stable_end(); |
| 294 | } |
| 295 | |
| 296 | /// Returns the innermost normal cleanup on the stack, or |
| 297 | /// stable_end() if there are no normal cleanups. |
| 298 | stable_iterator getInnermostNormalCleanup() const { |
| 299 | return InnermostNormalCleanup; |
| 300 | } |
| 301 | |
| 302 | /// Determines whether there are any EH cleanups on the stack. |
| 303 | bool hasEHCleanups() const { |
| 304 | return InnermostEHCleanup != stable_end(); |
| 305 | } |
| 306 | |
| 307 | /// Returns the innermost EH cleanup on the stack, or stable_end() |
| 308 | /// if there are no EH cleanups. |
| 309 | stable_iterator getInnermostEHCleanup() const { |
| 310 | return InnermostEHCleanup; |
| 311 | } |
| 312 | |
| 313 | /// An unstable reference to a scope-stack depth. Invalidated by |
| 314 | /// pushes but not pops. |
| 315 | class iterator; |
| 316 | |
| 317 | /// Returns an iterator pointing to the innermost EH scope. |
| 318 | iterator begin() const; |
| 319 | |
| 320 | /// Returns an iterator pointing to the outermost EH scope. |
| 321 | iterator end() const; |
| 322 | |
| 323 | /// Create a stable reference to the top of the EH stack. The |
| 324 | /// returned reference is valid until that scope is popped off the |
| 325 | /// stack. |
| 326 | stable_iterator stable_begin() const { |
| 327 | return stable_iterator(EndOfBuffer - StartOfData); |
| 328 | } |
| 329 | |
| 330 | /// Create a stable reference to the bottom of the EH stack. |
| 331 | static stable_iterator stable_end() { |
| 332 | return stable_iterator(0); |
| 333 | } |
| 334 | |
| 335 | /// Translates an iterator into a stable_iterator. |
| 336 | stable_iterator stabilize(iterator it) const; |
| 337 | |
| 338 | /// Finds the nearest cleanup enclosing the given iterator. |
| 339 | /// Returns stable_iterator::invalid() if there are no such cleanups. |
| 340 | stable_iterator getEnclosingEHCleanup(iterator it) const; |
| 341 | |
| 342 | /// Turn a stable reference to a scope depth into a unstable pointer |
| 343 | /// to the EH stack. |
| 344 | iterator find(stable_iterator save) const; |
| 345 | |
| 346 | /// Removes the cleanup pointed to by the given stable_iterator. |
| 347 | void removeCleanup(stable_iterator save); |
| 348 | |
| 349 | /// Add a branch fixup to the current cleanup scope. |
| 350 | BranchFixup &addBranchFixup() { |
| 351 | assert(hasNormalCleanups() && "adding fixup in scope without cleanups"); |
| 352 | BranchFixups.push_back(BranchFixup()); |
| 353 | return BranchFixups.back(); |
| 354 | } |
| 355 | |
| 356 | unsigned getNumBranchFixups() const { return BranchFixups.size(); } |
| 357 | BranchFixup &getBranchFixup(unsigned I) { |
| 358 | assert(I < getNumBranchFixups()); |
| 359 | return BranchFixups[I]; |
| 360 | } |
| 361 | |
| 362 | /// Mark any branch fixups leading to the given block as resolved. |
| 363 | void resolveBranchFixups(llvm::BasicBlock *Dest); |
| 364 | }; |
| 365 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 366 | /// CodeGenFunction - This class organizes the per-function state that is used |
| 367 | /// while generating LLVM code. |
Mike Stump | 2a99814 | 2009-03-04 18:17:45 +0000 | [diff] [blame] | 368 | class CodeGenFunction : public BlockFunction { |
Anders Carlsson | 8a219ce | 2009-02-24 04:21:31 +0000 | [diff] [blame] | 369 | CodeGenFunction(const CodeGenFunction&); // DO NOT IMPLEMENT |
| 370 | void operator=(const CodeGenFunction&); // DO NOT IMPLEMENT |
Chris Lattner | bfc0c1a | 2007-08-26 23:13:56 +0000 | [diff] [blame] | 371 | public: |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 372 | /// A jump destination is a pair of a basic block and a cleanup |
| 373 | /// depth. They are used to implement direct jumps across cleanup |
| 374 | /// scopes, e.g. goto, break, continue, and return. |
| 375 | struct JumpDest { |
| 376 | JumpDest() : Block(0), ScopeDepth() {} |
| 377 | JumpDest(llvm::BasicBlock *Block, EHScopeStack::stable_iterator Depth) |
| 378 | : Block(Block), ScopeDepth(Depth) {} |
| 379 | |
| 380 | llvm::BasicBlock *Block; |
| 381 | EHScopeStack::stable_iterator ScopeDepth; |
| 382 | }; |
| 383 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 384 | CodeGenModule &CGM; // Per-module state. |
Daniel Dunbar | 444be73 | 2009-11-13 05:51:54 +0000 | [diff] [blame] | 385 | const TargetInfo &Target; |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 386 | |
Chris Lattner | 58dee10 | 2007-08-21 16:57:55 +0000 | [diff] [blame] | 387 | typedef std::pair<llvm::Value *, llvm::Value *> ComplexPairTy; |
Daniel Dunbar | 45d196b | 2008-11-01 01:53:16 +0000 | [diff] [blame] | 388 | CGBuilderTy Builder; |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 389 | |
Chris Lattner | b5437d2 | 2009-04-23 05:30:27 +0000 | [diff] [blame] | 390 | /// CurFuncDecl - Holds the Decl for the current function or ObjC method. |
| 391 | /// This excludes BlockDecls. |
Chris Lattner | 4111024 | 2008-06-17 18:05:57 +0000 | [diff] [blame] | 392 | const Decl *CurFuncDecl; |
Chris Lattner | b5437d2 | 2009-04-23 05:30:27 +0000 | [diff] [blame] | 393 | /// CurCodeDecl - This is the inner-most code context, which includes blocks. |
| 394 | const Decl *CurCodeDecl; |
Daniel Dunbar | 88b5396 | 2009-02-02 22:03:45 +0000 | [diff] [blame] | 395 | const CGFunctionInfo *CurFnInfo; |
Chris Lattner | 391d77a | 2008-03-30 23:03:07 +0000 | [diff] [blame] | 396 | QualType FnRetTy; |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 397 | llvm::Function *CurFn; |
| 398 | |
Mike Stump | 6a1e0eb | 2009-12-04 23:26:17 +0000 | [diff] [blame] | 399 | /// CurGD - The GlobalDecl for the current function being compiled. |
| 400 | GlobalDecl CurGD; |
Mike Stump | 6a1e0eb | 2009-12-04 23:26:17 +0000 | [diff] [blame] | 401 | |
Daniel Dunbar | 5ca2084 | 2008-09-09 21:00:17 +0000 | [diff] [blame] | 402 | /// ReturnBlock - Unified return block. |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 403 | JumpDest ReturnBlock; |
| 404 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 405 | /// ReturnValue - The temporary alloca to hold the return value. This is null |
| 406 | /// iff the function has no return value. |
Eli Friedman | b17daf9 | 2009-12-04 02:43:40 +0000 | [diff] [blame] | 407 | llvm::Value *ReturnValue; |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 408 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 409 | /// AllocaInsertPoint - This is an instruction in the entry block before which |
| 410 | /// we prefer to insert allocas. |
Chris Lattner | 481769b | 2009-03-31 22:17:44 +0000 | [diff] [blame] | 411 | llvm::AssertingVH<llvm::Instruction> AllocaInsertPt; |
Daniel Dunbar | 0ffb125 | 2008-08-04 16:51:22 +0000 | [diff] [blame] | 412 | |
Chris Lattner | 77b89b8 | 2010-06-27 07:15:29 +0000 | [diff] [blame] | 413 | // intptr_t, i32, i64 |
| 414 | const llvm::IntegerType *IntPtrTy, *Int32Ty, *Int64Ty; |
Hartmut Kaiser | 7b66000 | 2007-10-17 15:00:17 +0000 | [diff] [blame] | 415 | uint32_t LLVMPointerWidth; |
Daniel Dunbar | 18ccc77 | 2008-09-28 01:03:14 +0000 | [diff] [blame] | 416 | |
Mike Stump | d88ea56 | 2009-12-09 03:35:49 +0000 | [diff] [blame] | 417 | bool Exceptions; |
Mike Stump | 9c276ae | 2009-12-12 01:27:46 +0000 | [diff] [blame] | 418 | bool CatchUndefined; |
Douglas Gregor | 3d91bbc | 2010-05-17 15:52:46 +0000 | [diff] [blame] | 419 | |
| 420 | /// \brief A mapping from NRVO variables to the flags used to indicate |
| 421 | /// when the NRVO has been applied to this variable. |
| 422 | llvm::DenseMap<const VarDecl *, llvm::Value *> NRVOFlags; |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 423 | |
| 424 | EHScopeStack EHStack; |
| 425 | |
| 426 | /// The exception slot. All landing pads write the current |
| 427 | /// exception pointer into this alloca. |
| 428 | llvm::Value *ExceptionSlot; |
| 429 | |
| 430 | /// Emits a landing pad for the current EH stack. |
| 431 | llvm::BasicBlock *EmitLandingPad(); |
| 432 | |
| 433 | llvm::BasicBlock *getInvokeDestImpl(); |
| 434 | |
Daniel Dunbar | 18ccc77 | 2008-09-28 01:03:14 +0000 | [diff] [blame] | 435 | public: |
Anders Carlsson | fa1f756 | 2009-02-10 06:07:49 +0000 | [diff] [blame] | 436 | /// ObjCEHValueStack - Stack of Objective-C exception values, used for |
| 437 | /// rethrows. |
Anders Carlsson | 273558f | 2009-02-07 21:37:21 +0000 | [diff] [blame] | 438 | llvm::SmallVector<llvm::Value*, 8> ObjCEHValueStack; |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 439 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 440 | // A struct holding information about a finally block's IR |
| 441 | // generation. For now, doesn't actually hold anything. |
| 442 | struct FinallyInfo { |
Anders Carlsson | bb66f9f | 2009-02-08 07:46:24 +0000 | [diff] [blame] | 443 | }; |
| 444 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 445 | FinallyInfo EnterFinallyBlock(const Stmt *Stmt, |
| 446 | llvm::Constant *BeginCatchFn, |
| 447 | llvm::Constant *EndCatchFn, |
| 448 | llvm::Constant *RethrowFn); |
| 449 | void ExitFinallyBlock(FinallyInfo &FinallyInfo); |
Mike Stump | d88ea56 | 2009-12-09 03:35:49 +0000 | [diff] [blame] | 450 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 451 | /// PushDestructorCleanup - Push a cleanup to call the |
| 452 | /// complete-object destructor of an object of the given type at the |
| 453 | /// given address. Does nothing if T is not a C++ class type with a |
| 454 | /// non-trivial destructor. |
| 455 | void PushDestructorCleanup(QualType T, llvm::Value *Addr); |
| 456 | |
| 457 | /// PopCleanupBlock - Will pop the cleanup entry on the stack and |
| 458 | /// process all branch fixups. |
| 459 | void PopCleanupBlock(); |
| 460 | |
| 461 | /// CleanupBlock - RAII object that will create a cleanup block and |
| 462 | /// set the insert point to that block. When destructed, it sets the |
| 463 | /// insert point to the previous block and pushes a new cleanup |
| 464 | /// entry on the stack. |
| 465 | class CleanupBlock { |
| 466 | CodeGenFunction &CGF; |
| 467 | CGBuilderTy::InsertPoint SavedIP; |
| 468 | llvm::BasicBlock *NormalCleanupEntryBB; |
| 469 | llvm::BasicBlock *NormalCleanupExitBB; |
| 470 | llvm::BasicBlock *EHCleanupEntryBB; |
Fariborz Jahanian | 7799621 | 2009-11-04 17:57:40 +0000 | [diff] [blame] | 471 | |
Anders Carlsson | 0d5c685 | 2009-02-07 23:30:41 +0000 | [diff] [blame] | 472 | public: |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 473 | CleanupBlock(CodeGenFunction &CGF, CleanupKind Kind); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 474 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 475 | /// If we're currently writing a normal cleanup, tie that off and |
| 476 | /// start writing an EH cleanup. |
| 477 | void beginEHCleanup(); |
Fariborz Jahanian | 7799621 | 2009-11-04 17:57:40 +0000 | [diff] [blame] | 478 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 479 | ~CleanupBlock(); |
Anders Carlsson | 0d5c685 | 2009-02-07 23:30:41 +0000 | [diff] [blame] | 480 | }; |
| 481 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 482 | /// \brief Enters a new scope for capturing cleanups, all of which |
| 483 | /// will be executed once the scope is exited. |
| 484 | class RunCleanupsScope { |
Douglas Gregor | 01234bb | 2009-11-24 16:43:22 +0000 | [diff] [blame] | 485 | CodeGenFunction& CGF; |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 486 | EHScopeStack::stable_iterator CleanupStackDepth; |
Douglas Gregor | 01234bb | 2009-11-24 16:43:22 +0000 | [diff] [blame] | 487 | bool OldDidCallStackSave; |
Douglas Gregor | 5656e14 | 2009-11-24 21:15:44 +0000 | [diff] [blame] | 488 | bool PerformCleanup; |
Douglas Gregor | 01234bb | 2009-11-24 16:43:22 +0000 | [diff] [blame] | 489 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 490 | RunCleanupsScope(const RunCleanupsScope &); // DO NOT IMPLEMENT |
| 491 | RunCleanupsScope &operator=(const RunCleanupsScope &); // DO NOT IMPLEMENT |
Douglas Gregor | 01234bb | 2009-11-24 16:43:22 +0000 | [diff] [blame] | 492 | |
| 493 | public: |
| 494 | /// \brief Enter a new cleanup scope. |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 495 | explicit RunCleanupsScope(CodeGenFunction &CGF) |
Douglas Gregor | 5656e14 | 2009-11-24 21:15:44 +0000 | [diff] [blame] | 496 | : CGF(CGF), PerformCleanup(true) |
| 497 | { |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 498 | CleanupStackDepth = CGF.EHStack.stable_begin(); |
Douglas Gregor | 01234bb | 2009-11-24 16:43:22 +0000 | [diff] [blame] | 499 | OldDidCallStackSave = CGF.DidCallStackSave; |
| 500 | } |
| 501 | |
| 502 | /// \brief Exit this cleanup scope, emitting any accumulated |
| 503 | /// cleanups. |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 504 | ~RunCleanupsScope() { |
Douglas Gregor | 5656e14 | 2009-11-24 21:15:44 +0000 | [diff] [blame] | 505 | if (PerformCleanup) { |
| 506 | CGF.DidCallStackSave = OldDidCallStackSave; |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 507 | CGF.PopCleanupBlocks(CleanupStackDepth); |
Douglas Gregor | 5656e14 | 2009-11-24 21:15:44 +0000 | [diff] [blame] | 508 | } |
| 509 | } |
| 510 | |
| 511 | /// \brief Determine whether this scope requires any cleanups. |
| 512 | bool requiresCleanups() const { |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 513 | return CGF.EHStack.stable_begin() != CleanupStackDepth; |
Douglas Gregor | 5656e14 | 2009-11-24 21:15:44 +0000 | [diff] [blame] | 514 | } |
| 515 | |
| 516 | /// \brief Force the emission of cleanups now, instead of waiting |
| 517 | /// until this object is destroyed. |
| 518 | void ForceCleanup() { |
| 519 | assert(PerformCleanup && "Already forced cleanup"); |
Douglas Gregor | 01234bb | 2009-11-24 16:43:22 +0000 | [diff] [blame] | 520 | CGF.DidCallStackSave = OldDidCallStackSave; |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 521 | CGF.PopCleanupBlocks(CleanupStackDepth); |
Douglas Gregor | 5656e14 | 2009-11-24 21:15:44 +0000 | [diff] [blame] | 522 | PerformCleanup = false; |
Douglas Gregor | 01234bb | 2009-11-24 16:43:22 +0000 | [diff] [blame] | 523 | } |
| 524 | }; |
| 525 | |
Anders Carlsson | 44ec82b | 2010-03-30 03:14:41 +0000 | [diff] [blame] | 526 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 527 | /// PopCleanupBlocks - Takes the old cleanup stack size and emits |
| 528 | /// the cleanup blocks that have been added. |
| 529 | void PopCleanupBlocks(EHScopeStack::stable_iterator OldCleanupStackSize); |
Anders Carlsson | 44ec82b | 2010-03-30 03:14:41 +0000 | [diff] [blame] | 530 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 531 | /// The given basic block lies in the current EH scope, but may be a |
| 532 | /// target of a potentially scope-crossing jump; get a stable handle |
| 533 | /// to which we can perform this jump later. |
| 534 | JumpDest getJumpDestInCurrentScope(llvm::BasicBlock *Target) const { |
| 535 | return JumpDest(Target, EHStack.stable_begin()); |
| 536 | } |
Anders Carlsson | c71c845 | 2009-02-07 23:50:39 +0000 | [diff] [blame] | 537 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 538 | /// The given basic block lies in the current EH scope, but may be a |
| 539 | /// target of a potentially scope-crossing jump; get a stable handle |
| 540 | /// to which we can perform this jump later. |
| 541 | JumpDest getJumpDestInCurrentScope(const char *Name = 0) { |
| 542 | return JumpDest(createBasicBlock(Name), EHStack.stable_begin()); |
| 543 | } |
| 544 | |
| 545 | /// EmitBranchThroughCleanup - Emit a branch from the current insert |
| 546 | /// block through the normal cleanup handling code (if any) and then |
| 547 | /// on to \arg Dest. |
| 548 | void EmitBranchThroughCleanup(JumpDest Dest); |
| 549 | |
| 550 | /// EmitBranchThroughEHCleanup - Emit a branch from the current |
| 551 | /// insert block through the EH cleanup handling code (if any) and |
| 552 | /// then on to \arg Dest. |
| 553 | void EmitBranchThroughEHCleanup(JumpDest Dest); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 554 | |
Anders Carlsson | 72119a8 | 2010-02-04 17:18:07 +0000 | [diff] [blame] | 555 | /// BeginConditionalBranch - Should be called before a conditional part of an |
Anders Carlsson | a36bf8f | 2009-11-20 17:27:56 +0000 | [diff] [blame] | 556 | /// expression is emitted. For example, before the RHS of the expression below |
| 557 | /// is emitted: |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 558 | /// |
Anders Carlsson | 1d84750 | 2009-06-04 02:22:12 +0000 | [diff] [blame] | 559 | /// b && f(T()); |
| 560 | /// |
Anders Carlsson | a36bf8f | 2009-11-20 17:27:56 +0000 | [diff] [blame] | 561 | /// This is used to make sure that any temporaries created in the conditional |
Anders Carlsson | 1d84750 | 2009-06-04 02:22:12 +0000 | [diff] [blame] | 562 | /// branch are only destroyed if the branch is taken. |
Anders Carlsson | 72119a8 | 2010-02-04 17:18:07 +0000 | [diff] [blame] | 563 | void BeginConditionalBranch() { |
Anders Carlsson | a36bf8f | 2009-11-20 17:27:56 +0000 | [diff] [blame] | 564 | ++ConditionalBranchLevel; |
| 565 | } |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 566 | |
Anders Carlsson | 72119a8 | 2010-02-04 17:18:07 +0000 | [diff] [blame] | 567 | /// EndConditionalBranch - Should be called after a conditional part of an |
Anders Carlsson | a36bf8f | 2009-11-20 17:27:56 +0000 | [diff] [blame] | 568 | /// expression has been emitted. |
Anders Carlsson | 72119a8 | 2010-02-04 17:18:07 +0000 | [diff] [blame] | 569 | void EndConditionalBranch() { |
Anders Carlsson | 08e9e45 | 2010-01-24 00:20:05 +0000 | [diff] [blame] | 570 | assert(ConditionalBranchLevel != 0 && |
| 571 | "Conditional branch mismatch!"); |
| 572 | |
Anders Carlsson | a36bf8f | 2009-11-20 17:27:56 +0000 | [diff] [blame] | 573 | --ConditionalBranchLevel; |
| 574 | } |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 575 | |
Chris Lattner | 7f02f72 | 2007-08-24 05:35:26 +0000 | [diff] [blame] | 576 | private: |
Chris Lattner | d9becd1 | 2009-10-28 23:59:40 +0000 | [diff] [blame] | 577 | CGDebugInfo *DebugInfo; |
Mike Stump | 09429b9 | 2009-02-17 17:00:02 +0000 | [diff] [blame] | 578 | |
Mike Stump | f71d232 | 2009-11-30 20:08:49 +0000 | [diff] [blame] | 579 | /// IndirectBranch - The first time an indirect goto is seen we create a block |
| 580 | /// with an indirect branch. Every time we see the address of a label taken, |
| 581 | /// we add the label to the indirect goto. Every subsequent indirect goto is |
| 582 | /// codegen'd as a jump to the IndirectBranch's basic block. |
Chris Lattner | d9becd1 | 2009-10-28 23:59:40 +0000 | [diff] [blame] | 583 | llvm::IndirectBrInst *IndirectBranch; |
Daniel Dunbar | 0ffb125 | 2008-08-04 16:51:22 +0000 | [diff] [blame] | 584 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 585 | /// LocalDeclMap - This keeps track of the LLVM allocas or globals for local C |
| 586 | /// decls. |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 587 | llvm::DenseMap<const Decl*, llvm::Value*> LocalDeclMap; |
| 588 | |
| 589 | /// LabelMap - This keeps track of the LLVM basic block for each C label. |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 590 | llvm::DenseMap<const LabelStmt*, JumpDest> LabelMap; |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 591 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 592 | // BreakContinueStack - This keeps track of where break and continue |
Anders Carlsson | e4b6d34 | 2009-02-10 05:52:02 +0000 | [diff] [blame] | 593 | // statements should jump to. |
Chris Lattner | da13870 | 2007-07-16 21:28:45 +0000 | [diff] [blame] | 594 | struct BreakContinue { |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 595 | BreakContinue(JumpDest Break, JumpDest Continue) |
| 596 | : BreakBlock(Break), ContinueBlock(Continue) {} |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 597 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 598 | JumpDest BreakBlock; |
| 599 | JumpDest ContinueBlock; |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 600 | }; |
Chris Lattner | da13870 | 2007-07-16 21:28:45 +0000 | [diff] [blame] | 601 | llvm::SmallVector<BreakContinue, 8> BreakContinueStack; |
Daniel Dunbar | 18ccc77 | 2008-09-28 01:03:14 +0000 | [diff] [blame] | 602 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 603 | /// SwitchInsn - This is nearest current switch instruction. It is null if if |
| 604 | /// current context is not in a switch. |
Devang Patel | 51b09f2 | 2007-10-04 23:45:31 +0000 | [diff] [blame] | 605 | llvm::SwitchInst *SwitchInsn; |
| 606 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 607 | /// CaseRangeBlock - This block holds if condition check for last case |
Devang Patel | 80fd5f9 | 2007-10-09 17:08:50 +0000 | [diff] [blame] | 608 | /// statement range in current switch instruction. |
Devang Patel | c049e4f | 2007-10-08 20:57:48 +0000 | [diff] [blame] | 609 | llvm::BasicBlock *CaseRangeBlock; |
| 610 | |
Daniel Dunbar | 9834ffb | 2009-02-23 17:26:39 +0000 | [diff] [blame] | 611 | /// InvokeDest - This is the nearest exception target for calls |
| 612 | /// which can unwind, when exceptions are being used. |
| 613 | llvm::BasicBlock *InvokeDest; |
| 614 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 615 | // VLASizeMap - This keeps track of the associated size for each VLA type. |
Eli Friedman | bbed6b9 | 2009-08-15 02:50:32 +0000 | [diff] [blame] | 616 | // We track this by the size expression rather than the type itself because |
| 617 | // in certain situations, like a const qualifier applied to an VLA typedef, |
| 618 | // multiple VLA types can share the same size expression. |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 619 | // FIXME: Maybe this could be a stack of maps that is pushed/popped as we |
| 620 | // enter/leave scopes. |
Eli Friedman | bbed6b9 | 2009-08-15 02:50:32 +0000 | [diff] [blame] | 621 | llvm::DenseMap<const Expr*, llvm::Value*> VLASizeMap; |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 622 | |
Anders Carlsson | 4cc1a47 | 2009-02-09 20:20:56 +0000 | [diff] [blame] | 623 | /// DidCallStackSave - Whether llvm.stacksave has been called. Used to avoid |
| 624 | /// calling llvm.stacksave for multiple VLAs in the same scope. |
| 625 | bool DidCallStackSave; |
Mike Stump | 09429b9 | 2009-02-17 17:00:02 +0000 | [diff] [blame] | 626 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 627 | /// A block containing a single 'unreachable' instruction. Created |
| 628 | /// lazily by getUnreachableBlock(). |
| 629 | llvm::BasicBlock *UnreachableBlock; |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 630 | |
Anders Carlsson | f6c56e2 | 2009-11-25 03:15:49 +0000 | [diff] [blame] | 631 | /// CXXThisDecl - When generating code for a C++ member function, |
| 632 | /// this will hold the implicit 'this' declaration. |
Anders Carlsson | 2b77ba8 | 2009-04-04 20:47:02 +0000 | [diff] [blame] | 633 | ImplicitParamDecl *CXXThisDecl; |
John McCall | 2504941 | 2010-02-16 22:04:33 +0000 | [diff] [blame] | 634 | llvm::Value *CXXThisValue; |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 635 | |
Anders Carlsson | f6c56e2 | 2009-11-25 03:15:49 +0000 | [diff] [blame] | 636 | /// CXXVTTDecl - When generating code for a base object constructor or |
| 637 | /// base object destructor with virtual bases, this will hold the implicit |
| 638 | /// VTT parameter. |
| 639 | ImplicitParamDecl *CXXVTTDecl; |
John McCall | 2504941 | 2010-02-16 22:04:33 +0000 | [diff] [blame] | 640 | llvm::Value *CXXVTTValue; |
Anders Carlsson | f6c56e2 | 2009-11-25 03:15:49 +0000 | [diff] [blame] | 641 | |
Anders Carlsson | a36bf8f | 2009-11-20 17:27:56 +0000 | [diff] [blame] | 642 | /// ConditionalBranchLevel - Contains the nesting level of the current |
| 643 | /// conditional branch. This is used so that we know if a temporary should be |
| 644 | /// destroyed conditionally. |
| 645 | unsigned ConditionalBranchLevel; |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 646 | |
Anders Carlsson | 7dfa407 | 2009-09-12 02:14:24 +0000 | [diff] [blame] | 647 | |
| 648 | /// ByrefValueInfoMap - For each __block variable, contains a pair of the LLVM |
| 649 | /// type as well as the field number that contains the actual data. |
| 650 | llvm::DenseMap<const ValueDecl *, std::pair<const llvm::Type *, |
| 651 | unsigned> > ByRefValueInfo; |
| 652 | |
| 653 | /// getByrefValueFieldNumber - Given a declaration, returns the LLVM field |
| 654 | /// number that holds the value. |
| 655 | unsigned getByRefValueLLVMField(const ValueDecl *VD) const; |
Mike Stump | 182f383 | 2009-12-10 00:02:42 +0000 | [diff] [blame] | 656 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 657 | llvm::BasicBlock *TerminateLandingPad; |
Mike Stump | 182f383 | 2009-12-10 00:02:42 +0000 | [diff] [blame] | 658 | llvm::BasicBlock *TerminateHandler; |
Mike Stump | 15037ca | 2009-12-15 00:35:12 +0000 | [diff] [blame] | 659 | llvm::BasicBlock *TrapBB; |
Eli Friedman | 9406705 | 2009-12-10 02:21:21 +0000 | [diff] [blame] | 660 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 661 | public: |
| 662 | CodeGenFunction(CodeGenModule &cgm); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 663 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 664 | ASTContext &getContext() const; |
Anders Carlsson | e896d98 | 2009-02-13 08:11:52 +0000 | [diff] [blame] | 665 | CGDebugInfo *getDebugInfo() { return DebugInfo; } |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 666 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 667 | /// Returns a pointer to the function's exception object slot, which |
| 668 | /// is assigned in every landing pad. |
| 669 | llvm::Value *getExceptionSlot(); |
| 670 | |
| 671 | llvm::BasicBlock *getUnreachableBlock() { |
| 672 | if (!UnreachableBlock) { |
| 673 | UnreachableBlock = createBasicBlock("unreachable"); |
| 674 | new llvm::UnreachableInst(getLLVMContext(), UnreachableBlock); |
| 675 | } |
| 676 | return UnreachableBlock; |
| 677 | } |
| 678 | |
| 679 | llvm::BasicBlock *getInvokeDest() { |
| 680 | if (!EHStack.requiresLandingPad()) return 0; |
| 681 | return getInvokeDestImpl(); |
| 682 | } |
Daniel Dunbar | 9834ffb | 2009-02-23 17:26:39 +0000 | [diff] [blame] | 683 | |
Owen Anderson | a1cf15f | 2009-07-14 23:10:40 +0000 | [diff] [blame] | 684 | llvm::LLVMContext &getLLVMContext() { return VMContext; } |
Owen Anderson | 6924382 | 2009-07-13 04:10:07 +0000 | [diff] [blame] | 685 | |
Daniel Dunbar | 9834ffb | 2009-02-23 17:26:39 +0000 | [diff] [blame] | 686 | //===--------------------------------------------------------------------===// |
| 687 | // Objective-C |
| 688 | //===--------------------------------------------------------------------===// |
| 689 | |
Chris Lattner | 391d77a | 2008-03-30 23:03:07 +0000 | [diff] [blame] | 690 | void GenerateObjCMethod(const ObjCMethodDecl *OMD); |
Daniel Dunbar | af05bb9 | 2008-08-26 08:29:31 +0000 | [diff] [blame] | 691 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 692 | void StartObjCMethod(const ObjCMethodDecl *MD, |
Fariborz Jahanian | 679a502 | 2009-01-10 21:06:09 +0000 | [diff] [blame] | 693 | const ObjCContainerDecl *CD); |
Daniel Dunbar | af05bb9 | 2008-08-26 08:29:31 +0000 | [diff] [blame] | 694 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 695 | /// GenerateObjCGetter - Synthesize an Objective-C property getter function. |
Fariborz Jahanian | fef30b5 | 2008-12-09 20:23:04 +0000 | [diff] [blame] | 696 | void GenerateObjCGetter(ObjCImplementationDecl *IMP, |
| 697 | const ObjCPropertyImplDecl *PID); |
Fariborz Jahanian | 109dfc6 | 2010-04-28 21:28:56 +0000 | [diff] [blame] | 698 | void GenerateObjCCtorDtorMethod(ObjCImplementationDecl *IMP, |
| 699 | ObjCMethodDecl *MD, bool ctor); |
Daniel Dunbar | af05bb9 | 2008-08-26 08:29:31 +0000 | [diff] [blame] | 700 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 701 | /// GenerateObjCSetter - Synthesize an Objective-C property setter function |
| 702 | /// for the given property. |
Fariborz Jahanian | fef30b5 | 2008-12-09 20:23:04 +0000 | [diff] [blame] | 703 | void GenerateObjCSetter(ObjCImplementationDecl *IMP, |
| 704 | const ObjCPropertyImplDecl *PID); |
Fariborz Jahanian | 0b2bd47 | 2010-04-13 00:38:05 +0000 | [diff] [blame] | 705 | bool IndirectObjCSetterArg(const CGFunctionInfo &FI); |
Fariborz Jahanian | 15bd588 | 2010-04-13 18:32:24 +0000 | [diff] [blame] | 706 | bool IvarTypeWithAggrGCObjects(QualType Ty); |
Daniel Dunbar | af05bb9 | 2008-08-26 08:29:31 +0000 | [diff] [blame] | 707 | |
Mike Stump | 4e7a1f7 | 2009-02-21 20:00:35 +0000 | [diff] [blame] | 708 | //===--------------------------------------------------------------------===// |
| 709 | // Block Bits |
| 710 | //===--------------------------------------------------------------------===// |
| 711 | |
Mike Stump | 8a2b4b1 | 2009-02-25 23:33:13 +0000 | [diff] [blame] | 712 | llvm::Value *BuildBlockLiteralTmp(const BlockExpr *); |
Blaine Garst | 2a7eb28 | 2010-02-23 21:51:17 +0000 | [diff] [blame] | 713 | llvm::Constant *BuildDescriptorBlockDecl(const BlockExpr *, |
| 714 | bool BlockHasCopyDispose, |
Ken Dyck | 199c3d6 | 2010-01-11 17:06:35 +0000 | [diff] [blame] | 715 | CharUnits Size, |
Mike Stump | 0892099 | 2009-03-07 02:35:30 +0000 | [diff] [blame] | 716 | const llvm::StructType *, |
| 717 | std::vector<HelperInfo> *); |
Mike Stump | 4e7a1f7 | 2009-02-21 20:00:35 +0000 | [diff] [blame] | 718 | |
Fariborz Jahanian | 564360b | 2010-06-24 00:08:06 +0000 | [diff] [blame] | 719 | llvm::Function *GenerateBlockFunction(GlobalDecl GD, |
| 720 | const BlockExpr *BExpr, |
John McCall | ee50429 | 2010-05-21 04:11:14 +0000 | [diff] [blame] | 721 | CGBlockInfo &Info, |
Mike Stump | 6cc88f7 | 2009-03-20 21:53:12 +0000 | [diff] [blame] | 722 | const Decl *OuterFuncDecl, |
John McCall | ee50429 | 2010-05-21 04:11:14 +0000 | [diff] [blame] | 723 | llvm::DenseMap<const Decl*, llvm::Value*> ldm); |
Mike Stump | 4e7a1f7 | 2009-02-21 20:00:35 +0000 | [diff] [blame] | 724 | |
| 725 | llvm::Value *LoadBlockStruct(); |
| 726 | |
John McCall | ea1471e | 2010-05-20 01:18:31 +0000 | [diff] [blame] | 727 | void AllocateBlockCXXThisPointer(const CXXThisExpr *E); |
| 728 | void AllocateBlockDecl(const BlockDeclRefExpr *E); |
John McCall | ee50429 | 2010-05-21 04:11:14 +0000 | [diff] [blame] | 729 | llvm::Value *GetAddrOfBlockDecl(const BlockDeclRefExpr *E) { |
| 730 | return GetAddrOfBlockDecl(E->getDecl(), E->isByRef()); |
| 731 | } |
| 732 | llvm::Value *GetAddrOfBlockDecl(const ValueDecl *D, bool ByRef); |
Anders Carlsson | 9ad5513 | 2009-09-09 02:51:03 +0000 | [diff] [blame] | 733 | const llvm::Type *BuildByRefType(const ValueDecl *D); |
Mike Stump | dab514f | 2009-03-04 03:23:46 +0000 | [diff] [blame] | 734 | |
Anders Carlsson | 0ff8baf | 2009-09-11 00:07:24 +0000 | [diff] [blame] | 735 | void GenerateCode(GlobalDecl GD, llvm::Function *Fn); |
| 736 | void StartFunction(GlobalDecl GD, QualType RetTy, |
Daniel Dunbar | 7c08651 | 2008-09-09 23:14:03 +0000 | [diff] [blame] | 737 | llvm::Function *Fn, |
Daniel Dunbar | 2284ac9 | 2008-10-18 18:22:23 +0000 | [diff] [blame] | 738 | const FunctionArgList &Args, |
| 739 | SourceLocation StartLoc); |
Daniel Dunbar | a448fb2 | 2008-11-11 23:11:34 +0000 | [diff] [blame] | 740 | |
John McCall | 9fc6a77 | 2010-02-19 09:25:03 +0000 | [diff] [blame] | 741 | void EmitConstructorBody(FunctionArgList &Args); |
| 742 | void EmitDestructorBody(FunctionArgList &Args); |
| 743 | void EmitFunctionBody(FunctionArgList &Args); |
John McCall | a355e07 | 2010-02-18 03:17:58 +0000 | [diff] [blame] | 744 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 745 | /// EmitReturnBlock - Emit the unified return block, trying to avoid its |
| 746 | /// emission when possible. |
Daniel Dunbar | 1c1d607 | 2009-01-26 23:27:52 +0000 | [diff] [blame] | 747 | void EmitReturnBlock(); |
| 748 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 749 | /// FinishFunction - Complete IR generation of the current function. It is |
| 750 | /// legal to call this function even if there is no current insertion point. |
Daniel Dunbar | af05bb9 | 2008-08-26 08:29:31 +0000 | [diff] [blame] | 751 | void FinishFunction(SourceLocation EndLoc=SourceLocation()); |
Daniel Dunbar | 17b708d | 2008-09-09 23:27:19 +0000 | [diff] [blame] | 752 | |
Anders Carlsson | 519c328 | 2010-03-24 00:39:18 +0000 | [diff] [blame] | 753 | /// GenerateThunk - Generate a thunk for the given method. |
| 754 | void GenerateThunk(llvm::Function *Fn, GlobalDecl GD, const ThunkInfo &Thunk); |
| 755 | |
Douglas Gregor | fb8cc25 | 2010-05-05 05:51:00 +0000 | [diff] [blame] | 756 | void EmitCtorPrologue(const CXXConstructorDecl *CD, CXXCtorType Type, |
| 757 | FunctionArgList &Args); |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 758 | |
Anders Carlsson | d103f9f | 2010-03-28 19:40:00 +0000 | [diff] [blame] | 759 | /// InitializeVTablePointer - Initialize the vtable pointer of the given |
| 760 | /// subobject. |
| 761 | /// |
Anders Carlsson | b3b772e | 2010-04-20 05:22:15 +0000 | [diff] [blame] | 762 | void InitializeVTablePointer(BaseSubobject Base, |
| 763 | const CXXRecordDecl *NearestVBase, |
Anders Carlsson | 4235840 | 2010-05-03 00:07:07 +0000 | [diff] [blame] | 764 | uint64_t OffsetFromNearestVBase, |
Anders Carlsson | d103f9f | 2010-03-28 19:40:00 +0000 | [diff] [blame] | 765 | llvm::Constant *VTable, |
| 766 | const CXXRecordDecl *VTableClass); |
| 767 | |
| 768 | typedef llvm::SmallPtrSet<const CXXRecordDecl *, 4> VisitedVirtualBasesSetTy; |
Anders Carlsson | b3b772e | 2010-04-20 05:22:15 +0000 | [diff] [blame] | 769 | void InitializeVTablePointers(BaseSubobject Base, |
| 770 | const CXXRecordDecl *NearestVBase, |
Anders Carlsson | 4235840 | 2010-05-03 00:07:07 +0000 | [diff] [blame] | 771 | uint64_t OffsetFromNearestVBase, |
Anders Carlsson | 603d6d1 | 2010-03-28 21:07:49 +0000 | [diff] [blame] | 772 | bool BaseIsNonVirtualPrimaryBase, |
| 773 | llvm::Constant *VTable, |
| 774 | const CXXRecordDecl *VTableClass, |
| 775 | VisitedVirtualBasesSetTy& VBases); |
Eli Friedman | 77a259c | 2009-12-08 06:46:18 +0000 | [diff] [blame] | 776 | |
Anders Carlsson | 603d6d1 | 2010-03-28 21:07:49 +0000 | [diff] [blame] | 777 | void InitializeVTablePointers(const CXXRecordDecl *ClassDecl); |
Anders Carlsson | d103f9f | 2010-03-28 19:40:00 +0000 | [diff] [blame] | 778 | |
| 779 | |
Fariborz Jahanian | 426cc38 | 2009-07-30 17:49:11 +0000 | [diff] [blame] | 780 | /// EmitDtorEpilogue - Emit all code that comes at the end of class's |
Mike Stump | f71d232 | 2009-11-30 20:08:49 +0000 | [diff] [blame] | 781 | /// destructor. This is to call destructors on members and base classes in |
| 782 | /// reverse order of their construction. |
Anders Carlsson | de1d26b | 2009-09-14 05:32:02 +0000 | [diff] [blame] | 783 | void EmitDtorEpilogue(const CXXDestructorDecl *Dtor, |
| 784 | CXXDtorType Type); |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 785 | |
Chris Lattner | 7255a2d | 2010-06-22 00:03:40 +0000 | [diff] [blame] | 786 | /// ShouldInstrumentFunction - Return true if the current function should be |
| 787 | /// instrumented with __cyg_profile_func_* calls |
| 788 | bool ShouldInstrumentFunction(); |
| 789 | |
| 790 | /// EmitFunctionInstrumentation - Emit LLVM code to call the specified |
| 791 | /// instrumentation function with the current function and the call site, if |
| 792 | /// function instrumentation is enabled. |
| 793 | void EmitFunctionInstrumentation(const char *Fn); |
| 794 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 795 | /// EmitFunctionProlog - Emit the target specific LLVM code to load the |
| 796 | /// arguments for the given function. This is also responsible for naming the |
| 797 | /// LLVM function arguments. |
Daniel Dunbar | 88b5396 | 2009-02-02 22:03:45 +0000 | [diff] [blame] | 798 | void EmitFunctionProlog(const CGFunctionInfo &FI, |
| 799 | llvm::Function *Fn, |
Daniel Dunbar | 17b708d | 2008-09-09 23:27:19 +0000 | [diff] [blame] | 800 | const FunctionArgList &Args); |
| 801 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 802 | /// EmitFunctionEpilog - Emit the target specific LLVM code to return the |
| 803 | /// given temporary. |
Chris Lattner | 35b21b8 | 2010-06-27 01:06:27 +0000 | [diff] [blame] | 804 | void EmitFunctionEpilog(const CGFunctionInfo &FI); |
Daniel Dunbar | 17b708d | 2008-09-09 23:27:19 +0000 | [diff] [blame] | 805 | |
Mike Stump | cce3d4f | 2009-12-07 23:38:24 +0000 | [diff] [blame] | 806 | /// EmitStartEHSpec - Emit the start of the exception spec. |
| 807 | void EmitStartEHSpec(const Decl *D); |
| 808 | |
| 809 | /// EmitEndEHSpec - Emit the end of the exception spec. |
| 810 | void EmitEndEHSpec(const Decl *D); |
| 811 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 812 | /// getTerminateLandingPad - Return a landing pad that just calls terminate. |
| 813 | llvm::BasicBlock *getTerminateLandingPad(); |
| 814 | |
| 815 | /// getTerminateHandler - Return a handler (not a landing pad, just |
| 816 | /// a catch handler) that just calls terminate. This is used when |
| 817 | /// a terminate scope encloses a try. |
Mike Stump | 9b39c51 | 2009-12-09 22:59:31 +0000 | [diff] [blame] | 818 | llvm::BasicBlock *getTerminateHandler(); |
| 819 | |
Daniel Dunbar | 8b1a343 | 2009-02-03 23:03:55 +0000 | [diff] [blame] | 820 | const llvm::Type *ConvertTypeForMem(QualType T); |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 821 | const llvm::Type *ConvertType(QualType T); |
John McCall | bff225e | 2010-02-16 04:15:37 +0000 | [diff] [blame] | 822 | const llvm::Type *ConvertType(const TypeDecl *T) { |
| 823 | return ConvertType(getContext().getTypeDeclType(T)); |
| 824 | } |
Chris Lattner | c8aa5f1 | 2008-04-04 04:07:35 +0000 | [diff] [blame] | 825 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 826 | /// LoadObjCSelf - Load the value of self. This function is only valid while |
| 827 | /// generating code for an Objective-C method. |
Chris Lattner | c8aa5f1 | 2008-04-04 04:07:35 +0000 | [diff] [blame] | 828 | llvm::Value *LoadObjCSelf(); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 829 | |
| 830 | /// TypeOfSelfObject - Return type of object that this self represents. |
Fariborz Jahanian | 45012a7 | 2009-02-03 00:09:52 +0000 | [diff] [blame] | 831 | QualType TypeOfSelfObject(); |
Chris Lattner | 4111024 | 2008-06-17 18:05:57 +0000 | [diff] [blame] | 832 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 833 | /// hasAggregateLLVMType - Return true if the specified AST type will map into |
| 834 | /// an aggregate LLVM type or is void. |
| 835 | static bool hasAggregateLLVMType(QualType T); |
Daniel Dunbar | 55e8742 | 2008-11-11 02:29:29 +0000 | [diff] [blame] | 836 | |
| 837 | /// createBasicBlock - Create an LLVM basic block. |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 838 | llvm::BasicBlock *createBasicBlock(const char *Name="", |
Daniel Dunbar | 55e8742 | 2008-11-11 02:29:29 +0000 | [diff] [blame] | 839 | llvm::Function *Parent=0, |
| 840 | llvm::BasicBlock *InsertBefore=0) { |
Daniel Dunbar | 29ea672 | 2008-11-12 00:01:12 +0000 | [diff] [blame] | 841 | #ifdef NDEBUG |
Owen Anderson | 0032b27 | 2009-08-13 21:57:51 +0000 | [diff] [blame] | 842 | return llvm::BasicBlock::Create(VMContext, "", Parent, InsertBefore); |
Daniel Dunbar | 29ea672 | 2008-11-12 00:01:12 +0000 | [diff] [blame] | 843 | #else |
Owen Anderson | 0032b27 | 2009-08-13 21:57:51 +0000 | [diff] [blame] | 844 | return llvm::BasicBlock::Create(VMContext, Name, Parent, InsertBefore); |
Daniel Dunbar | 29ea672 | 2008-11-12 00:01:12 +0000 | [diff] [blame] | 845 | #endif |
Daniel Dunbar | 55e8742 | 2008-11-11 02:29:29 +0000 | [diff] [blame] | 846 | } |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 847 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 848 | /// getBasicBlockForLabel - Return the LLVM basicblock that the specified |
| 849 | /// label maps to. |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 850 | JumpDest getJumpDestForLabel(const LabelStmt *S); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 851 | |
Mike Stump | f71d232 | 2009-11-30 20:08:49 +0000 | [diff] [blame] | 852 | /// SimplifyForwardingBlocks - If the given basic block is only a branch to |
| 853 | /// another basic block, simplify it. This assumes that no other code could |
| 854 | /// potentially reference the basic block. |
Daniel Dunbar | aa5bd87 | 2009-04-01 04:37:47 +0000 | [diff] [blame] | 855 | void SimplifyForwardingBlocks(llvm::BasicBlock *BB); |
| 856 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 857 | /// EmitBlock - Emit the given block \arg BB and set it as the insert point, |
| 858 | /// adding a fall-through branch from the current insert block if |
| 859 | /// necessary. It is legal to call this function even if there is no current |
| 860 | /// insertion point. |
Daniel Dunbar | a0c21a8 | 2008-11-13 01:24:05 +0000 | [diff] [blame] | 861 | /// |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 862 | /// IsFinished - If true, indicates that the caller has finished emitting |
| 863 | /// branches to the given block and does not expect to emit code into it. This |
| 864 | /// means the block can be ignored if it is unreachable. |
Daniel Dunbar | a0c21a8 | 2008-11-13 01:24:05 +0000 | [diff] [blame] | 865 | void EmitBlock(llvm::BasicBlock *BB, bool IsFinished=false); |
Daniel Dunbar | 824e3bd | 2008-11-11 04:34:23 +0000 | [diff] [blame] | 866 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 867 | /// EmitBranch - Emit a branch to the specified basic block from the current |
| 868 | /// insert block, taking care to avoid creation of branches from dummy |
| 869 | /// blocks. It is legal to call this function even if there is no current |
| 870 | /// insertion point. |
Daniel Dunbar | 5e08ad3 | 2008-11-11 22:06:59 +0000 | [diff] [blame] | 871 | /// |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 872 | /// This function clears the current insertion point. The caller should follow |
| 873 | /// calls to this function with calls to Emit*Block prior to generation new |
| 874 | /// code. |
Daniel Dunbar | d57a871 | 2008-11-11 09:41:28 +0000 | [diff] [blame] | 875 | void EmitBranch(llvm::BasicBlock *Block); |
| 876 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 877 | /// HaveInsertPoint - True if an insertion point is defined. If not, this |
| 878 | /// indicates that the current code being emitted is unreachable. |
| 879 | bool HaveInsertPoint() const { |
Daniel Dunbar | a448fb2 | 2008-11-11 23:11:34 +0000 | [diff] [blame] | 880 | return Builder.GetInsertBlock() != 0; |
| 881 | } |
| 882 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 883 | /// EnsureInsertPoint - Ensure that an insertion point is defined so that |
| 884 | /// emitted IR has a place to go. Note that by definition, if this function |
| 885 | /// creates a block then that block is unreachable; callers may do better to |
| 886 | /// detect when no insertion point is defined and simply skip IR generation. |
Daniel Dunbar | a448fb2 | 2008-11-11 23:11:34 +0000 | [diff] [blame] | 887 | void EnsureInsertPoint() { |
| 888 | if (!HaveInsertPoint()) |
| 889 | EmitBlock(createBasicBlock()); |
| 890 | } |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 891 | |
Daniel Dunbar | 488e993 | 2008-08-16 00:56:44 +0000 | [diff] [blame] | 892 | /// ErrorUnsupported - Print out an error that codegen doesn't support the |
Chris Lattner | dc5e826 | 2007-12-02 01:43:38 +0000 | [diff] [blame] | 893 | /// specified stmt yet. |
Daniel Dunbar | 90df4b6 | 2008-09-04 03:43:08 +0000 | [diff] [blame] | 894 | void ErrorUnsupported(const Stmt *S, const char *Type, |
| 895 | bool OmitOnError=false); |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 896 | |
| 897 | //===--------------------------------------------------------------------===// |
| 898 | // Helpers |
| 899 | //===--------------------------------------------------------------------===// |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 900 | |
John McCall | 0953e76 | 2009-09-24 19:53:00 +0000 | [diff] [blame] | 901 | Qualifiers MakeQualifiers(QualType T) { |
Mike Stump | df317bf | 2009-11-03 23:25:48 +0000 | [diff] [blame] | 902 | Qualifiers Quals = getContext().getCanonicalType(T).getQualifiers(); |
John McCall | 0953e76 | 2009-09-24 19:53:00 +0000 | [diff] [blame] | 903 | Quals.setObjCGCAttr(getContext().getObjCGCAttrKind(T)); |
| 904 | return Quals; |
| 905 | } |
| 906 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 907 | /// CreateTempAlloca - This creates a alloca and inserts it into the entry |
Daniel Dunbar | 195337d | 2010-02-09 02:48:28 +0000 | [diff] [blame] | 908 | /// block. The caller is responsible for setting an appropriate alignment on |
| 909 | /// the alloca. |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 910 | llvm::AllocaInst *CreateTempAlloca(const llvm::Type *Ty, |
Daniel Dunbar | 259e9cc | 2009-10-19 01:21:05 +0000 | [diff] [blame] | 911 | const llvm::Twine &Name = "tmp"); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 912 | |
John McCall | ac41816 | 2010-04-22 01:10:34 +0000 | [diff] [blame] | 913 | /// InitTempAlloca - Provide an initial value for the given alloca. |
| 914 | void InitTempAlloca(llvm::AllocaInst *Alloca, llvm::Value *Value); |
| 915 | |
Daniel Dunbar | 9bd4da2 | 2010-02-16 19:44:13 +0000 | [diff] [blame] | 916 | /// CreateIRTemp - Create a temporary IR object of the given type, with |
| 917 | /// appropriate alignment. This routine should only be used when an temporary |
| 918 | /// value needs to be stored into an alloca (for example, to avoid explicit |
| 919 | /// PHI construction), but the type is the IR type, not the type appropriate |
| 920 | /// for storing in memory. |
Chris Lattner | 121b3fa | 2010-07-05 20:21:00 +0000 | [diff] [blame] | 921 | llvm::AllocaInst *CreateIRTemp(QualType T, const llvm::Twine &Name = "tmp"); |
Daniel Dunbar | 9bd4da2 | 2010-02-16 19:44:13 +0000 | [diff] [blame] | 922 | |
Daniel Dunbar | 195337d | 2010-02-09 02:48:28 +0000 | [diff] [blame] | 923 | /// CreateMemTemp - Create a temporary memory object of the given type, with |
| 924 | /// appropriate alignment. |
Chris Lattner | 121b3fa | 2010-07-05 20:21:00 +0000 | [diff] [blame] | 925 | llvm::AllocaInst *CreateMemTemp(QualType T, const llvm::Twine &Name = "tmp"); |
Daniel Dunbar | 195337d | 2010-02-09 02:48:28 +0000 | [diff] [blame] | 926 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 927 | /// EvaluateExprAsBool - Perform the usual unary conversions on the specified |
| 928 | /// expression and compare the result against zero, returning an Int1Ty value. |
| 929 | llvm::Value *EvaluateExprAsBool(const Expr *E); |
| 930 | |
Chris Lattner | 9b65551 | 2007-08-31 22:49:20 +0000 | [diff] [blame] | 931 | /// EmitAnyExpr - Emit code to compute the specified expression which can have |
| 932 | /// any type. The result is returned as an RValue struct. If this is an |
| 933 | /// aggregate expression, the aggloc/agglocvolatile arguments indicate where |
| 934 | /// the result should be returned. |
Mike Stump | 49d1cd5 | 2009-05-26 22:03:21 +0000 | [diff] [blame] | 935 | /// |
| 936 | /// \param IgnoreResult - True if the resulting value isn't used. |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 937 | RValue EmitAnyExpr(const Expr *E, llvm::Value *AggLoc = 0, |
Anders Carlsson | 14c5cbf | 2009-08-16 07:36:22 +0000 | [diff] [blame] | 938 | bool IsAggLocVolatile = false, bool IgnoreResult = false, |
| 939 | bool IsInitializer = false); |
Devang Patel | d9363c3 | 2007-09-28 21:49:18 +0000 | [diff] [blame] | 940 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 941 | // EmitVAListRef - Emit a "reference" to a va_list; this is either the address |
| 942 | // or the value of the expression, depending on how va_list is defined. |
Eli Friedman | 4fd0aa5 | 2009-01-20 17:46:04 +0000 | [diff] [blame] | 943 | llvm::Value *EmitVAListRef(const Expr *E); |
| 944 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 945 | /// EmitAnyExprToTemp - Similary to EmitAnyExpr(), however, the result will |
| 946 | /// always be accessible even if no aggregate location is provided. |
Anders Carlsson | 14c5cbf | 2009-08-16 07:36:22 +0000 | [diff] [blame] | 947 | RValue EmitAnyExprToTemp(const Expr *E, bool IsAggLocVolatile = false, |
| 948 | bool IsInitializer = false); |
Daniel Dunbar | 46f45b9 | 2008-09-09 01:06:48 +0000 | [diff] [blame] | 949 | |
John McCall | 3d3ec1c | 2010-04-21 10:05:39 +0000 | [diff] [blame] | 950 | /// EmitsAnyExprToMem - Emits the code necessary to evaluate an |
| 951 | /// arbitrary expression into the given memory location. |
| 952 | void EmitAnyExprToMem(const Expr *E, llvm::Value *Location, |
| 953 | bool IsLocationVolatile = false, |
| 954 | bool IsInitializer = false); |
| 955 | |
Mike Stump | 27fe2e6 | 2009-05-23 22:29:41 +0000 | [diff] [blame] | 956 | /// EmitAggregateCopy - Emit an aggrate copy. |
| 957 | /// |
| 958 | /// \param isVolatile - True iff either the source or the destination is |
| 959 | /// volatile. |
Daniel Dunbar | 7482d12 | 2008-09-09 20:49:46 +0000 | [diff] [blame] | 960 | void EmitAggregateCopy(llvm::Value *DestPtr, llvm::Value *SrcPtr, |
Mike Stump | 27fe2e6 | 2009-05-23 22:29:41 +0000 | [diff] [blame] | 961 | QualType EltTy, bool isVolatile=false); |
Daniel Dunbar | 7482d12 | 2008-09-09 20:49:46 +0000 | [diff] [blame] | 962 | |
Devang Patel | 51b09f2 | 2007-10-04 23:45:31 +0000 | [diff] [blame] | 963 | /// StartBlock - Start new block named N. If insert block is a dummy block |
| 964 | /// then reuse it. |
| 965 | void StartBlock(const char *N); |
| 966 | |
Lauro Ramos Venancio | 8137335 | 2008-02-26 21:41:45 +0000 | [diff] [blame] | 967 | /// GetAddrOfStaticLocalVar - Return the address of a static local variable. |
Steve Naroff | 248a753 | 2008-04-15 22:42:06 +0000 | [diff] [blame] | 968 | llvm::Constant *GetAddrOfStaticLocalVar(const VarDecl *BVD); |
Dan Gohman | 4f8d123 | 2008-05-22 00:50:06 +0000 | [diff] [blame] | 969 | |
Anders Carlsson | dde0a94 | 2008-09-11 09:15:33 +0000 | [diff] [blame] | 970 | /// GetAddrOfLocalVar - Return the address of a local variable. |
| 971 | llvm::Value *GetAddrOfLocalVar(const VarDecl *VD); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 972 | |
Dan Gohman | 4f8d123 | 2008-05-22 00:50:06 +0000 | [diff] [blame] | 973 | /// getAccessedFieldNo - Given an encoded value and a result number, return |
| 974 | /// the input field number being accessed. |
| 975 | static unsigned getAccessedFieldNo(unsigned Idx, const llvm::Constant *Elts); |
| 976 | |
Chris Lattner | d9becd1 | 2009-10-28 23:59:40 +0000 | [diff] [blame] | 977 | llvm::BlockAddress *GetAddrOfLabel(const LabelStmt *L); |
Chris Lattner | 3d00fdc | 2009-10-13 06:55:33 +0000 | [diff] [blame] | 978 | llvm::BasicBlock *GetIndirectGotoBlock(); |
Daniel Dunbar | 0ffb125 | 2008-08-04 16:51:22 +0000 | [diff] [blame] | 979 | |
Anders Carlsson | 1884eb0 | 2010-05-22 17:35:42 +0000 | [diff] [blame] | 980 | /// EmitNullInitialization - Generate code to set a value of the given type to |
| 981 | /// null, If the type contains data member pointers, they will be initialized |
| 982 | /// to -1 in accordance with the Itanium C++ ABI. |
| 983 | void EmitNullInitialization(llvm::Value *DestPtr, QualType Ty); |
Anders Carlsson | ddf7cac | 2008-11-04 05:30:00 +0000 | [diff] [blame] | 984 | |
| 985 | // EmitVAArg - Generate code to get an argument from the passed in pointer |
| 986 | // and update it accordingly. The return value is a pointer to the argument. |
| 987 | // FIXME: We should be able to get rid of this method and use the va_arg |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 988 | // instruction in LLVM instead once it works well enough. |
Anders Carlsson | ddf7cac | 2008-11-04 05:30:00 +0000 | [diff] [blame] | 989 | llvm::Value *EmitVAArg(llvm::Value *VAListAddr, QualType Ty); |
Anders Carlsson | f666b77 | 2008-12-20 20:27:15 +0000 | [diff] [blame] | 990 | |
Mike Stump | f71d232 | 2009-11-30 20:08:49 +0000 | [diff] [blame] | 991 | /// EmitVLASize - Generate code for any VLA size expressions that might occur |
| 992 | /// in a variably modified type. If Ty is a VLA, will return the value that |
| 993 | /// corresponds to the size in bytes of the VLA type. Will return 0 otherwise. |
Daniel Dunbar | d286f05 | 2009-07-19 06:58:07 +0000 | [diff] [blame] | 994 | /// |
| 995 | /// This function can be called with a null (unreachable) insert point. |
Anders Carlsson | 60d3541 | 2008-12-20 20:46:34 +0000 | [diff] [blame] | 996 | llvm::Value *EmitVLASize(QualType Ty); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 997 | |
Anders Carlsson | dcc90d8 | 2008-12-12 07:19:02 +0000 | [diff] [blame] | 998 | // GetVLASize - Returns an LLVM value that corresponds to the size in bytes |
| 999 | // of a variable length array type. |
| 1000 | llvm::Value *GetVLASize(const VariableArrayType *); |
| 1001 | |
Anders Carlsson | 5f4307b | 2009-04-14 16:58:56 +0000 | [diff] [blame] | 1002 | /// LoadCXXThis - Load the value of 'this'. This function is only valid while |
| 1003 | /// generating code for an C++ member function. |
John McCall | 2504941 | 2010-02-16 22:04:33 +0000 | [diff] [blame] | 1004 | llvm::Value *LoadCXXThis() { |
| 1005 | assert(CXXThisValue && "no 'this' value for this function"); |
| 1006 | return CXXThisValue; |
| 1007 | } |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1008 | |
Anders Carlsson | c997d42 | 2010-01-02 01:01:18 +0000 | [diff] [blame] | 1009 | /// LoadCXXVTT - Load the VTT parameter to base constructors/destructors have |
| 1010 | /// virtual bases. |
John McCall | 2504941 | 2010-02-16 22:04:33 +0000 | [diff] [blame] | 1011 | llvm::Value *LoadCXXVTT() { |
| 1012 | assert(CXXVTTValue && "no VTT value for this function"); |
| 1013 | return CXXVTTValue; |
| 1014 | } |
John McCall | bff225e | 2010-02-16 04:15:37 +0000 | [diff] [blame] | 1015 | |
| 1016 | /// GetAddressOfBaseOfCompleteClass - Convert the given pointer to a |
Anders Carlsson | 8561a86 | 2010-04-24 23:01:49 +0000 | [diff] [blame] | 1017 | /// complete class to the given direct base. |
| 1018 | llvm::Value * |
| 1019 | GetAddressOfDirectBaseInCompleteClass(llvm::Value *Value, |
| 1020 | const CXXRecordDecl *Derived, |
| 1021 | const CXXRecordDecl *Base, |
| 1022 | bool BaseIsVirtual); |
Anders Carlsson | a88ad56 | 2010-04-24 21:51:08 +0000 | [diff] [blame] | 1023 | |
Mike Stump | f71d232 | 2009-11-30 20:08:49 +0000 | [diff] [blame] | 1024 | /// GetAddressOfBaseClass - This function will add the necessary delta to the |
| 1025 | /// load of 'this' and returns address of the base class. |
Anders Carlsson | 34a2d38 | 2010-04-24 21:06:20 +0000 | [diff] [blame] | 1026 | llvm::Value *GetAddressOfBaseClass(llvm::Value *Value, |
Anders Carlsson | 8561a86 | 2010-04-24 23:01:49 +0000 | [diff] [blame] | 1027 | const CXXRecordDecl *Derived, |
Anders Carlsson | 34a2d38 | 2010-04-24 21:06:20 +0000 | [diff] [blame] | 1028 | const CXXBaseSpecifierArray &BasePath, |
| 1029 | bool NullCheckValue); |
| 1030 | |
Anders Carlsson | a3697c9 | 2009-11-23 17:57:54 +0000 | [diff] [blame] | 1031 | llvm::Value *GetAddressOfDerivedClass(llvm::Value *Value, |
Anders Carlsson | 8561a86 | 2010-04-24 23:01:49 +0000 | [diff] [blame] | 1032 | const CXXRecordDecl *Derived, |
Anders Carlsson | a04efdf | 2010-04-24 21:23:59 +0000 | [diff] [blame] | 1033 | const CXXBaseSpecifierArray &BasePath, |
Anders Carlsson | a3697c9 | 2009-11-23 17:57:54 +0000 | [diff] [blame] | 1034 | bool NullCheckValue); |
| 1035 | |
Anders Carlsson | bb7e17b | 2010-01-31 01:36:53 +0000 | [diff] [blame] | 1036 | llvm::Value *GetVirtualBaseClassOffset(llvm::Value *This, |
| 1037 | const CXXRecordDecl *ClassDecl, |
| 1038 | const CXXRecordDecl *BaseClassDecl); |
Anders Carlsson | 2f1986b | 2009-10-06 22:43:30 +0000 | [diff] [blame] | 1039 | |
John McCall | c0bf462 | 2010-02-23 00:48:20 +0000 | [diff] [blame] | 1040 | void EmitDelegateCXXConstructorCall(const CXXConstructorDecl *Ctor, |
| 1041 | CXXCtorType CtorType, |
| 1042 | const FunctionArgList &Args); |
Anders Carlsson | 155ed4a | 2010-05-02 23:20:53 +0000 | [diff] [blame] | 1043 | void EmitCXXConstructorCall(const CXXConstructorDecl *D, CXXCtorType Type, |
| 1044 | bool ForVirtualBase, llvm::Value *This, |
Anders Carlsson | b14095a | 2009-04-17 00:06:03 +0000 | [diff] [blame] | 1045 | CallExpr::const_arg_iterator ArgBeg, |
| 1046 | CallExpr::const_arg_iterator ArgEnd); |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1047 | |
Fariborz Jahanian | 288dcaf | 2009-08-19 20:55:16 +0000 | [diff] [blame] | 1048 | void EmitCXXAggrConstructorCall(const CXXConstructorDecl *D, |
Anders Carlsson | 569c1f4 | 2009-09-23 02:45:36 +0000 | [diff] [blame] | 1049 | const ConstantArrayType *ArrayTy, |
Anders Carlsson | 5d4d946 | 2009-11-24 18:43:52 +0000 | [diff] [blame] | 1050 | llvm::Value *ArrayPtr, |
| 1051 | CallExpr::const_arg_iterator ArgBeg, |
| 1052 | CallExpr::const_arg_iterator ArgEnd); |
| 1053 | |
Anders Carlsson | 569c1f4 | 2009-09-23 02:45:36 +0000 | [diff] [blame] | 1054 | void EmitCXXAggrConstructorCall(const CXXConstructorDecl *D, |
| 1055 | llvm::Value *NumElements, |
Anders Carlsson | 5d4d946 | 2009-11-24 18:43:52 +0000 | [diff] [blame] | 1056 | llvm::Value *ArrayPtr, |
| 1057 | CallExpr::const_arg_iterator ArgBeg, |
| 1058 | CallExpr::const_arg_iterator ArgEnd); |
Anders Carlsson | b14095a | 2009-04-17 00:06:03 +0000 | [diff] [blame] | 1059 | |
Fariborz Jahanian | f800f6c | 2009-08-20 20:54:15 +0000 | [diff] [blame] | 1060 | void EmitCXXAggrDestructorCall(const CXXDestructorDecl *D, |
| 1061 | const ArrayType *Array, |
| 1062 | llvm::Value *This); |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1063 | |
Fariborz Jahanian | 72c2153 | 2009-11-13 19:27:47 +0000 | [diff] [blame] | 1064 | void EmitCXXAggrDestructorCall(const CXXDestructorDecl *D, |
| 1065 | llvm::Value *NumElements, |
| 1066 | llvm::Value *This); |
| 1067 | |
Anders Carlsson | 02e370a | 2010-06-08 22:14:59 +0000 | [diff] [blame] | 1068 | llvm::Function *GenerateCXXAggrDestructorHelper(const CXXDestructorDecl *D, |
| 1069 | const ArrayType *Array, |
| 1070 | llvm::Value *This); |
Fariborz Jahanian | 88f4280 | 2009-11-10 19:24:06 +0000 | [diff] [blame] | 1071 | |
Anders Carlsson | 7267c16 | 2009-05-29 21:03:38 +0000 | [diff] [blame] | 1072 | void EmitCXXDestructorCall(const CXXDestructorDecl *D, CXXDtorType Type, |
Anders Carlsson | 8e6404c | 2010-05-02 23:29:11 +0000 | [diff] [blame] | 1073 | bool ForVirtualBase, llvm::Value *This); |
Fariborz Jahanian | ef66872 | 2010-06-25 18:26:07 +0000 | [diff] [blame] | 1074 | |
| 1075 | void EmitNewArrayInitializer(const CXXNewExpr *E, llvm::Value *NewPtr, |
| 1076 | llvm::Value *NumElements); |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1077 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 1078 | void EmitCXXTemporary(const CXXTemporary *Temporary, llvm::Value *Ptr); |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1079 | |
Anders Carlsson | a00703d | 2009-05-31 01:40:14 +0000 | [diff] [blame] | 1080 | llvm::Value *EmitCXXNewExpr(const CXXNewExpr *E); |
Anders Carlsson | 60e282c | 2009-08-16 21:13:42 +0000 | [diff] [blame] | 1081 | void EmitCXXDeleteExpr(const CXXDeleteExpr *E); |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1082 | |
Eli Friedman | 4bf8152 | 2009-11-18 00:57:03 +0000 | [diff] [blame] | 1083 | void EmitDeleteCall(const FunctionDecl *DeleteFD, llvm::Value *Ptr, |
| 1084 | QualType DeleteTy); |
| 1085 | |
Mike Stump | c2e84ae | 2009-11-15 08:09:41 +0000 | [diff] [blame] | 1086 | llvm::Value* EmitCXXTypeidExpr(const CXXTypeidExpr *E); |
Mike Stump | c849c05 | 2009-11-16 06:50:58 +0000 | [diff] [blame] | 1087 | llvm::Value *EmitDynamicCast(llvm::Value *V, const CXXDynamicCastExpr *DCE); |
Mike Stump | c2e84ae | 2009-11-15 08:09:41 +0000 | [diff] [blame] | 1088 | |
Mike Stump | b14e62d | 2009-12-16 02:57:00 +0000 | [diff] [blame] | 1089 | void EmitCheck(llvm::Value *, unsigned Size); |
| 1090 | |
Chris Lattner | dd36d32 | 2010-01-09 21:40:03 +0000 | [diff] [blame] | 1091 | llvm::Value *EmitScalarPrePostIncDec(const UnaryOperator *E, LValue LV, |
| 1092 | bool isInc, bool isPre); |
| 1093 | ComplexPairTy EmitComplexPrePostIncDec(const UnaryOperator *E, LValue LV, |
| 1094 | bool isInc, bool isPre); |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1095 | //===--------------------------------------------------------------------===// |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1096 | // Declaration Emission |
| 1097 | //===--------------------------------------------------------------------===// |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1098 | |
Daniel Dunbar | d286f05 | 2009-07-19 06:58:07 +0000 | [diff] [blame] | 1099 | /// EmitDecl - Emit a declaration. |
| 1100 | /// |
| 1101 | /// This function can be called with a null (unreachable) insert point. |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1102 | void EmitDecl(const Decl &D); |
Daniel Dunbar | d286f05 | 2009-07-19 06:58:07 +0000 | [diff] [blame] | 1103 | |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1104 | /// EmitBlockVarDecl - Emit a block variable declaration. |
Daniel Dunbar | d286f05 | 2009-07-19 06:58:07 +0000 | [diff] [blame] | 1105 | /// |
| 1106 | /// This function can be called with a null (unreachable) insert point. |
Steve Naroff | 248a753 | 2008-04-15 22:42:06 +0000 | [diff] [blame] | 1107 | void EmitBlockVarDecl(const VarDecl &D); |
Daniel Dunbar | d286f05 | 2009-07-19 06:58:07 +0000 | [diff] [blame] | 1108 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 1109 | typedef void SpecialInitFn(CodeGenFunction &Init, const VarDecl &D, |
| 1110 | llvm::Value *Address); |
| 1111 | |
Daniel Dunbar | d286f05 | 2009-07-19 06:58:07 +0000 | [diff] [blame] | 1112 | /// EmitLocalBlockVarDecl - Emit a local block variable declaration. |
| 1113 | /// |
| 1114 | /// This function can be called with a null (unreachable) insert point. |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 1115 | void EmitLocalBlockVarDecl(const VarDecl &D, SpecialInitFn *SpecialInit = 0); |
Daniel Dunbar | d286f05 | 2009-07-19 06:58:07 +0000 | [diff] [blame] | 1116 | |
Anders Carlsson | f6b89a1 | 2010-02-07 02:03:08 +0000 | [diff] [blame] | 1117 | void EmitStaticBlockVarDecl(const VarDecl &D, |
| 1118 | llvm::GlobalValue::LinkageTypes Linkage); |
Daniel Dunbar | b7ec246 | 2008-08-16 03:19:19 +0000 | [diff] [blame] | 1119 | |
| 1120 | /// EmitParmDecl - Emit a ParmVarDecl or an ImplicitParamDecl. |
| 1121 | void EmitParmDecl(const VarDecl &D, llvm::Value *Arg); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1122 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1123 | //===--------------------------------------------------------------------===// |
| 1124 | // Statement Emission |
| 1125 | //===--------------------------------------------------------------------===// |
| 1126 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1127 | /// EmitStopPoint - Emit a debug stoppoint if we are emitting debug info. |
Daniel Dunbar | 0912425 | 2008-11-12 08:21:33 +0000 | [diff] [blame] | 1128 | void EmitStopPoint(const Stmt *S); |
| 1129 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1130 | /// EmitStmt - Emit the code for the statement \arg S. It is legal to call |
| 1131 | /// this function even if there is no current insertion point. |
| 1132 | /// |
| 1133 | /// This function may clear the current insertion point; callers should use |
| 1134 | /// EnsureInsertPoint if they wish to subsequently generate code without first |
| 1135 | /// calling EmitBlock, EmitBranch, or EmitStmt. |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1136 | void EmitStmt(const Stmt *S); |
Daniel Dunbar | a448fb2 | 2008-11-11 23:11:34 +0000 | [diff] [blame] | 1137 | |
Daniel Dunbar | 0912425 | 2008-11-12 08:21:33 +0000 | [diff] [blame] | 1138 | /// EmitSimpleStmt - Try to emit a "simple" statement which does not |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1139 | /// necessarily require an insertion point or debug information; typically |
| 1140 | /// because the statement amounts to a jump or a container of other |
| 1141 | /// statements. |
Daniel Dunbar | 0912425 | 2008-11-12 08:21:33 +0000 | [diff] [blame] | 1142 | /// |
| 1143 | /// \return True if the statement was handled. |
| 1144 | bool EmitSimpleStmt(const Stmt *S); |
| 1145 | |
Chris Lattner | 9b65551 | 2007-08-31 22:49:20 +0000 | [diff] [blame] | 1146 | RValue EmitCompoundStmt(const CompoundStmt &S, bool GetLast = false, |
| 1147 | llvm::Value *AggLoc = 0, bool isAggVol = false); |
Daniel Dunbar | a448fb2 | 2008-11-11 23:11:34 +0000 | [diff] [blame] | 1148 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1149 | /// EmitLabel - Emit the block for the given label. It is legal to call this |
| 1150 | /// function even if there is no current insertion point. |
Chris Lattner | 91d723d | 2008-07-26 20:23:23 +0000 | [diff] [blame] | 1151 | void EmitLabel(const LabelStmt &S); // helper for EmitLabelStmt. |
Daniel Dunbar | a448fb2 | 2008-11-11 23:11:34 +0000 | [diff] [blame] | 1152 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1153 | void EmitLabelStmt(const LabelStmt &S); |
| 1154 | void EmitGotoStmt(const GotoStmt &S); |
Daniel Dunbar | 0ffb125 | 2008-08-04 16:51:22 +0000 | [diff] [blame] | 1155 | void EmitIndirectGotoStmt(const IndirectGotoStmt &S); |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1156 | void EmitIfStmt(const IfStmt &S); |
| 1157 | void EmitWhileStmt(const WhileStmt &S); |
| 1158 | void EmitDoStmt(const DoStmt &S); |
| 1159 | void EmitForStmt(const ForStmt &S); |
| 1160 | void EmitReturnStmt(const ReturnStmt &S); |
| 1161 | void EmitDeclStmt(const DeclStmt &S); |
Daniel Dunbar | 0912425 | 2008-11-12 08:21:33 +0000 | [diff] [blame] | 1162 | void EmitBreakStmt(const BreakStmt &S); |
| 1163 | void EmitContinueStmt(const ContinueStmt &S); |
Devang Patel | 51b09f2 | 2007-10-04 23:45:31 +0000 | [diff] [blame] | 1164 | void EmitSwitchStmt(const SwitchStmt &S); |
| 1165 | void EmitDefaultStmt(const DefaultStmt &S); |
| 1166 | void EmitCaseStmt(const CaseStmt &S); |
Devang Patel | c049e4f | 2007-10-08 20:57:48 +0000 | [diff] [blame] | 1167 | void EmitCaseStmtRange(const CaseStmt &S); |
Anders Carlsson | fb1aeb8 | 2008-02-05 16:35:33 +0000 | [diff] [blame] | 1168 | void EmitAsmStmt(const AsmStmt &S); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1169 | |
Anders Carlsson | 3d8400d | 2008-08-30 19:51:14 +0000 | [diff] [blame] | 1170 | void EmitObjCForCollectionStmt(const ObjCForCollectionStmt &S); |
Anders Carlsson | 64d5d6c | 2008-09-09 10:04:29 +0000 | [diff] [blame] | 1171 | void EmitObjCAtTryStmt(const ObjCAtTryStmt &S); |
| 1172 | void EmitObjCAtThrowStmt(const ObjCAtThrowStmt &S); |
Chris Lattner | 10cac6f | 2008-11-15 21:26:17 +0000 | [diff] [blame] | 1173 | void EmitObjCAtSynchronizedStmt(const ObjCAtSynchronizedStmt &S); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1174 | |
Douglas Gregor | 86a3a03 | 2010-05-16 01:24:12 +0000 | [diff] [blame] | 1175 | llvm::Constant *getUnwindResumeOrRethrowFn(); |
John McCall | 59a7000 | 2010-07-07 06:56:46 +0000 | [diff] [blame] | 1176 | void EnterCXXTryStmt(const CXXTryStmt &S, bool IsFnTryBlock = false); |
| 1177 | void ExitCXXTryStmt(const CXXTryStmt &S, bool IsFnTryBlock = false); |
John McCall | 9fc6a77 | 2010-02-19 09:25:03 +0000 | [diff] [blame] | 1178 | |
Anders Carlsson | 6815e94 | 2009-09-27 18:58:34 +0000 | [diff] [blame] | 1179 | void EmitCXXTryStmt(const CXXTryStmt &S); |
| 1180 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1181 | //===--------------------------------------------------------------------===// |
| 1182 | // LValue Expression Emission |
| 1183 | //===--------------------------------------------------------------------===// |
| 1184 | |
Daniel Dunbar | 13e8173 | 2009-02-05 07:09:07 +0000 | [diff] [blame] | 1185 | /// GetUndefRValue - Get an appropriate 'undef' rvalue for the given type. |
| 1186 | RValue GetUndefRValue(QualType Ty); |
| 1187 | |
Daniel Dunbar | ce1d38b | 2009-01-09 16:50:52 +0000 | [diff] [blame] | 1188 | /// EmitUnsupportedRValue - Emit a dummy r-value using the type of E |
| 1189 | /// and issue an ErrorUnsupported style diagnostic (using the |
| 1190 | /// provided Name). |
| 1191 | RValue EmitUnsupportedRValue(const Expr *E, |
| 1192 | const char *Name); |
| 1193 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1194 | /// EmitUnsupportedLValue - Emit a dummy l-value using the type of E and issue |
| 1195 | /// an ErrorUnsupported style diagnostic (using the provided Name). |
Daniel Dunbar | 6ba82a4 | 2008-08-25 20:45:57 +0000 | [diff] [blame] | 1196 | LValue EmitUnsupportedLValue(const Expr *E, |
| 1197 | const char *Name); |
| 1198 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1199 | /// EmitLValue - Emit code to compute a designator that specifies the location |
| 1200 | /// of the expression. |
| 1201 | /// |
| 1202 | /// This can return one of two things: a simple address or a bitfield |
| 1203 | /// reference. In either case, the LLVM Value* in the LValue structure is |
| 1204 | /// guaranteed to be an LLVM pointer type. |
| 1205 | /// |
| 1206 | /// If this returns a bitfield reference, nothing about the pointee type of |
| 1207 | /// the LLVM value is known: For example, it may not be a pointer to an |
| 1208 | /// integer. |
| 1209 | /// |
| 1210 | /// If this returns a normal address, and if the lvalue's C type is fixed |
| 1211 | /// size, this method guarantees that the returned pointer type will point to |
| 1212 | /// an LLVM type of the same size of the lvalue's type. If the lvalue has a |
| 1213 | /// variable length type, this is not possible. |
| 1214 | /// |
| 1215 | LValue EmitLValue(const Expr *E); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1216 | |
Mike Stump | b14e62d | 2009-12-16 02:57:00 +0000 | [diff] [blame] | 1217 | /// EmitCheckedLValue - Same as EmitLValue but additionally we generate |
| 1218 | /// checking code to guard against undefined behavior. This is only |
| 1219 | /// suitable when we know that the address will be used to access the |
| 1220 | /// object. |
| 1221 | LValue EmitCheckedLValue(const Expr *E); |
| 1222 | |
Daniel Dunbar | 9d9cc87 | 2009-02-10 00:57:50 +0000 | [diff] [blame] | 1223 | /// EmitLoadOfScalar - Load a scalar value from an address, taking |
| 1224 | /// care to appropriately convert from the memory representation to |
| 1225 | /// the LLVM value representation. |
Mike Stump | 09429b9 | 2009-02-17 17:00:02 +0000 | [diff] [blame] | 1226 | llvm::Value *EmitLoadOfScalar(llvm::Value *Addr, bool Volatile, |
Daniel Dunbar | 9d9cc87 | 2009-02-10 00:57:50 +0000 | [diff] [blame] | 1227 | QualType Ty); |
| 1228 | |
| 1229 | /// EmitStoreOfScalar - Store a scalar value to an address, taking |
| 1230 | /// care to appropriately convert from the memory representation to |
| 1231 | /// the LLVM value representation. |
Mike Stump | 09429b9 | 2009-02-17 17:00:02 +0000 | [diff] [blame] | 1232 | void EmitStoreOfScalar(llvm::Value *Value, llvm::Value *Addr, |
Anders Carlsson | b4aa466 | 2009-05-19 18:50:41 +0000 | [diff] [blame] | 1233 | bool Volatile, QualType Ty); |
Daniel Dunbar | 9d9cc87 | 2009-02-10 00:57:50 +0000 | [diff] [blame] | 1234 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1235 | /// EmitLoadOfLValue - Given an expression that represents a value lvalue, |
| 1236 | /// this method emits the address of the lvalue, then loads the result as an |
| 1237 | /// rvalue, returning the rvalue. |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1238 | RValue EmitLoadOfLValue(LValue V, QualType LVType); |
Nate Begeman | 213541a | 2008-04-18 23:10:10 +0000 | [diff] [blame] | 1239 | RValue EmitLoadOfExtVectorElementLValue(LValue V, QualType LVType); |
Lauro Ramos Venancio | 3b8c22d | 2008-01-22 20:17:04 +0000 | [diff] [blame] | 1240 | RValue EmitLoadOfBitfieldLValue(LValue LV, QualType ExprType); |
Daniel Dunbar | 85c59ed | 2008-08-29 08:11:39 +0000 | [diff] [blame] | 1241 | RValue EmitLoadOfPropertyRefLValue(LValue LV, QualType ExprType); |
Fariborz Jahanian | 43f4470 | 2008-11-22 22:30:21 +0000 | [diff] [blame] | 1242 | RValue EmitLoadOfKVCRefLValue(LValue LV, QualType ExprType); |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1243 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1244 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1245 | /// EmitStoreThroughLValue - Store the specified rvalue into the specified |
| 1246 | /// lvalue, where both are guaranteed to the have the same type, and that type |
| 1247 | /// is 'Ty'. |
| 1248 | void EmitStoreThroughLValue(RValue Src, LValue Dst, QualType Ty); |
Nate Begeman | 213541a | 2008-04-18 23:10:10 +0000 | [diff] [blame] | 1249 | void EmitStoreThroughExtVectorComponentLValue(RValue Src, LValue Dst, |
| 1250 | QualType Ty); |
Daniel Dunbar | 85c59ed | 2008-08-29 08:11:39 +0000 | [diff] [blame] | 1251 | void EmitStoreThroughPropertyRefLValue(RValue Src, LValue Dst, QualType Ty); |
Fariborz Jahanian | 43f4470 | 2008-11-22 22:30:21 +0000 | [diff] [blame] | 1252 | void EmitStoreThroughKVCRefLValue(RValue Src, LValue Dst, QualType Ty); |
Daniel Dunbar | ed3849b | 2008-11-19 09:36:46 +0000 | [diff] [blame] | 1253 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1254 | /// EmitStoreThroughLValue - Store Src into Dst with same constraints as |
| 1255 | /// EmitStoreThroughLValue. |
Daniel Dunbar | ed3849b | 2008-11-19 09:36:46 +0000 | [diff] [blame] | 1256 | /// |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1257 | /// \param Result [out] - If non-null, this will be set to a Value* for the |
| 1258 | /// bit-field contents after the store, appropriate for use as the result of |
| 1259 | /// an assignment to the bit-field. |
Daniel Dunbar | ed3849b | 2008-11-19 09:36:46 +0000 | [diff] [blame] | 1260 | void EmitStoreThroughBitfieldLValue(RValue Src, LValue Dst, QualType Ty, |
| 1261 | llvm::Value **Result=0); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1262 | |
Christopher Lamb | 22c940e | 2007-12-29 05:02:41 +0000 | [diff] [blame] | 1263 | // Note: only availabe for agg return types |
Daniel Dunbar | 80e62c2 | 2008-09-04 03:20:13 +0000 | [diff] [blame] | 1264 | LValue EmitBinaryOperatorLValue(const BinaryOperator *E); |
Douglas Gregor | 6a03e34 | 2010-04-23 04:16:32 +0000 | [diff] [blame] | 1265 | LValue EmitCompoundAssignOperatorLValue(const CompoundAssignOperator *E); |
Daniel Dunbar | 5b5c9ef | 2009-02-11 20:59:32 +0000 | [diff] [blame] | 1266 | // Note: only available for agg return types |
Christopher Lamb | 22c940e | 2007-12-29 05:02:41 +0000 | [diff] [blame] | 1267 | LValue EmitCallExprLValue(const CallExpr *E); |
Daniel Dunbar | 5b5c9ef | 2009-02-11 20:59:32 +0000 | [diff] [blame] | 1268 | // Note: only available for agg return types |
| 1269 | LValue EmitVAArgExprLValue(const VAArgExpr *E); |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1270 | LValue EmitDeclRefLValue(const DeclRefExpr *E); |
| 1271 | LValue EmitStringLiteralLValue(const StringLiteral *E); |
Chris Lattner | eaf2bb8 | 2009-02-24 22:18:39 +0000 | [diff] [blame] | 1272 | LValue EmitObjCEncodeExprLValue(const ObjCEncodeExpr *E); |
Daniel Dunbar | 662b71e | 2008-10-17 21:58:32 +0000 | [diff] [blame] | 1273 | LValue EmitPredefinedFunctionName(unsigned Type); |
Chris Lattner | d9f6910 | 2008-08-10 01:53:14 +0000 | [diff] [blame] | 1274 | LValue EmitPredefinedLValue(const PredefinedExpr *E); |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1275 | LValue EmitUnaryOpLValue(const UnaryOperator *E); |
| 1276 | LValue EmitArraySubscriptExpr(const ArraySubscriptExpr *E); |
Nate Begeman | 213541a | 2008-04-18 23:10:10 +0000 | [diff] [blame] | 1277 | LValue EmitExtVectorElementExpr(const ExtVectorElementExpr *E); |
Devang Patel | b84a06e | 2007-10-23 02:10:49 +0000 | [diff] [blame] | 1278 | LValue EmitMemberExpr(const MemberExpr *E); |
Fariborz Jahanian | 820bca4 | 2009-12-09 23:35:29 +0000 | [diff] [blame] | 1279 | LValue EmitObjCIsaExpr(const ObjCIsaExpr *E); |
Eli Friedman | 06e863f | 2008-05-13 23:18:27 +0000 | [diff] [blame] | 1280 | LValue EmitCompoundLiteralLValue(const CompoundLiteralExpr *E); |
Anders Carlsson | 6fcec8b | 2009-09-15 16:35:24 +0000 | [diff] [blame] | 1281 | LValue EmitConditionalOperatorLValue(const ConditionalOperator *E); |
Chris Lattner | 75dfeda | 2009-03-18 18:28:57 +0000 | [diff] [blame] | 1282 | LValue EmitCastLValue(const CastExpr *E); |
Douglas Gregor | ed8abf1 | 2010-07-08 06:14:04 +0000 | [diff] [blame] | 1283 | LValue EmitNullInitializationLValue(const CXXScalarValueInitExpr *E); |
Anders Carlsson | 909fbf7 | 2009-11-07 22:00:15 +0000 | [diff] [blame] | 1284 | |
Daniel Dunbar | 2a03192 | 2009-04-22 05:08:15 +0000 | [diff] [blame] | 1285 | llvm::Value *EmitIvarOffset(const ObjCInterfaceDecl *Interface, |
Daniel Dunbar | 29e0bcc | 2008-09-24 04:00:38 +0000 | [diff] [blame] | 1286 | const ObjCIvarDecl *Ivar); |
John McCall | a9976d3 | 2010-05-21 01:18:57 +0000 | [diff] [blame] | 1287 | LValue EmitLValueForAnonRecordField(llvm::Value* Base, |
| 1288 | const FieldDecl* Field, |
| 1289 | unsigned CVRQualifiers); |
Anders Carlsson | 0ed303c | 2009-11-17 03:57:07 +0000 | [diff] [blame] | 1290 | LValue EmitLValueForField(llvm::Value* Base, const FieldDecl* Field, |
Anders Carlsson | e6d2a53 | 2010-01-29 05:05:36 +0000 | [diff] [blame] | 1291 | unsigned CVRQualifiers); |
Anders Carlsson | 06a2970 | 2010-01-29 05:24:29 +0000 | [diff] [blame] | 1292 | |
| 1293 | /// EmitLValueForFieldInitialization - Like EmitLValueForField, except that |
| 1294 | /// if the Field is a reference, this will return the address of the reference |
| 1295 | /// and not the address of the value stored in the reference. |
| 1296 | LValue EmitLValueForFieldInitialization(llvm::Value* Base, |
| 1297 | const FieldDecl* Field, |
| 1298 | unsigned CVRQualifiers); |
| 1299 | |
Fariborz Jahanian | 45012a7 | 2009-02-03 00:09:52 +0000 | [diff] [blame] | 1300 | LValue EmitLValueForIvar(QualType ObjectTy, |
| 1301 | llvm::Value* Base, const ObjCIvarDecl *Ivar, |
Daniel Dunbar | 29e0bcc | 2008-09-24 04:00:38 +0000 | [diff] [blame] | 1302 | unsigned CVRQualifiers); |
| 1303 | |
Anders Carlsson | 0ed303c | 2009-11-17 03:57:07 +0000 | [diff] [blame] | 1304 | LValue EmitLValueForBitfield(llvm::Value* Base, const FieldDecl* Field, |
Fariborz Jahanian | 598d3f6 | 2009-02-03 19:03:09 +0000 | [diff] [blame] | 1305 | unsigned CVRQualifiers); |
Fariborz Jahanian | fd64bb6 | 2008-12-15 20:35:07 +0000 | [diff] [blame] | 1306 | |
Mike Stump | a99038c | 2009-02-28 09:07:16 +0000 | [diff] [blame] | 1307 | LValue EmitBlockDeclRefLValue(const BlockDeclRefExpr *E); |
| 1308 | |
Anders Carlsson | b58d017 | 2009-05-30 23:23:33 +0000 | [diff] [blame] | 1309 | LValue EmitCXXConstructLValue(const CXXConstructExpr *E); |
Anders Carlsson | e61c9e8 | 2009-05-30 23:30:54 +0000 | [diff] [blame] | 1310 | LValue EmitCXXBindTemporaryLValue(const CXXBindTemporaryExpr *E); |
Anders Carlsson | b9ea0b5 | 2009-09-14 01:10:45 +0000 | [diff] [blame] | 1311 | LValue EmitCXXExprWithTemporariesLValue(const CXXExprWithTemporaries *E); |
Mike Stump | c2e84ae | 2009-11-15 08:09:41 +0000 | [diff] [blame] | 1312 | LValue EmitCXXTypeidLValue(const CXXTypeidExpr *E); |
Anders Carlsson | b9ea0b5 | 2009-09-14 01:10:45 +0000 | [diff] [blame] | 1313 | |
Daniel Dunbar | 0a04d77 | 2008-08-23 10:51:21 +0000 | [diff] [blame] | 1314 | LValue EmitObjCMessageExprLValue(const ObjCMessageExpr *E); |
Chris Lattner | 391d77a | 2008-03-30 23:03:07 +0000 | [diff] [blame] | 1315 | LValue EmitObjCIvarRefLValue(const ObjCIvarRefExpr *E); |
Daniel Dunbar | 85c59ed | 2008-08-29 08:11:39 +0000 | [diff] [blame] | 1316 | LValue EmitObjCPropertyRefLValue(const ObjCPropertyRefExpr *E); |
Fariborz Jahanian | 09105f5 | 2009-08-20 17:02:02 +0000 | [diff] [blame] | 1317 | LValue EmitObjCKVCRefLValue(const ObjCImplicitSetterGetterRefExpr *E); |
Chris Lattner | 6545994 | 2009-04-25 19:35:26 +0000 | [diff] [blame] | 1318 | LValue EmitObjCSuperExprLValue(const ObjCSuperExpr *E); |
| 1319 | LValue EmitStmtExprLValue(const StmtExpr *E); |
Fariborz Jahanian | 8bfd31f | 2009-10-22 22:57:31 +0000 | [diff] [blame] | 1320 | LValue EmitPointerToDataMemberBinaryExpr(const BinaryOperator *E); |
Fariborz Jahanian | 03b2960 | 2010-06-17 19:56:20 +0000 | [diff] [blame] | 1321 | LValue EmitObjCSelectorLValue(const ObjCSelectorExpr *E); |
Fariborz Jahanian | 8bfd31f | 2009-10-22 22:57:31 +0000 | [diff] [blame] | 1322 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1323 | //===--------------------------------------------------------------------===// |
Chris Lattner | 883f6a7 | 2007-08-11 00:04:45 +0000 | [diff] [blame] | 1324 | // Scalar Expression Emission |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1325 | //===--------------------------------------------------------------------===// |
| 1326 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1327 | /// EmitCall - Generate a call of the given function, expecting the given |
| 1328 | /// result type, and using the given argument list which specifies both the |
| 1329 | /// LLVM arguments and the types they were derived from. |
Daniel Dunbar | c0ef9f5 | 2009-02-20 18:06:48 +0000 | [diff] [blame] | 1330 | /// |
Mike Stump | f71d232 | 2009-11-30 20:08:49 +0000 | [diff] [blame] | 1331 | /// \param TargetDecl - If given, the decl of the function in a direct call; |
| 1332 | /// used to set attributes on the call (noreturn, etc.). |
Daniel Dunbar | 88b5396 | 2009-02-02 22:03:45 +0000 | [diff] [blame] | 1333 | RValue EmitCall(const CGFunctionInfo &FnInfo, |
| 1334 | llvm::Value *Callee, |
Anders Carlsson | f3c47c9 | 2009-12-24 19:25:24 +0000 | [diff] [blame] | 1335 | ReturnValueSlot ReturnValue, |
Daniel Dunbar | c0ef9f5 | 2009-02-20 18:06:48 +0000 | [diff] [blame] | 1336 | const CallArgList &Args, |
David Chisnall | dd5c98f | 2010-05-01 11:15:56 +0000 | [diff] [blame] | 1337 | const Decl *TargetDecl = 0, |
David Chisnall | 4b02afc | 2010-05-02 13:41:58 +0000 | [diff] [blame] | 1338 | llvm::Instruction **callOrInvoke = 0); |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1339 | |
Anders Carlsson | 31777a2 | 2009-12-24 19:08:58 +0000 | [diff] [blame] | 1340 | RValue EmitCall(QualType FnType, llvm::Value *Callee, |
Anders Carlsson | d2490a9 | 2009-12-24 20:40:36 +0000 | [diff] [blame] | 1341 | ReturnValueSlot ReturnValue, |
Anders Carlsson | 9864771 | 2009-05-27 01:22:39 +0000 | [diff] [blame] | 1342 | CallExpr::const_arg_iterator ArgBeg, |
| 1343 | CallExpr::const_arg_iterator ArgEnd, |
| 1344 | const Decl *TargetDecl = 0); |
Anders Carlsson | d2490a9 | 2009-12-24 20:40:36 +0000 | [diff] [blame] | 1345 | RValue EmitCallExpr(const CallExpr *E, |
| 1346 | ReturnValueSlot ReturnValue = ReturnValueSlot()); |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1347 | |
John McCall | f1549f6 | 2010-07-06 01:34:17 +0000 | [diff] [blame] | 1348 | llvm::CallSite EmitCallOrInvoke(llvm::Value *Callee, |
| 1349 | llvm::Value * const *ArgBegin, |
| 1350 | llvm::Value * const *ArgEnd, |
| 1351 | const llvm::Twine &Name = ""); |
| 1352 | |
Anders Carlsson | 566abee | 2009-11-13 04:45:41 +0000 | [diff] [blame] | 1353 | llvm::Value *BuildVirtualCall(const CXXMethodDecl *MD, llvm::Value *This, |
Mike Stump | f0070db | 2009-08-26 20:46:33 +0000 | [diff] [blame] | 1354 | const llvm::Type *Ty); |
Anders Carlsson | 566abee | 2009-11-13 04:45:41 +0000 | [diff] [blame] | 1355 | llvm::Value *BuildVirtualCall(const CXXDestructorDecl *DD, CXXDtorType Type, |
| 1356 | llvm::Value *&This, const llvm::Type *Ty); |
| 1357 | |
Anders Carlsson | b9de2c5 | 2009-05-11 23:37:08 +0000 | [diff] [blame] | 1358 | RValue EmitCXXMemberCall(const CXXMethodDecl *MD, |
| 1359 | llvm::Value *Callee, |
Anders Carlsson | a1736c0 | 2009-12-24 21:13:40 +0000 | [diff] [blame] | 1360 | ReturnValueSlot ReturnValue, |
Anders Carlsson | b9de2c5 | 2009-05-11 23:37:08 +0000 | [diff] [blame] | 1361 | llvm::Value *This, |
Anders Carlsson | c997d42 | 2010-01-02 01:01:18 +0000 | [diff] [blame] | 1362 | llvm::Value *VTT, |
Anders Carlsson | b9de2c5 | 2009-05-11 23:37:08 +0000 | [diff] [blame] | 1363 | CallExpr::const_arg_iterator ArgBeg, |
| 1364 | CallExpr::const_arg_iterator ArgEnd); |
Anders Carlsson | a1736c0 | 2009-12-24 21:13:40 +0000 | [diff] [blame] | 1365 | RValue EmitCXXMemberCallExpr(const CXXMemberCallExpr *E, |
| 1366 | ReturnValueSlot ReturnValue); |
| 1367 | RValue EmitCXXMemberPointerCallExpr(const CXXMemberCallExpr *E, |
| 1368 | ReturnValueSlot ReturnValue); |
Ted Kremenek | 5549976 | 2008-06-17 02:43:46 +0000 | [diff] [blame] | 1369 | |
Anders Carlsson | 0f29463 | 2009-05-27 04:18:27 +0000 | [diff] [blame] | 1370 | RValue EmitCXXOperatorMemberCallExpr(const CXXOperatorCallExpr *E, |
Anders Carlsson | a1736c0 | 2009-12-24 21:13:40 +0000 | [diff] [blame] | 1371 | const CXXMethodDecl *MD, |
| 1372 | ReturnValueSlot ReturnValue); |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1373 | |
Anders Carlsson | 375c31c | 2009-10-03 19:43:08 +0000 | [diff] [blame] | 1374 | |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1375 | RValue EmitBuiltinExpr(const FunctionDecl *FD, |
Daniel Dunbar | ef2abfe | 2009-02-16 22:43:43 +0000 | [diff] [blame] | 1376 | unsigned BuiltinID, const CallExpr *E); |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1377 | |
Anders Carlsson | a1736c0 | 2009-12-24 21:13:40 +0000 | [diff] [blame] | 1378 | RValue EmitBlockCallExpr(const CallExpr *E, ReturnValueSlot ReturnValue); |
Mike Stump | 09429b9 | 2009-02-17 17:00:02 +0000 | [diff] [blame] | 1379 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1380 | /// EmitTargetBuiltinExpr - Emit the given builtin call. Returns 0 if the call |
| 1381 | /// is unhandled by the current target. |
Daniel Dunbar | f02e9dd | 2008-10-10 00:24:54 +0000 | [diff] [blame] | 1382 | llvm::Value *EmitTargetBuiltinExpr(unsigned BuiltinID, const CallExpr *E); |
| 1383 | |
Chris Lattner | 2752c01 | 2010-03-03 19:03:45 +0000 | [diff] [blame] | 1384 | llvm::Value *EmitARMBuiltinExpr(unsigned BuiltinID, const CallExpr *E); |
Nate Begeman | 30d9171 | 2010-06-08 06:03:01 +0000 | [diff] [blame] | 1385 | llvm::Value *EmitNeonCall(llvm::Function *F, |
| 1386 | llvm::SmallVectorImpl<llvm::Value*> &O, |
Nate Begeman | 61eecf5 | 2010-06-14 05:21:25 +0000 | [diff] [blame] | 1387 | const char *name, bool splat = false, |
| 1388 | unsigned shift = 0, bool rightshift = false); |
Nate Begeman | d075c01 | 2010-06-10 00:17:56 +0000 | [diff] [blame] | 1389 | llvm::Value *EmitNeonSplat(llvm::Value *V, llvm::Constant *Idx); |
Nate Begeman | 464ccb6 | 2010-06-11 22:57:12 +0000 | [diff] [blame] | 1390 | llvm::Value *EmitNeonShiftVector(llvm::Value *V, const llvm::Type *Ty, |
Nate Begeman | 61eecf5 | 2010-06-14 05:21:25 +0000 | [diff] [blame] | 1391 | bool negateForRightShift); |
Nate Begeman | 30d9171 | 2010-06-08 06:03:01 +0000 | [diff] [blame] | 1392 | |
Anders Carlsson | 564f1de | 2007-12-09 23:17:02 +0000 | [diff] [blame] | 1393 | llvm::Value *EmitX86BuiltinExpr(unsigned BuiltinID, const CallExpr *E); |
| 1394 | llvm::Value *EmitPPCBuiltinExpr(unsigned BuiltinID, const CallExpr *E); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1395 | |
Daniel Dunbar | ed7c618 | 2008-08-20 00:28:19 +0000 | [diff] [blame] | 1396 | llvm::Value *EmitObjCProtocolExpr(const ObjCProtocolExpr *E); |
Chris Lattner | 7f02f72 | 2007-08-24 05:35:26 +0000 | [diff] [blame] | 1397 | llvm::Value *EmitObjCStringLiteral(const ObjCStringLiteral *E); |
Chris Lattner | 8fdf328 | 2008-06-24 17:04:18 +0000 | [diff] [blame] | 1398 | llvm::Value *EmitObjCSelectorExpr(const ObjCSelectorExpr *E); |
John McCall | ef072fd | 2010-05-22 01:48:05 +0000 | [diff] [blame] | 1399 | RValue EmitObjCMessageExpr(const ObjCMessageExpr *E, |
| 1400 | ReturnValueSlot Return = ReturnValueSlot()); |
| 1401 | RValue EmitObjCPropertyGet(const Expr *E, |
| 1402 | ReturnValueSlot Return = ReturnValueSlot()); |
| 1403 | RValue EmitObjCSuperPropertyGet(const Expr *Exp, const Selector &S, |
| 1404 | ReturnValueSlot Return = ReturnValueSlot()); |
Fariborz Jahanian | 43f4470 | 2008-11-22 22:30:21 +0000 | [diff] [blame] | 1405 | void EmitObjCPropertySet(const Expr *E, RValue Src); |
Fariborz Jahanian | f469557 | 2009-03-20 19:18:21 +0000 | [diff] [blame] | 1406 | void EmitObjCSuperPropertySet(const Expr *E, const Selector &S, RValue Src); |
Chris Lattner | 8fdf328 | 2008-06-24 17:04:18 +0000 | [diff] [blame] | 1407 | |
| 1408 | |
Anders Carlsson | 4029ca7 | 2009-05-20 00:24:07 +0000 | [diff] [blame] | 1409 | /// EmitReferenceBindingToExpr - Emits a reference binding to the passed in |
| 1410 | /// expression. Will emit a temporary variable if E is not an LValue. |
Anders Carlsson | 32f36ba | 2010-06-26 16:35:32 +0000 | [diff] [blame] | 1411 | RValue EmitReferenceBindingToExpr(const Expr* E, |
| 1412 | const NamedDecl *InitializedDecl); |
Anders Carlsson | 3aba093 | 2010-01-31 18:34:51 +0000 | [diff] [blame] | 1413 | |
Chris Lattner | 883f6a7 | 2007-08-11 00:04:45 +0000 | [diff] [blame] | 1414 | //===--------------------------------------------------------------------===// |
Chris Lattner | bfc0c1a | 2007-08-26 23:13:56 +0000 | [diff] [blame] | 1415 | // Expression Emission |
Chris Lattner | 883f6a7 | 2007-08-11 00:04:45 +0000 | [diff] [blame] | 1416 | //===--------------------------------------------------------------------===// |
Chris Lattner | bfc0c1a | 2007-08-26 23:13:56 +0000 | [diff] [blame] | 1417 | |
| 1418 | // Expressions are broken into three classes: scalar, complex, aggregate. |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1419 | |
| 1420 | /// EmitScalarExpr - Emit the computation of the specified expression of LLVM |
| 1421 | /// scalar type, returning the result. |
Anders Carlsson | 14c5cbf | 2009-08-16 07:36:22 +0000 | [diff] [blame] | 1422 | llvm::Value *EmitScalarExpr(const Expr *E , bool IgnoreResultAssign = false); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1423 | |
Chris Lattner | 3707b25 | 2007-08-26 06:48:56 +0000 | [diff] [blame] | 1424 | /// EmitScalarConversion - Emit a conversion from the specified type to the |
| 1425 | /// specified destination type, both of which are LLVM scalar types. |
| 1426 | llvm::Value *EmitScalarConversion(llvm::Value *Src, QualType SrcTy, |
| 1427 | QualType DstTy); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1428 | |
Chris Lattner | 4f1a7b3 | 2007-08-26 16:34:22 +0000 | [diff] [blame] | 1429 | /// EmitComplexToScalarConversion - Emit a conversion from the specified |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1430 | /// complex type to the specified destination type, where the destination type |
| 1431 | /// is an LLVM scalar type. |
Chris Lattner | 4f1a7b3 | 2007-08-26 16:34:22 +0000 | [diff] [blame] | 1432 | llvm::Value *EmitComplexToScalarConversion(ComplexPairTy Src, QualType SrcTy, |
| 1433 | QualType DstTy); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1434 | |
| 1435 | |
Chris Lattner | 883f6a7 | 2007-08-11 00:04:45 +0000 | [diff] [blame] | 1436 | /// EmitAggExpr - Emit the computation of the specified expression of |
| 1437 | /// aggregate type. The result is computed into DestPtr. Note that if |
| 1438 | /// DestPtr is null, the value of the aggregate expression is not needed. |
Mike Stump | 49d1cd5 | 2009-05-26 22:03:21 +0000 | [diff] [blame] | 1439 | void EmitAggExpr(const Expr *E, llvm::Value *DestPtr, bool VolatileDest, |
Fariborz Jahanian | 08c3213 | 2009-08-31 19:33:16 +0000 | [diff] [blame] | 1440 | bool IgnoreResult = false, bool IsInitializer = false, |
| 1441 | bool RequiresGCollection = false); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1442 | |
Daniel Dunbar | 18aba0d | 2010-02-05 19:38:31 +0000 | [diff] [blame] | 1443 | /// EmitAggExprToLValue - Emit the computation of the specified expression of |
| 1444 | /// aggregate type into a temporary LValue. |
| 1445 | LValue EmitAggExprToLValue(const Expr *E); |
| 1446 | |
Fariborz Jahanian | 082b02e | 2009-07-08 01:18:33 +0000 | [diff] [blame] | 1447 | /// EmitGCMemmoveCollectable - Emit special API for structs with object |
| 1448 | /// pointers. |
| 1449 | void EmitGCMemmoveCollectable(llvm::Value *DestPtr, llvm::Value *SrcPtr, |
Fariborz Jahanian | 08c3213 | 2009-08-31 19:33:16 +0000 | [diff] [blame] | 1450 | QualType Ty); |
Fariborz Jahanian | 082b02e | 2009-07-08 01:18:33 +0000 | [diff] [blame] | 1451 | |
Chris Lattner | b6ef18a | 2007-08-21 05:54:00 +0000 | [diff] [blame] | 1452 | /// EmitComplexExpr - Emit the computation of the specified expression of |
Chris Lattner | 23b1cdb | 2007-08-23 23:43:33 +0000 | [diff] [blame] | 1453 | /// complex type, returning the result. |
Mike Stump | 7f79f9b | 2009-05-29 15:46:01 +0000 | [diff] [blame] | 1454 | ComplexPairTy EmitComplexExpr(const Expr *E, bool IgnoreReal = false, |
| 1455 | bool IgnoreImag = false, |
| 1456 | bool IgnoreRealAssign = false, |
| 1457 | bool IgnoreImagAssign = false); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1458 | |
Chris Lattner | 23b1cdb | 2007-08-23 23:43:33 +0000 | [diff] [blame] | 1459 | /// EmitComplexExprIntoAddr - Emit the computation of the specified expression |
| 1460 | /// of complex type, storing into the specified Value*. |
Chris Lattner | 190dbe2 | 2007-08-26 16:22:13 +0000 | [diff] [blame] | 1461 | void EmitComplexExprIntoAddr(const Expr *E, llvm::Value *DestAddr, |
| 1462 | bool DestIsVolatile); |
Daniel Dunbar | 7f8ea5c | 2008-08-30 05:35:15 +0000 | [diff] [blame] | 1463 | |
| 1464 | /// StoreComplexToAddr - Store a complex number into the specified address. |
| 1465 | void StoreComplexToAddr(ComplexPairTy V, llvm::Value *DestAddr, |
| 1466 | bool DestIsVolatile); |
Chris Lattner | 9b65551 | 2007-08-31 22:49:20 +0000 | [diff] [blame] | 1467 | /// LoadComplexFromAddr - Load a complex number from the specified address. |
| 1468 | ComplexPairTy LoadComplexFromAddr(llvm::Value *SrcAddr, bool SrcIsVolatile); |
Chris Lattner | 2621fd1 | 2008-05-08 05:58:21 +0000 | [diff] [blame] | 1469 | |
Mike Stump | f71d232 | 2009-11-30 20:08:49 +0000 | [diff] [blame] | 1470 | /// CreateStaticBlockVarDecl - Create a zero-initialized LLVM global for a |
| 1471 | /// static block var decl. |
Chris Lattner | 761acc1 | 2009-12-05 08:22:11 +0000 | [diff] [blame] | 1472 | llvm::GlobalVariable *CreateStaticBlockVarDecl(const VarDecl &D, |
| 1473 | const char *Separator, |
Mike Stump | f71d232 | 2009-11-30 20:08:49 +0000 | [diff] [blame] | 1474 | llvm::GlobalValue::LinkageTypes Linkage); |
Chris Lattner | 761acc1 | 2009-12-05 08:22:11 +0000 | [diff] [blame] | 1475 | |
| 1476 | /// AddInitializerToGlobalBlockVarDecl - Add the initializer for 'D' to the |
| 1477 | /// global variable that has already been created for it. If the initializer |
| 1478 | /// has a different type than GV does, this may free GV and return a different |
| 1479 | /// one. Otherwise it just returns GV. |
| 1480 | llvm::GlobalVariable * |
| 1481 | AddInitializerToGlobalBlockVarDecl(const VarDecl &D, |
| 1482 | llvm::GlobalVariable *GV); |
| 1483 | |
Daniel Dunbar | 0096acf | 2009-02-25 19:24:29 +0000 | [diff] [blame] | 1484 | |
Mike Stump | f71d232 | 2009-11-30 20:08:49 +0000 | [diff] [blame] | 1485 | /// EmitStaticCXXBlockVarDeclInit - Create the initializer for a C++ runtime |
| 1486 | /// initialized static block var decl. |
Anders Carlsson | 3b2e16b | 2009-08-08 21:45:14 +0000 | [diff] [blame] | 1487 | void EmitStaticCXXBlockVarDeclInit(const VarDecl &D, |
| 1488 | llvm::GlobalVariable *GV); |
Anders Carlsson | e1b29ef | 2008-08-22 16:00:37 +0000 | [diff] [blame] | 1489 | |
Anders Carlsson | 3b2e16b | 2009-08-08 21:45:14 +0000 | [diff] [blame] | 1490 | /// EmitCXXGlobalVarDeclInit - Create the initializer for a C++ |
| 1491 | /// variable with global storage. |
| 1492 | void EmitCXXGlobalVarDeclInit(const VarDecl &D, llvm::Constant *DeclPtr); |
| 1493 | |
| 1494 | /// EmitCXXGlobalDtorRegistration - Emits a call to register the global ptr |
| 1495 | /// with the C++ runtime so that its destructor will be called at exit. |
Fariborz Jahanian | 88f4280 | 2009-11-10 19:24:06 +0000 | [diff] [blame] | 1496 | void EmitCXXGlobalDtorRegistration(llvm::Constant *DtorFn, |
Anders Carlsson | 3b2e16b | 2009-08-08 21:45:14 +0000 | [diff] [blame] | 1497 | llvm::Constant *DeclPtr); |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1498 | |
Daniel Dunbar | efb0fa9 | 2010-03-20 04:15:41 +0000 | [diff] [blame] | 1499 | /// GenerateCXXGlobalInitFunc - Generates code for initializing global |
| 1500 | /// variables. |
| 1501 | void GenerateCXXGlobalInitFunc(llvm::Function *Fn, |
| 1502 | llvm::Constant **Decls, |
| 1503 | unsigned NumDecls); |
| 1504 | |
| 1505 | /// GenerateCXXGlobalDtorFunc - Generates code for destroying global |
| 1506 | /// variables. |
| 1507 | void GenerateCXXGlobalDtorFunc(llvm::Function *Fn, |
Chris Lattner | 810112e | 2010-06-19 05:52:45 +0000 | [diff] [blame] | 1508 | const std::vector<std::pair<llvm::WeakVH, |
Daniel Dunbar | efb0fa9 | 2010-03-20 04:15:41 +0000 | [diff] [blame] | 1509 | llvm::Constant*> > &DtorsAndObjects); |
| 1510 | |
| 1511 | void GenerateCXXGlobalVarDeclInitFunc(llvm::Function *Fn, const VarDecl *D); |
| 1512 | |
Anders Carlsson | 31ccf37 | 2009-05-03 17:47:16 +0000 | [diff] [blame] | 1513 | void EmitCXXConstructExpr(llvm::Value *Dest, const CXXConstructExpr *E); |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1514 | |
Anders Carlsson | b58d017 | 2009-05-30 23:23:33 +0000 | [diff] [blame] | 1515 | RValue EmitCXXExprWithTemporaries(const CXXExprWithTemporaries *E, |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1516 | llvm::Value *AggLoc = 0, |
Anders Carlsson | 14c5cbf | 2009-08-16 07:36:22 +0000 | [diff] [blame] | 1517 | bool IsAggLocVolatile = false, |
| 1518 | bool IsInitializer = false); |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1519 | |
Anders Carlsson | 756b5c4 | 2009-10-30 01:42:31 +0000 | [diff] [blame] | 1520 | void EmitCXXThrowExpr(const CXXThrowExpr *E); |
Douglas Gregor | 1eb2e59 | 2010-05-16 00:44:00 +0000 | [diff] [blame] | 1521 | |
Daniel Dunbar | 0ffb125 | 2008-08-04 16:51:22 +0000 | [diff] [blame] | 1522 | //===--------------------------------------------------------------------===// |
| 1523 | // Internal Helpers |
| 1524 | //===--------------------------------------------------------------------===// |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1525 | |
Chris Lattner | 0946ccd | 2008-11-11 07:41:27 +0000 | [diff] [blame] | 1526 | /// ContainsLabel - Return true if the statement contains a label in it. If |
| 1527 | /// this statement is not executed normally, it not containing a label means |
| 1528 | /// that we can just remove the code. |
| 1529 | static bool ContainsLabel(const Stmt *S, bool IgnoreCaseStmts = false); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1530 | |
Daniel Dunbar | 4bc0455 | 2008-11-12 10:12:14 +0000 | [diff] [blame] | 1531 | /// ConstantFoldsToSimpleInteger - If the specified expression does not fold |
Chris Lattner | 31a0984 | 2008-11-12 08:04:58 +0000 | [diff] [blame] | 1532 | /// to a constant, or if it does but contains a label, return 0. If it |
| 1533 | /// constant folds to 'true' and does not contain a label, return 1, if it |
| 1534 | /// constant folds to 'false' and does not contain a label, return -1. |
| 1535 | int ConstantFoldsToSimpleInteger(const Expr *Cond); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1536 | |
Chris Lattner | 31a0984 | 2008-11-12 08:04:58 +0000 | [diff] [blame] | 1537 | /// EmitBranchOnBoolExpr - Emit a branch on a boolean condition (e.g. for an |
| 1538 | /// if statement) to the specified blocks. Based on the condition, this might |
| 1539 | /// try to simplify the codegen of the conditional based on the branch. |
Chris Lattner | 9bc47e2 | 2008-11-12 07:46:33 +0000 | [diff] [blame] | 1540 | void EmitBranchOnBoolExpr(const Expr *Cond, llvm::BasicBlock *TrueBlock, |
Daniel Dunbar | 4bc0455 | 2008-11-12 10:12:14 +0000 | [diff] [blame] | 1541 | llvm::BasicBlock *FalseBlock); |
Mike Stump | be07f60 | 2009-12-14 21:58:14 +0000 | [diff] [blame] | 1542 | |
Mike Stump | 15037ca | 2009-12-15 00:35:12 +0000 | [diff] [blame] | 1543 | /// getTrapBB - Create a basic block that will call the trap intrinsic. We'll |
| 1544 | /// generate a branch around the created basic block as necessary. |
| 1545 | llvm::BasicBlock* getTrapBB(); |
Anders Carlsson | 21c9ad9 | 2010-03-30 03:27:09 +0000 | [diff] [blame] | 1546 | |
| 1547 | /// EmitCallArg - Emit a single call argument. |
| 1548 | RValue EmitCallArg(const Expr *E, QualType ArgType); |
| 1549 | |
John McCall | 2736071 | 2010-05-26 22:34:26 +0000 | [diff] [blame] | 1550 | /// EmitDelegateCallArg - We are performing a delegate call; that |
| 1551 | /// is, the current function is delegating to another one. Produce |
| 1552 | /// a r-value suitable for passing the given parameter. |
| 1553 | RValue EmitDelegateCallArg(const VarDecl *Param); |
| 1554 | |
Chris Lattner | 31a0984 | 2008-11-12 08:04:58 +0000 | [diff] [blame] | 1555 | private: |
Daniel Dunbar | 29e0bcc | 2008-09-24 04:00:38 +0000 | [diff] [blame] | 1556 | void EmitReturnOfRValue(RValue RV, QualType Ty); |
| 1557 | |
Daniel Dunbar | 5627377 | 2008-09-17 00:51:38 +0000 | [diff] [blame] | 1558 | /// ExpandTypeFromArgs - Reconstruct a structure of type \arg Ty |
| 1559 | /// from function arguments into \arg Dst. See ABIArgInfo::Expand. |
| 1560 | /// |
| 1561 | /// \param AI - The first function argument of the expansion. |
| 1562 | /// \return The argument following the last expanded function |
| 1563 | /// argument. |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1564 | llvm::Function::arg_iterator |
Daniel Dunbar | 5627377 | 2008-09-17 00:51:38 +0000 | [diff] [blame] | 1565 | ExpandTypeFromArgs(QualType Ty, LValue Dst, |
| 1566 | llvm::Function::arg_iterator AI); |
| 1567 | |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1568 | /// ExpandTypeToArgs - Expand an RValue \arg Src, with the LLVM type for \arg |
| 1569 | /// Ty, into individual arguments on the provided vector \arg Args. See |
| 1570 | /// ABIArgInfo::Expand. |
| 1571 | void ExpandTypeToArgs(QualType Ty, RValue Src, |
Daniel Dunbar | 5627377 | 2008-09-17 00:51:38 +0000 | [diff] [blame] | 1572 | llvm::SmallVector<llvm::Value*, 16> &Args); |
Anders Carlsson | c8c7b18 | 2009-01-11 19:40:10 +0000 | [diff] [blame] | 1573 | |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1574 | llvm::Value* EmitAsmInput(const AsmStmt &S, |
Daniel Dunbar | b84e8a6 | 2009-05-04 06:56:16 +0000 | [diff] [blame] | 1575 | const TargetInfo::ConstraintInfo &Info, |
Anders Carlsson | c8c7b18 | 2009-01-11 19:40:10 +0000 | [diff] [blame] | 1576 | const Expr *InputExpr, std::string &ConstraintStr); |
Mike Stump | 0dd9e88 | 2009-02-08 23:14:22 +0000 | [diff] [blame] | 1577 | |
Eli Friedman | 6d7cfd7 | 2010-07-16 00:55:21 +0000 | [diff] [blame] | 1578 | llvm::Value* EmitAsmInputLValue(const AsmStmt &S, |
| 1579 | const TargetInfo::ConstraintInfo &Info, |
| 1580 | LValue InputValue, QualType InputType, |
| 1581 | std::string &ConstraintStr); |
| 1582 | |
Anders Carlsson | 0139bb9 | 2009-04-08 20:47:54 +0000 | [diff] [blame] | 1583 | /// EmitCallArgs - Emit call arguments for a function. |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1584 | /// The CallArgTypeInfo parameter is used for iterating over the known |
Anders Carlsson | af23f69 | 2009-04-18 20:20:22 +0000 | [diff] [blame] | 1585 | /// argument types of the function being called. |
| 1586 | template<typename T> |
| 1587 | void EmitCallArgs(CallArgList& Args, const T* CallArgTypeInfo, |
Anders Carlsson | 0139bb9 | 2009-04-08 20:47:54 +0000 | [diff] [blame] | 1588 | CallExpr::const_arg_iterator ArgBeg, |
Anders Carlsson | af23f69 | 2009-04-18 20:20:22 +0000 | [diff] [blame] | 1589 | CallExpr::const_arg_iterator ArgEnd) { |
| 1590 | CallExpr::const_arg_iterator Arg = ArgBeg; |
Anders Carlsson | 0139bb9 | 2009-04-08 20:47:54 +0000 | [diff] [blame] | 1591 | |
Anders Carlsson | af23f69 | 2009-04-18 20:20:22 +0000 | [diff] [blame] | 1592 | // First, use the argument types that the type info knows about |
| 1593 | if (CallArgTypeInfo) { |
| 1594 | for (typename T::arg_type_iterator I = CallArgTypeInfo->arg_type_begin(), |
| 1595 | E = CallArgTypeInfo->arg_type_end(); I != E; ++I, ++Arg) { |
Eli Friedman | 44b0a3e | 2009-11-18 03:42:04 +0000 | [diff] [blame] | 1596 | assert(Arg != ArgEnd && "Running over edge of argument list!"); |
Anders Carlsson | af23f69 | 2009-04-18 20:20:22 +0000 | [diff] [blame] | 1597 | QualType ArgType = *I; |
| 1598 | |
| 1599 | assert(getContext().getCanonicalType(ArgType.getNonReferenceType()). |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1600 | getTypePtr() == |
| 1601 | getContext().getCanonicalType(Arg->getType()).getTypePtr() && |
Anders Carlsson | af23f69 | 2009-04-18 20:20:22 +0000 | [diff] [blame] | 1602 | "type mismatch in call argument!"); |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1603 | |
| 1604 | Args.push_back(std::make_pair(EmitCallArg(*Arg, ArgType), |
Anders Carlsson | af23f69 | 2009-04-18 20:20:22 +0000 | [diff] [blame] | 1605 | ArgType)); |
| 1606 | } |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1607 | |
| 1608 | // Either we've emitted all the call args, or we have a call to a |
Anders Carlsson | af23f69 | 2009-04-18 20:20:22 +0000 | [diff] [blame] | 1609 | // variadic function. |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1610 | assert((Arg == ArgEnd || CallArgTypeInfo->isVariadic()) && |
Anders Carlsson | af23f69 | 2009-04-18 20:20:22 +0000 | [diff] [blame] | 1611 | "Extra arguments in non-variadic function!"); |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1612 | |
Anders Carlsson | af23f69 | 2009-04-18 20:20:22 +0000 | [diff] [blame] | 1613 | } |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1614 | |
Anders Carlsson | af23f69 | 2009-04-18 20:20:22 +0000 | [diff] [blame] | 1615 | // If we still have any arguments, emit them using the type of the argument. |
| 1616 | for (; Arg != ArgEnd; ++Arg) { |
| 1617 | QualType ArgType = Arg->getType(); |
| 1618 | Args.push_back(std::make_pair(EmitCallArg(*Arg, ArgType), |
| 1619 | ArgType)); |
| 1620 | } |
| 1621 | } |
John McCall | 492c4f9 | 2010-03-03 04:15:11 +0000 | [diff] [blame] | 1622 | |
| 1623 | const TargetCodeGenInfo &getTargetHooks() const { |
| 1624 | return CGM.getTargetCodeGenInfo(); |
| 1625 | } |
John McCall | 744016d | 2010-07-06 23:57:41 +0000 | [diff] [blame] | 1626 | |
| 1627 | void EmitDeclMetadata(); |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1628 | }; |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 1629 | |
Anders Carlsson | af23f69 | 2009-04-18 20:20:22 +0000 | [diff] [blame] | 1630 | |
Reid Spencer | 5f016e2 | 2007-07-11 17:01:13 +0000 | [diff] [blame] | 1631 | } // end namespace CodeGen |
| 1632 | } // end namespace clang |
| 1633 | |
| 1634 | #endif |