annotate clang/lib/CodeGen/CGBuilder.h @ 173:0572611fdcc8 llvm10 llvm12

reorgnization done
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 11:55:54 +0900
parents 1d019706d866
children 2e18cbf3894f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 //===-- CGBuilder.h - Choose IRBuilder implementation ----------*- C++ -*-===//
anatofuz
parents:
diff changeset
2 //
anatofuz
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
anatofuz
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
anatofuz
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
anatofuz
parents:
diff changeset
6 //
anatofuz
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 #ifndef LLVM_CLANG_LIB_CODEGEN_CGBUILDER_H
anatofuz
parents:
diff changeset
10 #define LLVM_CLANG_LIB_CODEGEN_CGBUILDER_H
anatofuz
parents:
diff changeset
11
anatofuz
parents:
diff changeset
12 #include "llvm/IR/DataLayout.h"
anatofuz
parents:
diff changeset
13 #include "llvm/IR/IRBuilder.h"
anatofuz
parents:
diff changeset
14 #include "Address.h"
anatofuz
parents:
diff changeset
15 #include "CodeGenTypeCache.h"
anatofuz
parents:
diff changeset
16
anatofuz
parents:
diff changeset
17 namespace clang {
anatofuz
parents:
diff changeset
18 namespace CodeGen {
anatofuz
parents:
diff changeset
19
anatofuz
parents:
diff changeset
20 class CodeGenFunction;
anatofuz
parents:
diff changeset
21
anatofuz
parents:
diff changeset
22 /// This is an IRBuilder insertion helper that forwards to
anatofuz
parents:
diff changeset
23 /// CodeGenFunction::InsertHelper, which adds necessary metadata to
anatofuz
parents:
diff changeset
24 /// instructions.
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
25 class CGBuilderInserter final : public llvm::IRBuilderDefaultInserter {
150
anatofuz
parents:
diff changeset
26 public:
anatofuz
parents:
diff changeset
27 CGBuilderInserter() = default;
anatofuz
parents:
diff changeset
28 explicit CGBuilderInserter(CodeGenFunction *CGF) : CGF(CGF) {}
anatofuz
parents:
diff changeset
29
anatofuz
parents:
diff changeset
30 /// This forwards to CodeGenFunction::InsertHelper.
anatofuz
parents:
diff changeset
31 void InsertHelper(llvm::Instruction *I, const llvm::Twine &Name,
anatofuz
parents:
diff changeset
32 llvm::BasicBlock *BB,
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
33 llvm::BasicBlock::iterator InsertPt) const override;
150
anatofuz
parents:
diff changeset
34 private:
anatofuz
parents:
diff changeset
35 CodeGenFunction *CGF = nullptr;
anatofuz
parents:
diff changeset
36 };
anatofuz
parents:
diff changeset
37
anatofuz
parents:
diff changeset
38 typedef CGBuilderInserter CGBuilderInserterTy;
anatofuz
parents:
diff changeset
39
anatofuz
parents:
diff changeset
40 typedef llvm::IRBuilder<llvm::ConstantFolder, CGBuilderInserterTy>
anatofuz
parents:
diff changeset
41 CGBuilderBaseTy;
anatofuz
parents:
diff changeset
42
anatofuz
parents:
diff changeset
43 class CGBuilderTy : public CGBuilderBaseTy {
anatofuz
parents:
diff changeset
44 /// Storing a reference to the type cache here makes it a lot easier
anatofuz
parents:
diff changeset
45 /// to build natural-feeling, target-specific IR.
anatofuz
parents:
diff changeset
46 const CodeGenTypeCache &TypeCache;
anatofuz
parents:
diff changeset
47 public:
anatofuz
parents:
diff changeset
48 CGBuilderTy(const CodeGenTypeCache &TypeCache, llvm::LLVMContext &C)
anatofuz
parents:
diff changeset
49 : CGBuilderBaseTy(C), TypeCache(TypeCache) {}
anatofuz
parents:
diff changeset
50 CGBuilderTy(const CodeGenTypeCache &TypeCache,
anatofuz
parents:
diff changeset
51 llvm::LLVMContext &C, const llvm::ConstantFolder &F,
anatofuz
parents:
diff changeset
52 const CGBuilderInserterTy &Inserter)
anatofuz
parents:
diff changeset
53 : CGBuilderBaseTy(C, F, Inserter), TypeCache(TypeCache) {}
anatofuz
parents:
diff changeset
54 CGBuilderTy(const CodeGenTypeCache &TypeCache, llvm::Instruction *I)
anatofuz
parents:
diff changeset
55 : CGBuilderBaseTy(I), TypeCache(TypeCache) {}
anatofuz
parents:
diff changeset
56 CGBuilderTy(const CodeGenTypeCache &TypeCache, llvm::BasicBlock *BB)
anatofuz
parents:
diff changeset
57 : CGBuilderBaseTy(BB), TypeCache(TypeCache) {}
anatofuz
parents:
diff changeset
58
anatofuz
parents:
diff changeset
59 llvm::ConstantInt *getSize(CharUnits N) {
anatofuz
parents:
diff changeset
60 return llvm::ConstantInt::get(TypeCache.SizeTy, N.getQuantity());
anatofuz
parents:
diff changeset
61 }
anatofuz
parents:
diff changeset
62 llvm::ConstantInt *getSize(uint64_t N) {
anatofuz
parents:
diff changeset
63 return llvm::ConstantInt::get(TypeCache.SizeTy, N);
anatofuz
parents:
diff changeset
64 }
anatofuz
parents:
diff changeset
65
anatofuz
parents:
diff changeset
66 // Note that we intentionally hide the CreateLoad APIs that don't
anatofuz
parents:
diff changeset
67 // take an alignment.
anatofuz
parents:
diff changeset
68 llvm::LoadInst *CreateLoad(Address Addr, const llvm::Twine &Name = "") {
anatofuz
parents:
diff changeset
69 return CreateAlignedLoad(Addr.getPointer(),
anatofuz
parents:
diff changeset
70 Addr.getAlignment().getAsAlign(), Name);
anatofuz
parents:
diff changeset
71 }
anatofuz
parents:
diff changeset
72 llvm::LoadInst *CreateLoad(Address Addr, const char *Name) {
anatofuz
parents:
diff changeset
73 // This overload is required to prevent string literals from
anatofuz
parents:
diff changeset
74 // ending up in the IsVolatile overload.
anatofuz
parents:
diff changeset
75 return CreateAlignedLoad(Addr.getPointer(),
anatofuz
parents:
diff changeset
76 Addr.getAlignment().getAsAlign(), Name);
anatofuz
parents:
diff changeset
77 }
anatofuz
parents:
diff changeset
78 llvm::LoadInst *CreateLoad(Address Addr, bool IsVolatile,
anatofuz
parents:
diff changeset
79 const llvm::Twine &Name = "") {
anatofuz
parents:
diff changeset
80 return CreateAlignedLoad(
anatofuz
parents:
diff changeset
81 Addr.getPointer(), Addr.getAlignment().getAsAlign(), IsVolatile, Name);
anatofuz
parents:
diff changeset
82 }
anatofuz
parents:
diff changeset
83
anatofuz
parents:
diff changeset
84 using CGBuilderBaseTy::CreateAlignedLoad;
anatofuz
parents:
diff changeset
85 llvm::LoadInst *CreateAlignedLoad(llvm::Value *Addr, CharUnits Align,
anatofuz
parents:
diff changeset
86 const llvm::Twine &Name = "") {
anatofuz
parents:
diff changeset
87 return CreateAlignedLoad(Addr, Align.getAsAlign(), Name);
anatofuz
parents:
diff changeset
88 }
anatofuz
parents:
diff changeset
89 llvm::LoadInst *CreateAlignedLoad(llvm::Value *Addr, CharUnits Align,
anatofuz
parents:
diff changeset
90 const char *Name) {
anatofuz
parents:
diff changeset
91 return CreateAlignedLoad(Addr, Align.getAsAlign(), Name);
anatofuz
parents:
diff changeset
92 }
anatofuz
parents:
diff changeset
93 llvm::LoadInst *CreateAlignedLoad(llvm::Type *Ty, llvm::Value *Addr,
anatofuz
parents:
diff changeset
94 CharUnits Align,
anatofuz
parents:
diff changeset
95 const llvm::Twine &Name = "") {
anatofuz
parents:
diff changeset
96 assert(Addr->getType()->getPointerElementType() == Ty);
anatofuz
parents:
diff changeset
97 return CreateAlignedLoad(Addr, Align.getAsAlign(), Name);
anatofuz
parents:
diff changeset
98 }
anatofuz
parents:
diff changeset
99
anatofuz
parents:
diff changeset
100 // Note that we intentionally hide the CreateStore APIs that don't
anatofuz
parents:
diff changeset
101 // take an alignment.
anatofuz
parents:
diff changeset
102 llvm::StoreInst *CreateStore(llvm::Value *Val, Address Addr,
anatofuz
parents:
diff changeset
103 bool IsVolatile = false) {
anatofuz
parents:
diff changeset
104 return CreateAlignedStore(Val, Addr.getPointer(),
anatofuz
parents:
diff changeset
105 Addr.getAlignment().getAsAlign(), IsVolatile);
anatofuz
parents:
diff changeset
106 }
anatofuz
parents:
diff changeset
107
anatofuz
parents:
diff changeset
108 using CGBuilderBaseTy::CreateAlignedStore;
anatofuz
parents:
diff changeset
109 llvm::StoreInst *CreateAlignedStore(llvm::Value *Val, llvm::Value *Addr,
anatofuz
parents:
diff changeset
110 CharUnits Align, bool IsVolatile = false) {
anatofuz
parents:
diff changeset
111 return CreateAlignedStore(Val, Addr, Align.getAsAlign(), IsVolatile);
anatofuz
parents:
diff changeset
112 }
anatofuz
parents:
diff changeset
113
anatofuz
parents:
diff changeset
114 // FIXME: these "default-aligned" APIs should be removed,
anatofuz
parents:
diff changeset
115 // but I don't feel like fixing all the builtin code right now.
anatofuz
parents:
diff changeset
116 llvm::StoreInst *CreateDefaultAlignedStore(llvm::Value *Val,
anatofuz
parents:
diff changeset
117 llvm::Value *Addr,
anatofuz
parents:
diff changeset
118 bool IsVolatile = false) {
anatofuz
parents:
diff changeset
119 return CGBuilderBaseTy::CreateStore(Val, Addr, IsVolatile);
anatofuz
parents:
diff changeset
120 }
anatofuz
parents:
diff changeset
121
anatofuz
parents:
diff changeset
122 /// Emit a load from an i1 flag variable.
anatofuz
parents:
diff changeset
123 llvm::LoadInst *CreateFlagLoad(llvm::Value *Addr,
anatofuz
parents:
diff changeset
124 const llvm::Twine &Name = "") {
anatofuz
parents:
diff changeset
125 assert(Addr->getType()->getPointerElementType() == getInt1Ty());
anatofuz
parents:
diff changeset
126 return CreateAlignedLoad(getInt1Ty(), Addr, CharUnits::One(), Name);
anatofuz
parents:
diff changeset
127 }
anatofuz
parents:
diff changeset
128
anatofuz
parents:
diff changeset
129 /// Emit a store to an i1 flag variable.
anatofuz
parents:
diff changeset
130 llvm::StoreInst *CreateFlagStore(bool Value, llvm::Value *Addr) {
anatofuz
parents:
diff changeset
131 assert(Addr->getType()->getPointerElementType() == getInt1Ty());
anatofuz
parents:
diff changeset
132 return CreateAlignedStore(getInt1(Value), Addr, CharUnits::One());
anatofuz
parents:
diff changeset
133 }
anatofuz
parents:
diff changeset
134
anatofuz
parents:
diff changeset
135 using CGBuilderBaseTy::CreateBitCast;
anatofuz
parents:
diff changeset
136 Address CreateBitCast(Address Addr, llvm::Type *Ty,
anatofuz
parents:
diff changeset
137 const llvm::Twine &Name = "") {
anatofuz
parents:
diff changeset
138 return Address(CreateBitCast(Addr.getPointer(), Ty, Name),
anatofuz
parents:
diff changeset
139 Addr.getAlignment());
anatofuz
parents:
diff changeset
140 }
anatofuz
parents:
diff changeset
141
anatofuz
parents:
diff changeset
142 using CGBuilderBaseTy::CreateAddrSpaceCast;
anatofuz
parents:
diff changeset
143 Address CreateAddrSpaceCast(Address Addr, llvm::Type *Ty,
anatofuz
parents:
diff changeset
144 const llvm::Twine &Name = "") {
anatofuz
parents:
diff changeset
145 return Address(CreateAddrSpaceCast(Addr.getPointer(), Ty, Name),
anatofuz
parents:
diff changeset
146 Addr.getAlignment());
anatofuz
parents:
diff changeset
147 }
anatofuz
parents:
diff changeset
148
anatofuz
parents:
diff changeset
149 /// Cast the element type of the given address to a different type,
anatofuz
parents:
diff changeset
150 /// preserving information like the alignment and address space.
anatofuz
parents:
diff changeset
151 Address CreateElementBitCast(Address Addr, llvm::Type *Ty,
anatofuz
parents:
diff changeset
152 const llvm::Twine &Name = "") {
anatofuz
parents:
diff changeset
153 auto PtrTy = Ty->getPointerTo(Addr.getAddressSpace());
anatofuz
parents:
diff changeset
154 return CreateBitCast(Addr, PtrTy, Name);
anatofuz
parents:
diff changeset
155 }
anatofuz
parents:
diff changeset
156
anatofuz
parents:
diff changeset
157 using CGBuilderBaseTy::CreatePointerBitCastOrAddrSpaceCast;
anatofuz
parents:
diff changeset
158 Address CreatePointerBitCastOrAddrSpaceCast(Address Addr, llvm::Type *Ty,
anatofuz
parents:
diff changeset
159 const llvm::Twine &Name = "") {
anatofuz
parents:
diff changeset
160 llvm::Value *Ptr =
anatofuz
parents:
diff changeset
161 CreatePointerBitCastOrAddrSpaceCast(Addr.getPointer(), Ty, Name);
anatofuz
parents:
diff changeset
162 return Address(Ptr, Addr.getAlignment());
anatofuz
parents:
diff changeset
163 }
anatofuz
parents:
diff changeset
164
anatofuz
parents:
diff changeset
165 /// Given
anatofuz
parents:
diff changeset
166 /// %addr = {T1, T2...}* ...
anatofuz
parents:
diff changeset
167 /// produce
anatofuz
parents:
diff changeset
168 /// %name = getelementptr inbounds %addr, i32 0, i32 index
anatofuz
parents:
diff changeset
169 ///
anatofuz
parents:
diff changeset
170 /// This API assumes that drilling into a struct like this is always an
anatofuz
parents:
diff changeset
171 /// inbounds operation.
anatofuz
parents:
diff changeset
172 using CGBuilderBaseTy::CreateStructGEP;
anatofuz
parents:
diff changeset
173 Address CreateStructGEP(Address Addr, unsigned Index,
anatofuz
parents:
diff changeset
174 const llvm::Twine &Name = "") {
anatofuz
parents:
diff changeset
175 llvm::StructType *ElTy = cast<llvm::StructType>(Addr.getElementType());
anatofuz
parents:
diff changeset
176 const llvm::DataLayout &DL = BB->getParent()->getParent()->getDataLayout();
anatofuz
parents:
diff changeset
177 const llvm::StructLayout *Layout = DL.getStructLayout(ElTy);
anatofuz
parents:
diff changeset
178 auto Offset = CharUnits::fromQuantity(Layout->getElementOffset(Index));
anatofuz
parents:
diff changeset
179
anatofuz
parents:
diff changeset
180 return Address(CreateStructGEP(Addr.getElementType(),
anatofuz
parents:
diff changeset
181 Addr.getPointer(), Index, Name),
anatofuz
parents:
diff changeset
182 Addr.getAlignment().alignmentAtOffset(Offset));
anatofuz
parents:
diff changeset
183 }
anatofuz
parents:
diff changeset
184
anatofuz
parents:
diff changeset
185 /// Given
anatofuz
parents:
diff changeset
186 /// %addr = [n x T]* ...
anatofuz
parents:
diff changeset
187 /// produce
anatofuz
parents:
diff changeset
188 /// %name = getelementptr inbounds %addr, i64 0, i64 index
anatofuz
parents:
diff changeset
189 /// where i64 is actually the target word size.
anatofuz
parents:
diff changeset
190 ///
anatofuz
parents:
diff changeset
191 /// This API assumes that drilling into an array like this is always
anatofuz
parents:
diff changeset
192 /// an inbounds operation.
anatofuz
parents:
diff changeset
193 Address CreateConstArrayGEP(Address Addr, uint64_t Index,
anatofuz
parents:
diff changeset
194 const llvm::Twine &Name = "") {
anatofuz
parents:
diff changeset
195 llvm::ArrayType *ElTy = cast<llvm::ArrayType>(Addr.getElementType());
anatofuz
parents:
diff changeset
196 const llvm::DataLayout &DL = BB->getParent()->getParent()->getDataLayout();
anatofuz
parents:
diff changeset
197 CharUnits EltSize =
anatofuz
parents:
diff changeset
198 CharUnits::fromQuantity(DL.getTypeAllocSize(ElTy->getElementType()));
anatofuz
parents:
diff changeset
199
anatofuz
parents:
diff changeset
200 return Address(
anatofuz
parents:
diff changeset
201 CreateInBoundsGEP(Addr.getPointer(),
anatofuz
parents:
diff changeset
202 {getSize(CharUnits::Zero()), getSize(Index)}, Name),
anatofuz
parents:
diff changeset
203 Addr.getAlignment().alignmentAtOffset(Index * EltSize));
anatofuz
parents:
diff changeset
204 }
anatofuz
parents:
diff changeset
205
anatofuz
parents:
diff changeset
206 /// Given
anatofuz
parents:
diff changeset
207 /// %addr = T* ...
anatofuz
parents:
diff changeset
208 /// produce
anatofuz
parents:
diff changeset
209 /// %name = getelementptr inbounds %addr, i64 index
anatofuz
parents:
diff changeset
210 /// where i64 is actually the target word size.
anatofuz
parents:
diff changeset
211 Address CreateConstInBoundsGEP(Address Addr, uint64_t Index,
anatofuz
parents:
diff changeset
212 const llvm::Twine &Name = "") {
anatofuz
parents:
diff changeset
213 llvm::Type *ElTy = Addr.getElementType();
anatofuz
parents:
diff changeset
214 const llvm::DataLayout &DL = BB->getParent()->getParent()->getDataLayout();
anatofuz
parents:
diff changeset
215 CharUnits EltSize = CharUnits::fromQuantity(DL.getTypeAllocSize(ElTy));
anatofuz
parents:
diff changeset
216
anatofuz
parents:
diff changeset
217 return Address(CreateInBoundsGEP(Addr.getElementType(), Addr.getPointer(),
anatofuz
parents:
diff changeset
218 getSize(Index), Name),
anatofuz
parents:
diff changeset
219 Addr.getAlignment().alignmentAtOffset(Index * EltSize));
anatofuz
parents:
diff changeset
220 }
anatofuz
parents:
diff changeset
221
anatofuz
parents:
diff changeset
222 /// Given
anatofuz
parents:
diff changeset
223 /// %addr = T* ...
anatofuz
parents:
diff changeset
224 /// produce
anatofuz
parents:
diff changeset
225 /// %name = getelementptr inbounds %addr, i64 index
anatofuz
parents:
diff changeset
226 /// where i64 is actually the target word size.
anatofuz
parents:
diff changeset
227 Address CreateConstGEP(Address Addr, uint64_t Index,
anatofuz
parents:
diff changeset
228 const llvm::Twine &Name = "") {
anatofuz
parents:
diff changeset
229 const llvm::DataLayout &DL = BB->getParent()->getParent()->getDataLayout();
anatofuz
parents:
diff changeset
230 CharUnits EltSize =
anatofuz
parents:
diff changeset
231 CharUnits::fromQuantity(DL.getTypeAllocSize(Addr.getElementType()));
anatofuz
parents:
diff changeset
232
anatofuz
parents:
diff changeset
233 return Address(CreateGEP(Addr.getElementType(), Addr.getPointer(),
anatofuz
parents:
diff changeset
234 getSize(Index), Name),
anatofuz
parents:
diff changeset
235 Addr.getAlignment().alignmentAtOffset(Index * EltSize));
anatofuz
parents:
diff changeset
236 }
anatofuz
parents:
diff changeset
237
anatofuz
parents:
diff changeset
238 /// Given a pointer to i8, adjust it by a given constant offset.
anatofuz
parents:
diff changeset
239 Address CreateConstInBoundsByteGEP(Address Addr, CharUnits Offset,
anatofuz
parents:
diff changeset
240 const llvm::Twine &Name = "") {
anatofuz
parents:
diff changeset
241 assert(Addr.getElementType() == TypeCache.Int8Ty);
anatofuz
parents:
diff changeset
242 return Address(CreateInBoundsGEP(Addr.getPointer(), getSize(Offset), Name),
anatofuz
parents:
diff changeset
243 Addr.getAlignment().alignmentAtOffset(Offset));
anatofuz
parents:
diff changeset
244 }
anatofuz
parents:
diff changeset
245 Address CreateConstByteGEP(Address Addr, CharUnits Offset,
anatofuz
parents:
diff changeset
246 const llvm::Twine &Name = "") {
anatofuz
parents:
diff changeset
247 assert(Addr.getElementType() == TypeCache.Int8Ty);
anatofuz
parents:
diff changeset
248 return Address(CreateGEP(Addr.getPointer(), getSize(Offset), Name),
anatofuz
parents:
diff changeset
249 Addr.getAlignment().alignmentAtOffset(Offset));
anatofuz
parents:
diff changeset
250 }
anatofuz
parents:
diff changeset
251
anatofuz
parents:
diff changeset
252 using CGBuilderBaseTy::CreateConstInBoundsGEP2_32;
anatofuz
parents:
diff changeset
253 Address CreateConstInBoundsGEP2_32(Address Addr, unsigned Idx0, unsigned Idx1,
anatofuz
parents:
diff changeset
254 const llvm::Twine &Name = "") {
anatofuz
parents:
diff changeset
255 const llvm::DataLayout &DL = BB->getParent()->getParent()->getDataLayout();
anatofuz
parents:
diff changeset
256
anatofuz
parents:
diff changeset
257 auto *GEP = cast<llvm::GetElementPtrInst>(CreateConstInBoundsGEP2_32(
anatofuz
parents:
diff changeset
258 Addr.getElementType(), Addr.getPointer(), Idx0, Idx1, Name));
anatofuz
parents:
diff changeset
259 llvm::APInt Offset(
anatofuz
parents:
diff changeset
260 DL.getIndexSizeInBits(Addr.getType()->getPointerAddressSpace()), 0,
anatofuz
parents:
diff changeset
261 /*isSigned=*/true);
anatofuz
parents:
diff changeset
262 if (!GEP->accumulateConstantOffset(DL, Offset))
anatofuz
parents:
diff changeset
263 llvm_unreachable("offset of GEP with constants is always computable");
anatofuz
parents:
diff changeset
264 return Address(GEP, Addr.getAlignment().alignmentAtOffset(
anatofuz
parents:
diff changeset
265 CharUnits::fromQuantity(Offset.getSExtValue())));
anatofuz
parents:
diff changeset
266 }
anatofuz
parents:
diff changeset
267
anatofuz
parents:
diff changeset
268 using CGBuilderBaseTy::CreateMemCpy;
anatofuz
parents:
diff changeset
269 llvm::CallInst *CreateMemCpy(Address Dest, Address Src, llvm::Value *Size,
anatofuz
parents:
diff changeset
270 bool IsVolatile = false) {
anatofuz
parents:
diff changeset
271 return CreateMemCpy(Dest.getPointer(), Dest.getAlignment().getAsAlign(),
anatofuz
parents:
diff changeset
272 Src.getPointer(), Src.getAlignment().getAsAlign(), Size,
anatofuz
parents:
diff changeset
273 IsVolatile);
anatofuz
parents:
diff changeset
274 }
anatofuz
parents:
diff changeset
275 llvm::CallInst *CreateMemCpy(Address Dest, Address Src, uint64_t Size,
anatofuz
parents:
diff changeset
276 bool IsVolatile = false) {
anatofuz
parents:
diff changeset
277 return CreateMemCpy(Dest.getPointer(), Dest.getAlignment().getAsAlign(),
anatofuz
parents:
diff changeset
278 Src.getPointer(), Src.getAlignment().getAsAlign(), Size,
anatofuz
parents:
diff changeset
279 IsVolatile);
anatofuz
parents:
diff changeset
280 }
anatofuz
parents:
diff changeset
281
anatofuz
parents:
diff changeset
282 using CGBuilderBaseTy::CreateMemCpyInline;
anatofuz
parents:
diff changeset
283 llvm::CallInst *CreateMemCpyInline(Address Dest, Address Src, uint64_t Size) {
anatofuz
parents:
diff changeset
284 return CreateMemCpyInline(
anatofuz
parents:
diff changeset
285 Dest.getPointer(), Dest.getAlignment().getAsAlign(), Src.getPointer(),
anatofuz
parents:
diff changeset
286 Src.getAlignment().getAsAlign(), getInt64(Size));
anatofuz
parents:
diff changeset
287 }
anatofuz
parents:
diff changeset
288
anatofuz
parents:
diff changeset
289 using CGBuilderBaseTy::CreateMemMove;
anatofuz
parents:
diff changeset
290 llvm::CallInst *CreateMemMove(Address Dest, Address Src, llvm::Value *Size,
anatofuz
parents:
diff changeset
291 bool IsVolatile = false) {
anatofuz
parents:
diff changeset
292 return CreateMemMove(Dest.getPointer(), Dest.getAlignment().getAsAlign(),
anatofuz
parents:
diff changeset
293 Src.getPointer(), Src.getAlignment().getAsAlign(),
anatofuz
parents:
diff changeset
294 Size, IsVolatile);
anatofuz
parents:
diff changeset
295 }
anatofuz
parents:
diff changeset
296
anatofuz
parents:
diff changeset
297 using CGBuilderBaseTy::CreateMemSet;
anatofuz
parents:
diff changeset
298 llvm::CallInst *CreateMemSet(Address Dest, llvm::Value *Value,
anatofuz
parents:
diff changeset
299 llvm::Value *Size, bool IsVolatile = false) {
anatofuz
parents:
diff changeset
300 return CreateMemSet(Dest.getPointer(), Value, Size,
anatofuz
parents:
diff changeset
301 Dest.getAlignment().getAsAlign(), IsVolatile);
anatofuz
parents:
diff changeset
302 }
anatofuz
parents:
diff changeset
303
anatofuz
parents:
diff changeset
304 using CGBuilderBaseTy::CreatePreserveStructAccessIndex;
anatofuz
parents:
diff changeset
305 Address CreatePreserveStructAccessIndex(Address Addr,
anatofuz
parents:
diff changeset
306 unsigned Index,
anatofuz
parents:
diff changeset
307 unsigned FieldIndex,
anatofuz
parents:
diff changeset
308 llvm::MDNode *DbgInfo) {
anatofuz
parents:
diff changeset
309 llvm::StructType *ElTy = cast<llvm::StructType>(Addr.getElementType());
anatofuz
parents:
diff changeset
310 const llvm::DataLayout &DL = BB->getParent()->getParent()->getDataLayout();
anatofuz
parents:
diff changeset
311 const llvm::StructLayout *Layout = DL.getStructLayout(ElTy);
anatofuz
parents:
diff changeset
312 auto Offset = CharUnits::fromQuantity(Layout->getElementOffset(Index));
anatofuz
parents:
diff changeset
313
anatofuz
parents:
diff changeset
314 return Address(CreatePreserveStructAccessIndex(ElTy, Addr.getPointer(),
anatofuz
parents:
diff changeset
315 Index, FieldIndex, DbgInfo),
anatofuz
parents:
diff changeset
316 Addr.getAlignment().alignmentAtOffset(Offset));
anatofuz
parents:
diff changeset
317 }
anatofuz
parents:
diff changeset
318 };
anatofuz
parents:
diff changeset
319
anatofuz
parents:
diff changeset
320 } // end namespace CodeGen
anatofuz
parents:
diff changeset
321 } // end namespace clang
anatofuz
parents:
diff changeset
322
anatofuz
parents:
diff changeset
323 #endif