LLVM 20.0.0git
DataLayout.cpp
Go to the documentation of this file.
1//===- DataLayout.cpp - Data size & alignment routines ---------------------==//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file defines layout properties related to datatype size/offset/alignment
10// information.
11//
12// This structure should be created once, filled in if the defaults are not
13// correct and then passed around by const&. None of the members functions
14// require modification to the object.
15//
16//===----------------------------------------------------------------------===//
17
18#include "llvm/IR/DataLayout.h"
19#include "llvm/ADT/DenseMap.h"
20#include "llvm/ADT/StringRef.h"
21#include "llvm/IR/Constants.h"
25#include "llvm/IR/Module.h"
26#include "llvm/IR/Type.h"
27#include "llvm/IR/Value.h"
29#include "llvm/Support/Error.h"
35#include <algorithm>
36#include <cassert>
37#include <cstdint>
38#include <cstdlib>
39#include <new>
40#include <utility>
41
42using namespace llvm;
43
44//===----------------------------------------------------------------------===//
45// Support for StructLayout
46//===----------------------------------------------------------------------===//
47
48StructLayout::StructLayout(StructType *ST, const DataLayout &DL)
49 : StructSize(TypeSize::getFixed(0)) {
50 assert(!ST->isOpaque() && "Cannot get layout of opaque structs");
51 IsPadded = false;
52 NumElements = ST->getNumElements();
53
54 // Loop over each of the elements, placing them in memory.
55 for (unsigned i = 0, e = NumElements; i != e; ++i) {
56 Type *Ty = ST->getElementType(i);
57 if (i == 0 && Ty->isScalableTy())
58 StructSize = TypeSize::getScalable(0);
59
60 const Align TyAlign = ST->isPacked() ? Align(1) : DL.getABITypeAlign(Ty);
61
62 // Add padding if necessary to align the data element properly.
63 // Currently the only structure with scalable size will be the homogeneous
64 // scalable vector types. Homogeneous scalable vector types have members of
65 // the same data type so no alignment issue will happen. The condition here
66 // assumes so and needs to be adjusted if this assumption changes (e.g. we
67 // support structures with arbitrary scalable data type, or structure that
68 // contains both fixed size and scalable size data type members).
69 if (!StructSize.isScalable() && !isAligned(TyAlign, StructSize)) {
70 IsPadded = true;
71 StructSize = TypeSize::getFixed(alignTo(StructSize, TyAlign));
72 }
73
74 // Keep track of maximum alignment constraint.
75 StructAlignment = std::max(TyAlign, StructAlignment);
76
77 getMemberOffsets()[i] = StructSize;
78 // Consume space for this data item
79 StructSize += DL.getTypeAllocSize(Ty);
80 }
81
82 // Add padding to the end of the struct so that it could be put in an array
83 // and all array elements would be aligned correctly.
84 if (!StructSize.isScalable() && !isAligned(StructAlignment, StructSize)) {
85 IsPadded = true;
86 StructSize = TypeSize::getFixed(alignTo(StructSize, StructAlignment));
87 }
88}
89
90/// getElementContainingOffset - Given a valid offset into the structure,
91/// return the structure index that contains it.
93 assert(!StructSize.isScalable() &&
94 "Cannot get element at offset for structure containing scalable "
95 "vector types");
96 TypeSize Offset = TypeSize::getFixed(FixedOffset);
97 ArrayRef<TypeSize> MemberOffsets = getMemberOffsets();
98
99 const auto *SI =
100 std::upper_bound(MemberOffsets.begin(), MemberOffsets.end(), Offset,
101 [](TypeSize LHS, TypeSize RHS) -> bool {
102 return TypeSize::isKnownLT(LHS, RHS);
103 });
104 assert(SI != MemberOffsets.begin() && "Offset not in structure type!");
105 --SI;
106 assert(TypeSize::isKnownLE(*SI, Offset) && "upper_bound didn't work");
107 assert(
108 (SI == MemberOffsets.begin() || TypeSize::isKnownLE(*(SI - 1), Offset)) &&
109 (SI + 1 == MemberOffsets.end() ||
110 TypeSize::isKnownGT(*(SI + 1), Offset)) &&
111 "Upper bound didn't work!");
112
113 // Multiple fields can have the same offset if any of them are zero sized.
114 // For example, in { i32, [0 x i32], i32 }, searching for offset 4 will stop
115 // at the i32 element, because it is the last element at that offset. This is
116 // the right one to return, because anything after it will have a higher
117 // offset, implying that this element is non-empty.
118 return SI - MemberOffsets.begin();
119}
120
121//===----------------------------------------------------------------------===//
122// LayoutAlignElem, LayoutAlign support
123//===----------------------------------------------------------------------===//
124
127 assert(ABIAlign <= PrefAlign && "Preferred alignment worse than ABI!");
128 LayoutAlignElem retval;
129 retval.ABIAlign = ABIAlign;
130 retval.PrefAlign = PrefAlign;
131 retval.TypeBitWidth = BitWidth;
132 return retval;
133}
134
136 return ABIAlign == rhs.ABIAlign && PrefAlign == rhs.PrefAlign &&
138}
139
140//===----------------------------------------------------------------------===//
141// PointerAlignElem, PointerAlign support
142//===----------------------------------------------------------------------===//
143
145 Align ABIAlign, Align PrefAlign,
146 uint32_t TypeBitWidth,
147 uint32_t IndexBitWidth) {
148 assert(ABIAlign <= PrefAlign && "Preferred alignment worse than ABI!");
149 PointerAlignElem retval;
150 retval.AddressSpace = AddressSpace;
151 retval.ABIAlign = ABIAlign;
152 retval.PrefAlign = PrefAlign;
153 retval.TypeBitWidth = TypeBitWidth;
155 return retval;
156}
157
158bool
160 return (ABIAlign == rhs.ABIAlign && AddressSpace == rhs.AddressSpace &&
161 PrefAlign == rhs.PrefAlign && TypeBitWidth == rhs.TypeBitWidth &&
163}
164
165//===----------------------------------------------------------------------===//
166// DataLayout Class Implementation
167//===----------------------------------------------------------------------===//
168
170 if (T.isOSBinFormatGOFF())
171 return "-m:l";
172 if (T.isOSBinFormatMachO())
173 return "-m:o";
174 if ((T.isOSWindows() || T.isUEFI()) && T.isOSBinFormatCOFF())
175 return T.getArch() == Triple::x86 ? "-m:x" : "-m:w";
176 if (T.isOSBinFormatXCOFF())
177 return "-m:a";
178 return "-m:e";
179}
180
181static const std::pair<AlignTypeEnum, LayoutAlignElem> DefaultAlignments[] = {
182 {INTEGER_ALIGN, {1, Align(1), Align(1)}}, // i1
183 {INTEGER_ALIGN, {8, Align(1), Align(1)}}, // i8
184 {INTEGER_ALIGN, {16, Align(2), Align(2)}}, // i16
185 {INTEGER_ALIGN, {32, Align(4), Align(4)}}, // i32
186 {INTEGER_ALIGN, {64, Align(4), Align(8)}}, // i64
187 {FLOAT_ALIGN, {16, Align(2), Align(2)}}, // half, bfloat
188 {FLOAT_ALIGN, {32, Align(4), Align(4)}}, // float
189 {FLOAT_ALIGN, {64, Align(8), Align(8)}}, // double
190 {FLOAT_ALIGN, {128, Align(16), Align(16)}}, // ppcf128, quad, ...
191 {VECTOR_ALIGN, {64, Align(8), Align(8)}}, // v2i32, v1i64, ...
192 {VECTOR_ALIGN, {128, Align(16), Align(16)}}, // v16i8, v8i16, v4i32, ...
193};
194
196 clear();
197
198 LayoutMap = nullptr;
199 BigEndian = false;
200 AllocaAddrSpace = 0;
201 StackNaturalAlign.reset();
202 ProgramAddrSpace = 0;
203 DefaultGlobalsAddrSpace = 0;
204 FunctionPtrAlign.reset();
205 TheFunctionPtrAlignType = FunctionPtrAlignType::Independent;
206 ManglingMode = MM_None;
207 NonIntegralAddressSpaces.clear();
208 StructAlignment = LayoutAlignElem::get(Align(1), Align(8), 0);
209
210 // Default alignments
211 for (const auto &[Kind, Layout] : DefaultAlignments) {
212 if (Error Err = setAlignment(Kind, Layout.ABIAlign, Layout.PrefAlign,
213 Layout.TypeBitWidth))
214 return report_fatal_error(std::move(Err));
215 }
216 if (Error Err = setPointerAlignmentInBits(0, Align(8), Align(8), 64, 64))
217 return report_fatal_error(std::move(Err));
218
219 if (Error Err = parseSpecifier(Desc))
220 return report_fatal_error(std::move(Err));
221}
222
224 DataLayout Layout("");
225 if (Error Err = Layout.parseSpecifier(LayoutDescription))
226 return std::move(Err);
227 return Layout;
228}
229
230static Error reportError(const Twine &Message) {
231 return createStringError(inconvertibleErrorCode(), Message);
232}
233
234/// Checked version of split, to ensure mandatory subparts.
235static Error split(StringRef Str, char Separator,
236 std::pair<StringRef, StringRef> &Split) {
237 assert(!Str.empty() && "parse error, string can't be empty here");
238 Split = Str.split(Separator);
239 if (Split.second.empty() && Split.first != Str)
240 return reportError("Trailing separator in datalayout string");
241 if (!Split.second.empty() && Split.first.empty())
242 return reportError("Expected token before separator in datalayout string");
243 return Error::success();
244}
245
246/// Get an unsigned integer, including error checks.
247template <typename IntTy> static Error getInt(StringRef R, IntTy &Result) {
248 bool error = R.getAsInteger(10, Result); (void)error;
249 if (error)
250 return reportError("not a number, or does not fit in an unsigned int");
251 return Error::success();
252}
253
254/// Get an unsigned integer representing the number of bits and convert it into
255/// bytes. Error out of not a byte width multiple.
256template <typename IntTy>
257static Error getIntInBytes(StringRef R, IntTy &Result) {
258 if (Error Err = getInt<IntTy>(R, Result))
259 return Err;
260 if (Result % 8)
261 return reportError("number of bits must be a byte width multiple");
262 Result /= 8;
263 return Error::success();
264}
265
266static Error getAddrSpace(StringRef R, unsigned &AddrSpace) {
267 if (Error Err = getInt(R, AddrSpace))
268 return Err;
269 if (!isUInt<24>(AddrSpace))
270 return reportError("Invalid address space, must be a 24-bit integer");
271 return Error::success();
272}
273
274Error DataLayout::parseSpecifier(StringRef Desc) {
275 StringRepresentation = std::string(Desc);
276 while (!Desc.empty()) {
277 // Split at '-'.
278 std::pair<StringRef, StringRef> Split;
279 if (Error Err = ::split(Desc, '-', Split))
280 return Err;
281 Desc = Split.second;
282
283 // Split at ':'.
284 if (Error Err = ::split(Split.first, ':', Split))
285 return Err;
286
287 // Aliases used below.
288 StringRef &Tok = Split.first; // Current token.
289 StringRef &Rest = Split.second; // The rest of the string.
290
291 if (Tok == "ni") {
292 do {
293 if (Error Err = ::split(Rest, ':', Split))
294 return Err;
295 Rest = Split.second;
296 unsigned AS;
297 if (Error Err = getInt(Split.first, AS))
298 return Err;
299 if (AS == 0)
300 return reportError("Address space 0 can never be non-integral");
301 NonIntegralAddressSpaces.push_back(AS);
302 } while (!Rest.empty());
303
304 continue;
305 }
306
307 char Specifier = Tok.front();
308 Tok = Tok.substr(1);
309
310 switch (Specifier) {
311 case 's':
312 // Deprecated, but ignoring here to preserve loading older textual llvm
313 // ASM file
314 break;
315 case 'E':
316 BigEndian = true;
317 break;
318 case 'e':
319 BigEndian = false;
320 break;
321 case 'p': {
322 // Address space.
323 unsigned AddrSpace = 0;
324 if (!Tok.empty())
325 if (Error Err = getInt(Tok, AddrSpace))
326 return Err;
327 if (!isUInt<24>(AddrSpace))
328 return reportError("Invalid address space, must be a 24-bit integer");
329
330 // Size.
331 if (Rest.empty())
332 return reportError(
333 "Missing size specification for pointer in datalayout string");
334 if (Error Err = ::split(Rest, ':', Split))
335 return Err;
336 unsigned PointerMemSize;
337 if (Error Err = getInt(Tok, PointerMemSize))
338 return Err;
339 if (!PointerMemSize)
340 return reportError("Invalid pointer size of 0 bytes");
341
342 // ABI alignment.
343 if (Rest.empty())
344 return reportError(
345 "Missing alignment specification for pointer in datalayout string");
346 if (Error Err = ::split(Rest, ':', Split))
347 return Err;
348 unsigned PointerABIAlign;
349 if (Error Err = getIntInBytes(Tok, PointerABIAlign))
350 return Err;
351 if (!isPowerOf2_64(PointerABIAlign))
352 return reportError("Pointer ABI alignment must be a power of 2");
353
354 // Size of index used in GEP for address calculation.
355 // The parameter is optional. By default it is equal to size of pointer.
356 unsigned IndexSize = PointerMemSize;
357
358 // Preferred alignment.
359 unsigned PointerPrefAlign = PointerABIAlign;
360 if (!Rest.empty()) {
361 if (Error Err = ::split(Rest, ':', Split))
362 return Err;
363 if (Error Err = getIntInBytes(Tok, PointerPrefAlign))
364 return Err;
365 if (!isPowerOf2_64(PointerPrefAlign))
366 return reportError(
367 "Pointer preferred alignment must be a power of 2");
368
369 // Now read the index. It is the second optional parameter here.
370 if (!Rest.empty()) {
371 if (Error Err = ::split(Rest, ':', Split))
372 return Err;
373 if (Error Err = getInt(Tok, IndexSize))
374 return Err;
375 if (!IndexSize)
376 return reportError("Invalid index size of 0 bytes");
377 }
378 }
379 if (Error Err = setPointerAlignmentInBits(
380 AddrSpace, assumeAligned(PointerABIAlign),
381 assumeAligned(PointerPrefAlign), PointerMemSize, IndexSize))
382 return Err;
383 break;
384 }
385 case 'i':
386 case 'v':
387 case 'f':
388 case 'a': {
389 AlignTypeEnum AlignType;
390 switch (Specifier) {
391 default: llvm_unreachable("Unexpected specifier!");
392 case 'i': AlignType = INTEGER_ALIGN; break;
393 case 'v': AlignType = VECTOR_ALIGN; break;
394 case 'f': AlignType = FLOAT_ALIGN; break;
395 case 'a': AlignType = AGGREGATE_ALIGN; break;
396 }
397
398 // Bit size.
399 unsigned Size = 0;
400 if (!Tok.empty())
401 if (Error Err = getInt(Tok, Size))
402 return Err;
403
404 if (AlignType == AGGREGATE_ALIGN && Size != 0)
405 return reportError(
406 "Sized aggregate specification in datalayout string");
407
408 // ABI alignment.
409 if (Rest.empty())
410 return reportError(
411 "Missing alignment specification in datalayout string");
412 if (Error Err = ::split(Rest, ':', Split))
413 return Err;
414 unsigned ABIAlign;
415 if (Error Err = getIntInBytes(Tok, ABIAlign))
416 return Err;
417 if (AlignType != AGGREGATE_ALIGN && !ABIAlign)
418 return reportError(
419 "ABI alignment specification must be >0 for non-aggregate types");
420
421 if (!isUInt<16>(ABIAlign))
422 return reportError("Invalid ABI alignment, must be a 16bit integer");
423 if (ABIAlign != 0 && !isPowerOf2_64(ABIAlign))
424 return reportError("Invalid ABI alignment, must be a power of 2");
425 if (AlignType == INTEGER_ALIGN && Size == 8 && ABIAlign != 1)
426 return reportError(
427 "Invalid ABI alignment, i8 must be naturally aligned");
428
429 // Preferred alignment.
430 unsigned PrefAlign = ABIAlign;
431 if (!Rest.empty()) {
432 if (Error Err = ::split(Rest, ':', Split))
433 return Err;
434 if (Error Err = getIntInBytes(Tok, PrefAlign))
435 return Err;
436 }
437
438 if (!isUInt<16>(PrefAlign))
439 return reportError(
440 "Invalid preferred alignment, must be a 16bit integer");
441 if (PrefAlign != 0 && !isPowerOf2_64(PrefAlign))
442 return reportError("Invalid preferred alignment, must be a power of 2");
443
444 if (Error Err = setAlignment(AlignType, assumeAligned(ABIAlign),
445 assumeAligned(PrefAlign), Size))
446 return Err;
447
448 break;
449 }
450 case 'n': // Native integer types.
451 while (true) {
452 unsigned Width;
453 if (Error Err = getInt(Tok, Width))
454 return Err;
455 if (Width == 0)
456 return reportError(
457 "Zero width native integer type in datalayout string");
458 LegalIntWidths.push_back(Width);
459 if (Rest.empty())
460 break;
461 if (Error Err = ::split(Rest, ':', Split))
462 return Err;
463 }
464 break;
465 case 'S': { // Stack natural alignment.
466 uint64_t Alignment;
467 if (Error Err = getIntInBytes(Tok, Alignment))
468 return Err;
469 if (Alignment != 0 && !llvm::isPowerOf2_64(Alignment))
470 return reportError("Alignment is neither 0 nor a power of 2");
471 StackNaturalAlign = MaybeAlign(Alignment);
472 break;
473 }
474 case 'F': {
475 switch (Tok.front()) {
476 case 'i':
477 TheFunctionPtrAlignType = FunctionPtrAlignType::Independent;
478 break;
479 case 'n':
480 TheFunctionPtrAlignType = FunctionPtrAlignType::MultipleOfFunctionAlign;
481 break;
482 default:
483 return reportError("Unknown function pointer alignment type in "
484 "datalayout string");
485 }
486 Tok = Tok.substr(1);
487 uint64_t Alignment;
488 if (Error Err = getIntInBytes(Tok, Alignment))
489 return Err;
490 if (Alignment != 0 && !llvm::isPowerOf2_64(Alignment))
491 return reportError("Alignment is neither 0 nor a power of 2");
492 FunctionPtrAlign = MaybeAlign(Alignment);
493 break;
494 }
495 case 'P': { // Function address space.
496 if (Error Err = getAddrSpace(Tok, ProgramAddrSpace))
497 return Err;
498 break;
499 }
500 case 'A': { // Default stack/alloca address space.
501 if (Error Err = getAddrSpace(Tok, AllocaAddrSpace))
502 return Err;
503 break;
504 }
505 case 'G': { // Default address space for global variables.
506 if (Error Err = getAddrSpace(Tok, DefaultGlobalsAddrSpace))
507 return Err;
508 break;
509 }
510 case 'm':
511 if (!Tok.empty())
512 return reportError("Unexpected trailing characters after mangling "
513 "specifier in datalayout string");
514 if (Rest.empty())
515 return reportError("Expected mangling specifier in datalayout string");
516 if (Rest.size() > 1)
517 return reportError("Unknown mangling specifier in datalayout string");
518 switch(Rest[0]) {
519 default:
520 return reportError("Unknown mangling in datalayout string");
521 case 'e':
522 ManglingMode = MM_ELF;
523 break;
524 case 'l':
525 ManglingMode = MM_GOFF;
526 break;
527 case 'o':
528 ManglingMode = MM_MachO;
529 break;
530 case 'm':
531 ManglingMode = MM_Mips;
532 break;
533 case 'w':
534 ManglingMode = MM_WinCOFF;
535 break;
536 case 'x':
537 ManglingMode = MM_WinCOFFX86;
538 break;
539 case 'a':
540 ManglingMode = MM_XCOFF;
541 break;
542 }
543 break;
544 default:
545 return reportError("Unknown specifier in datalayout string");
546 break;
547 }
548 }
549
550 return Error::success();
551}
552
554 init(M);
555}
556
557void DataLayout::init(const Module *M) { *this = M->getDataLayout(); }
558
560 bool Ret = BigEndian == Other.BigEndian &&
561 AllocaAddrSpace == Other.AllocaAddrSpace &&
562 StackNaturalAlign == Other.StackNaturalAlign &&
563 ProgramAddrSpace == Other.ProgramAddrSpace &&
564 DefaultGlobalsAddrSpace == Other.DefaultGlobalsAddrSpace &&
565 FunctionPtrAlign == Other.FunctionPtrAlign &&
566 TheFunctionPtrAlignType == Other.TheFunctionPtrAlignType &&
567 ManglingMode == Other.ManglingMode &&
568 LegalIntWidths == Other.LegalIntWidths &&
569 IntAlignments == Other.IntAlignments &&
570 FloatAlignments == Other.FloatAlignments &&
571 VectorAlignments == Other.VectorAlignments &&
572 StructAlignment == Other.StructAlignment &&
573 Pointers == Other.Pointers;
574 // Note: getStringRepresentation() might differs, it is not canonicalized
575 return Ret;
576}
577
581 return partition_point(Alignments, [BitWidth](const LayoutAlignElem &E) {
582 return E.TypeBitWidth < BitWidth;
583 });
584}
585
586Error DataLayout::setAlignment(AlignTypeEnum AlignType, Align ABIAlign,
587 Align PrefAlign, uint32_t BitWidth) {
588 // AlignmentsTy::ABIAlign and AlignmentsTy::PrefAlign were once stored as
589 // uint16_t, it is unclear if there are requirements for alignment to be less
590 // than 2^16 other than storage. In the meantime we leave the restriction as
591 // an assert. See D67400 for context.
592 assert(Log2(ABIAlign) < 16 && Log2(PrefAlign) < 16 && "Alignment too big");
593 if (!isUInt<24>(BitWidth))
594 return reportError("Invalid bit width, must be a 24-bit integer");
595 if (PrefAlign < ABIAlign)
596 return reportError(
597 "Preferred alignment cannot be less than the ABI alignment");
598
600 switch (AlignType) {
601 case AGGREGATE_ALIGN:
602 StructAlignment.ABIAlign = ABIAlign;
603 StructAlignment.PrefAlign = PrefAlign;
604 return Error::success();
605 case INTEGER_ALIGN:
606 Alignments = &IntAlignments;
607 break;
608 case FLOAT_ALIGN:
609 Alignments = &FloatAlignments;
610 break;
611 case VECTOR_ALIGN:
612 Alignments = &VectorAlignments;
613 break;
614 }
615
616 auto I = partition_point(*Alignments, [BitWidth](const LayoutAlignElem &E) {
617 return E.TypeBitWidth < BitWidth;
618 });
619 if (I != Alignments->end() && I->TypeBitWidth == BitWidth) {
620 // Update the abi, preferred alignments.
621 I->ABIAlign = ABIAlign;
622 I->PrefAlign = PrefAlign;
623 } else {
624 // Insert before I to keep the vector sorted.
625 Alignments->insert(I, LayoutAlignElem::get(ABIAlign, PrefAlign, BitWidth));
626 }
627 return Error::success();
628}
629
630const PointerAlignElem &
631DataLayout::getPointerAlignElem(uint32_t AddressSpace) const {
632 if (AddressSpace != 0) {
633 auto I = lower_bound(Pointers, AddressSpace,
635 return A.AddressSpace < AddressSpace;
636 });
637 if (I != Pointers.end() && I->AddressSpace == AddressSpace)
638 return *I;
639 }
640
641 assert(Pointers[0].AddressSpace == 0);
642 return Pointers[0];
643}
644
645Error DataLayout::setPointerAlignmentInBits(uint32_t AddrSpace, Align ABIAlign,
646 Align PrefAlign,
647 uint32_t TypeBitWidth,
648 uint32_t IndexBitWidth) {
649 if (PrefAlign < ABIAlign)
650 return reportError(
651 "Preferred alignment cannot be less than the ABI alignment");
652 if (IndexBitWidth > TypeBitWidth)
653 return reportError("Index width cannot be larger than pointer width");
654
655 auto I = lower_bound(Pointers, AddrSpace,
657 return A.AddressSpace < AddressSpace;
658 });
659 if (I == Pointers.end() || I->AddressSpace != AddrSpace) {
660 Pointers.insert(I,
661 PointerAlignElem::getInBits(AddrSpace, ABIAlign, PrefAlign,
662 TypeBitWidth, IndexBitWidth));
663 } else {
664 I->ABIAlign = ABIAlign;
665 I->PrefAlign = PrefAlign;
666 I->TypeBitWidth = TypeBitWidth;
667 I->IndexBitWidth = IndexBitWidth;
668 }
669 return Error::success();
670}
671
672Align DataLayout::getIntegerAlignment(uint32_t BitWidth,
673 bool abi_or_pref) const {
674 auto I = findAlignmentLowerBound(IntAlignments, BitWidth);
675 // If we don't have an exact match, use alignment of next larger integer
676 // type. If there is none, use alignment of largest integer type by going
677 // back one element.
678 if (I == IntAlignments.end())
679 --I;
680 return abi_or_pref ? I->ABIAlign : I->PrefAlign;
681}
682
683namespace {
684
685class StructLayoutMap {
686 using LayoutInfoTy = DenseMap<StructType*, StructLayout*>;
687 LayoutInfoTy LayoutInfo;
688
689public:
690 ~StructLayoutMap() {
691 // Remove any layouts.
692 for (const auto &I : LayoutInfo) {
693 StructLayout *Value = I.second;
694 Value->~StructLayout();
695 free(Value);
696 }
697 }
698
699 StructLayout *&operator[](StructType *STy) {
700 return LayoutInfo[STy];
701 }
702};
703
704} // end anonymous namespace
705
706void DataLayout::clear() {
707 LegalIntWidths.clear();
708 IntAlignments.clear();
709 FloatAlignments.clear();
710 VectorAlignments.clear();
711 Pointers.clear();
712 delete static_cast<StructLayoutMap *>(LayoutMap);
713 LayoutMap = nullptr;
714}
715
717 clear();
718}
719
721 if (!LayoutMap)
722 LayoutMap = new StructLayoutMap();
723
724 StructLayoutMap *STM = static_cast<StructLayoutMap*>(LayoutMap);
725 StructLayout *&SL = (*STM)[Ty];
726 if (SL) return SL;
727
728 // Otherwise, create the struct layout. Because it is variable length, we
729 // malloc it, then use placement new.
731 StructLayout::totalSizeToAlloc<TypeSize>(Ty->getNumElements()));
732
733 // Set SL before calling StructLayout's ctor. The ctor could cause other
734 // entries to be added to TheMap, invalidating our reference.
735 SL = L;
736
737 new (L) StructLayout(Ty, *this);
738
739 return L;
740}
741
743 return getPointerAlignElem(AS).ABIAlign;
744}
745
747 return getPointerAlignElem(AS).PrefAlign;
748}
749
750unsigned DataLayout::getPointerSize(unsigned AS) const {
751 return divideCeil(getPointerAlignElem(AS).TypeBitWidth, 8);
752}
753
755 unsigned MaxIndexSize = 0;
756 for (auto &P : Pointers)
757 MaxIndexSize =
758 std::max(MaxIndexSize, (unsigned)divideCeil(P.TypeBitWidth, 8));
759
760 return MaxIndexSize;
761}
762
765 "This should only be called with a pointer or pointer vector type");
766 Ty = Ty->getScalarType();
767 return getPointerSizeInBits(cast<PointerType>(Ty)->getAddressSpace());
768}
769
770unsigned DataLayout::getIndexSize(unsigned AS) const {
771 return divideCeil(getPointerAlignElem(AS).IndexBitWidth, 8);
772}
773
776 "This should only be called with a pointer or pointer vector type");
777 Ty = Ty->getScalarType();
778 return getIndexSizeInBits(cast<PointerType>(Ty)->getAddressSpace());
779}
780
781/*!
782 \param abi_or_pref Flag that determines which alignment is returned. true
783 returns the ABI alignment, false returns the preferred alignment.
784 \param Ty The underlying type for which alignment is determined.
785
786 Get the ABI (\a abi_or_pref == true) or preferred alignment (\a abi_or_pref
787 == false) for the requested type \a Ty.
788 */
789Align DataLayout::getAlignment(Type *Ty, bool abi_or_pref) const {
790 assert(Ty->isSized() && "Cannot getTypeInfo() on a type that is unsized!");
791 switch (Ty->getTypeID()) {
792 // Early escape for the non-numeric types.
793 case Type::LabelTyID:
794 return abi_or_pref ? getPointerABIAlignment(0) : getPointerPrefAlignment(0);
795 case Type::PointerTyID: {
796 unsigned AS = cast<PointerType>(Ty)->getAddressSpace();
797 return abi_or_pref ? getPointerABIAlignment(AS)
799 }
800 case Type::ArrayTyID:
801 return getAlignment(cast<ArrayType>(Ty)->getElementType(), abi_or_pref);
802
803 case Type::StructTyID: {
804 // Packed structure types always have an ABI alignment of one.
805 if (cast<StructType>(Ty)->isPacked() && abi_or_pref)
806 return Align(1);
807
808 // Get the layout annotation... which is lazily created on demand.
809 const StructLayout *Layout = getStructLayout(cast<StructType>(Ty));
810 const Align Align =
811 abi_or_pref ? StructAlignment.ABIAlign : StructAlignment.PrefAlign;
812 return std::max(Align, Layout->getAlignment());
813 }
815 return getIntegerAlignment(Ty->getIntegerBitWidth(), abi_or_pref);
816 case Type::HalfTyID:
817 case Type::BFloatTyID:
818 case Type::FloatTyID:
819 case Type::DoubleTyID:
820 // PPC_FP128TyID and FP128TyID have different data contents, but the
821 // same size and alignment, so they look the same here.
823 case Type::FP128TyID:
824 case Type::X86_FP80TyID: {
826 auto I = findAlignmentLowerBound(FloatAlignments, BitWidth);
827 if (I != FloatAlignments.end() && I->TypeBitWidth == BitWidth)
828 return abi_or_pref ? I->ABIAlign : I->PrefAlign;
829
830 // If we still couldn't find a reasonable default alignment, fall back
831 // to a simple heuristic that the alignment is the first power of two
832 // greater-or-equal to the store size of the type. This is a reasonable
833 // approximation of reality, and if the user wanted something less
834 // less conservative, they should have specified it explicitly in the data
835 // layout.
836 return Align(PowerOf2Ceil(BitWidth / 8));
837 }
841 auto I = findAlignmentLowerBound(VectorAlignments, BitWidth);
842 if (I != VectorAlignments.end() && I->TypeBitWidth == BitWidth)
843 return abi_or_pref ? I->ABIAlign : I->PrefAlign;
844
845 // By default, use natural alignment for vector types. This is consistent
846 // with what clang and llvm-gcc do.
847 //
848 // We're only calculating a natural alignment, so it doesn't have to be
849 // based on the full size for scalable vectors. Using the minimum element
850 // count should be enough here.
851 return Align(PowerOf2Ceil(getTypeStoreSize(Ty).getKnownMinValue()));
852 }
854 return Align(64);
855 case Type::TargetExtTyID: {
856 Type *LayoutTy = cast<TargetExtType>(Ty)->getLayoutType();
857 return getAlignment(LayoutTy, abi_or_pref);
858 }
859 default:
860 llvm_unreachable("Bad type for getAlignment!!!");
861 }
862}
863
865 return getAlignment(Ty, true);
866}
867
869 return getAlignment(Ty, false);
870}
871
873 unsigned AddressSpace) const {
875}
876
879 "Expected a pointer or pointer vector type.");
880 unsigned NumBits = getPointerTypeSizeInBits(Ty);
881 IntegerType *IntTy = IntegerType::get(Ty->getContext(), NumBits);
882 if (VectorType *VecTy = dyn_cast<VectorType>(Ty))
883 return VectorType::get(IntTy, VecTy);
884 return IntTy;
885}
886
888 for (unsigned LegalIntWidth : LegalIntWidths)
889 if (Width <= LegalIntWidth)
890 return Type::getIntNTy(C, LegalIntWidth);
891 return nullptr;
892}
893
895 auto Max = llvm::max_element(LegalIntWidths);
896 return Max != LegalIntWidths.end() ? *Max : 0;
897}
898
900 unsigned AddressSpace) const {
902}
903
906 "Expected a pointer or pointer vector type.");
907 unsigned NumBits = getIndexTypeSizeInBits(Ty);
908 IntegerType *IntTy = IntegerType::get(Ty->getContext(), NumBits);
909 if (VectorType *VecTy = dyn_cast<VectorType>(Ty))
910 return VectorType::get(IntTy, VecTy);
911 return IntTy;
912}
913
915 ArrayRef<Value *> Indices) const {
916 int64_t Result = 0;
917
919 GTI = gep_type_begin(ElemTy, Indices),
920 GTE = gep_type_end(ElemTy, Indices);
921 for (; GTI != GTE; ++GTI) {
922 Value *Idx = GTI.getOperand();
923 if (StructType *STy = GTI.getStructTypeOrNull()) {
924 assert(Idx->getType()->isIntegerTy(32) && "Illegal struct idx");
925 unsigned FieldNo = cast<ConstantInt>(Idx)->getZExtValue();
926
927 // Get structure layout information...
928 const StructLayout *Layout = getStructLayout(STy);
929
930 // Add in the offset, as calculated by the structure layout info...
931 Result += Layout->getElementOffset(FieldNo);
932 } else {
933 if (int64_t ArrayIdx = cast<ConstantInt>(Idx)->getSExtValue())
934 Result += ArrayIdx * GTI.getSequentialElementStride(*this);
935 }
936 }
937
938 return Result;
939}
940
942 // Skip over scalable or zero size elements. Also skip element sizes larger
943 // than the positive index space, because the arithmetic below may not be
944 // correct in that case.
945 unsigned BitWidth = Offset.getBitWidth();
946 if (ElemSize.isScalable() || ElemSize == 0 ||
947 !isUIntN(BitWidth - 1, ElemSize)) {
948 return APInt::getZero(BitWidth);
949 }
950
951 APInt Index = Offset.sdiv(ElemSize);
952 Offset -= Index * ElemSize;
953 if (Offset.isNegative()) {
954 // Prefer a positive remaining offset to allow struct indexing.
955 --Index;
956 Offset += ElemSize;
957 assert(Offset.isNonNegative() && "Remaining offset shouldn't be negative");
958 }
959 return Index;
960}
961
962std::optional<APInt> DataLayout::getGEPIndexForOffset(Type *&ElemTy,
963 APInt &Offset) const {
964 if (auto *ArrTy = dyn_cast<ArrayType>(ElemTy)) {
965 ElemTy = ArrTy->getElementType();
966 return getElementIndex(getTypeAllocSize(ElemTy), Offset);
967 }
968
969 if (isa<VectorType>(ElemTy)) {
970 // Vector GEPs are partially broken (e.g. for overaligned element types),
971 // and may be forbidden in the future, so avoid generating GEPs into
972 // vectors. See https://discourse.llvm.org/t/67497
973 return std::nullopt;
974 }
975
976 if (auto *STy = dyn_cast<StructType>(ElemTy)) {
977 const StructLayout *SL = getStructLayout(STy);
978 uint64_t IntOffset = Offset.getZExtValue();
979 if (IntOffset >= SL->getSizeInBytes())
980 return std::nullopt;
981
982 unsigned Index = SL->getElementContainingOffset(IntOffset);
984 ElemTy = STy->getElementType(Index);
985 return APInt(32, Index);
986 }
987
988 // Non-aggregate type.
989 return std::nullopt;
990}
991
993 APInt &Offset) const {
994 assert(ElemTy->isSized() && "Element type must be sized");
995 SmallVector<APInt> Indices;
997 while (Offset != 0) {
998 std::optional<APInt> Index = getGEPIndexForOffset(ElemTy, Offset);
999 if (!Index)
1000 break;
1001 Indices.push_back(*Index);
1002 }
1003
1004 return Indices;
1005}
1006
1007/// getPreferredAlign - Return the preferred alignment of the specified global.
1008/// This includes an explicitly requested alignment (if the global has one).
1010 MaybeAlign GVAlignment = GV->getAlign();
1011 // If a section is specified, always precisely honor explicit alignment,
1012 // so we don't insert padding into a section we don't control.
1013 if (GVAlignment && GV->hasSection())
1014 return *GVAlignment;
1015
1016 // If no explicit alignment is specified, compute the alignment based on
1017 // the IR type. If an alignment is specified, increase it to match the ABI
1018 // alignment of the IR type.
1019 //
1020 // FIXME: Not sure it makes sense to use the alignment of the type if
1021 // there's already an explicit alignment specification.
1022 Type *ElemType = GV->getValueType();
1023 Align Alignment = getPrefTypeAlign(ElemType);
1024 if (GVAlignment) {
1025 if (*GVAlignment >= Alignment)
1026 Alignment = *GVAlignment;
1027 else
1028 Alignment = std::max(*GVAlignment, getABITypeAlign(ElemType));
1029 }
1030
1031 // If no explicit alignment is specified, and the global is large, increase
1032 // the alignment to 16.
1033 // FIXME: Why 16, specifically?
1034 if (GV->hasInitializer() && !GVAlignment) {
1035 if (Alignment < Align(16)) {
1036 // If the global is not external, see if it is large. If so, give it a
1037 // larger alignment.
1038 if (getTypeSizeInBits(ElemType) > 128)
1039 Alignment = Align(16); // 16-byte alignment.
1040 }
1041 }
1042 return Alignment;
1043}
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static Error reportError(StringRef Message)
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
This file contains the declarations for the subclasses of Constant, which represent the different fla...
static Error getInt(StringRef R, IntTy &Result)
Get an unsigned integer, including error checks.
Definition: DataLayout.cpp:247
static APInt getElementIndex(TypeSize ElemSize, APInt &Offset)
Definition: DataLayout.cpp:941
static Error getIntInBytes(StringRef R, IntTy &Result)
Get an unsigned integer representing the number of bits and convert it into bytes.
Definition: DataLayout.cpp:257
static SmallVectorImpl< LayoutAlignElem >::const_iterator findAlignmentLowerBound(const SmallVectorImpl< LayoutAlignElem > &Alignments, uint32_t BitWidth)
Definition: DataLayout.cpp:579
static Error getAddrSpace(StringRef R, unsigned &AddrSpace)
Definition: DataLayout.cpp:266
static Error split(StringRef Str, char Separator, std::pair< StringRef, StringRef > &Split)
Checked version of split, to ensure mandatory subparts.
Definition: DataLayout.cpp:235
static const std::pair< AlignTypeEnum, LayoutAlignElem > DefaultAlignments[]
Definition: DataLayout.cpp:181
Returns the sub type a function will return at a given Idx Should correspond to the result type of an ExtractValue instruction executed with just that one unsigned Idx
This file defines the DenseMap class.
uint64_t Size
#define I(x, y, z)
Definition: MD5.cpp:58
This file defines counterparts of C library allocation functions defined in the namespace 'std'.
Module.h This file contains the declarations for the Module class.
#define P(N)
assert(ImpDefSCC.getReg()==AMDGPU::SCC &&ImpDefSCC.isDef())
#define error(X)
Value * RHS
Value * LHS
Class for arbitrary precision integers.
Definition: APInt.h:78
static APInt getZero(unsigned numBits)
Get the '0' value for the specified bit-width.
Definition: APInt.h:180
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition: ArrayRef.h:41
iterator end() const
Definition: ArrayRef.h:154
iterator begin() const
Definition: ArrayRef.h:153
A parsed version of the target data layout string in and methods for querying it.
Definition: DataLayout.h:110
static const char * getManglingComponent(const Triple &T)
Definition: DataLayout.cpp:169
unsigned getPointerSizeInBits(unsigned AS=0) const
Layout pointer size, in bits FIXME: The defaults need to be removed once all of the backends/clients ...
Definition: DataLayout.h:410
unsigned getMaxIndexSize() const
Returns the maximum index size over all address spaces.
Definition: DataLayout.cpp:754
@ MultipleOfFunctionAlign
The function pointer alignment is a multiple of the function alignment.
@ Independent
The function pointer alignment is independent of the function alignment.
SmallVector< APInt > getGEPIndicesForOffset(Type *&ElemTy, APInt &Offset) const
Get GEP indices to access Offset inside ElemTy.
Definition: DataLayout.cpp:992
unsigned getLargestLegalIntTypeSizeInBits() const
Returns the size of largest legal integer type size, or 0 if none are set.
Definition: DataLayout.cpp:894
void init(const Module *M)
Definition: DataLayout.cpp:557
unsigned getIndexSize(unsigned AS) const
rounded up to a whole number of bytes.
Definition: DataLayout.cpp:770
const StructLayout * getStructLayout(StructType *Ty) const
Returns a StructLayout object, indicating the alignment of the struct, its size, and the offsets of i...
Definition: DataLayout.cpp:720
DataLayout(StringRef LayoutDescription)
Constructs a DataLayout from a specification string. See reset().
Definition: DataLayout.h:193
static Expected< DataLayout > parse(StringRef LayoutDescription)
Parse a data layout string and return the layout.
Definition: DataLayout.cpp:223
IntegerType * getIntPtrType(LLVMContext &C, unsigned AddressSpace=0) const
Returns an integer type with size at least as big as that of a pointer in the given address space.
Definition: DataLayout.cpp:872
Align getABITypeAlign(Type *Ty) const
Returns the minimum ABI-required alignment for the specified type.
Definition: DataLayout.cpp:864
unsigned getIndexTypeSizeInBits(Type *Ty) const
Layout size of the index used in GEP calculation.
Definition: DataLayout.cpp:774
unsigned getPointerTypeSizeInBits(Type *) const
Layout pointer size, in bits, based on the type.
Definition: DataLayout.cpp:763
void reset(StringRef LayoutDescription)
Parse a data layout string (with fallback to default values).
Definition: DataLayout.cpp:195
IntegerType * getIndexType(LLVMContext &C, unsigned AddressSpace) const
Returns the type of a GEP index in AddressSpace.
Definition: DataLayout.cpp:899
TypeSize getTypeAllocSize(Type *Ty) const
Returns the offset in bytes between successive objects of the specified type, including alignment pad...
Definition: DataLayout.h:504
std::optional< APInt > getGEPIndexForOffset(Type *&ElemTy, APInt &Offset) const
Get single GEP index to access Offset inside ElemTy.
Definition: DataLayout.cpp:962
Type * getSmallestLegalIntType(LLVMContext &C, unsigned Width=0) const
Returns the smallest integer type with size at least as big as Width bits.
Definition: DataLayout.cpp:887
Align getPreferredAlign(const GlobalVariable *GV) const
Returns the preferred alignment of the specified global.
unsigned getPointerSize(unsigned AS=0) const
Layout pointer size in bytes, rounded up to a whole number of bytes.
Definition: DataLayout.cpp:750
Align getPointerPrefAlignment(unsigned AS=0) const
Return target's alignment for stack-based pointers FIXME: The defaults need to be removed once all of...
Definition: DataLayout.cpp:746
unsigned getIndexSizeInBits(unsigned AS) const
Size in bits of index used for address calculation in getelementptr.
Definition: DataLayout.h:420
TypeSize getTypeSizeInBits(Type *Ty) const
Size examples:
Definition: DataLayout.h:664
TypeSize getTypeStoreSize(Type *Ty) const
Returns the maximum number of bytes that may be overwritten by storing the specified type.
Definition: DataLayout.h:472
bool operator==(const DataLayout &Other) const
Definition: DataLayout.cpp:559
int64_t getIndexedOffsetInType(Type *ElemTy, ArrayRef< Value * > Indices) const
Returns the offset from the beginning of the type for the specified indices.
Definition: DataLayout.cpp:914
Align getPointerABIAlignment(unsigned AS) const
Layout pointer alignment.
Definition: DataLayout.cpp:742
Align getPrefTypeAlign(Type *Ty) const
Returns the preferred stack/global alignment for the specified type.
Definition: DataLayout.cpp:868
Lightweight error class with error context and mandatory checking.
Definition: Error.h:160
static ErrorSuccess success()
Create a success value.
Definition: Error.h:337
Tagged union holding either a T or a Error.
Definition: Error.h:481
MaybeAlign getAlign() const
Returns the alignment of the given variable or function.
Definition: GlobalObject.h:80
bool hasSection() const
Check if this global has a custom object file section.
Definition: GlobalObject.h:110
Type * getValueType() const
Definition: GlobalValue.h:296
bool hasInitializer() const
Definitions have initializers, declarations don't.
Class to represent integer types.
Definition: DerivedTypes.h:40
static IntegerType * get(LLVMContext &C, unsigned NumBits)
This static method is the primary way of constructing an IntegerType.
Definition: Type.cpp:266
This is an important class for using LLVM in a threaded context.
Definition: LLVMContext.h:67
A Module instance is used to store all the information related to an LLVM module.
Definition: Module.h:65
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
Definition: SmallVector.h:587
typename SuperClass::const_iterator const_iterator
Definition: SmallVector.h:592
iterator insert(iterator I, T &&Elt)
Definition: SmallVector.h:819
void push_back(const T &Elt)
Definition: SmallVector.h:427
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
Definition: SmallVector.h:1210
StringRef - Represent a constant reference to a string, i.e.
Definition: StringRef.h:50
constexpr StringRef substr(size_t Start, size_t N=npos) const
Return a reference to the substring from [Start, Start + N).
Definition: StringRef.h:556
constexpr bool empty() const
empty - Check if the string is empty.
Definition: StringRef.h:134
constexpr size_t size() const
size - Get the string size.
Definition: StringRef.h:137
char front() const
front - Get the first character in the string.
Definition: StringRef.h:140
Used to lazily calculate structure layout information for a target machine, based on the DataLayout s...
Definition: DataLayout.h:614
TypeSize getSizeInBytes() const
Definition: DataLayout.h:621
MutableArrayRef< TypeSize > getMemberOffsets()
Definition: DataLayout.h:635
unsigned getElementContainingOffset(uint64_t FixedOffset) const
Given a valid byte offset into the structure, returns the structure index that contains it.
Definition: DataLayout.cpp:92
TypeSize getElementOffset(unsigned Idx) const
Definition: DataLayout.h:643
Align getAlignment() const
Definition: DataLayout.h:625
Class to represent struct types.
Definition: DerivedTypes.h:216
unsigned getNumElements() const
Random access to the elements.
Definition: DerivedTypes.h:341
Triple - Helper class for working with autoconf configuration names.
Definition: Triple.h:44
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
Definition: Twine.h:81
static constexpr TypeSize getFixed(ScalarTy ExactSize)
Definition: TypeSize.h:345
static constexpr TypeSize getScalable(ScalarTy MinimumSize)
Definition: TypeSize.h:348
The instances of the Type class are immutable: once they are created, they are never changed.
Definition: Type.h:45
unsigned getIntegerBitWidth() const
@ X86_AMXTyID
AMX vectors (8192 bits, X86 specific)
Definition: Type.h:66
@ ArrayTyID
Arrays.
Definition: Type.h:74
@ HalfTyID
16-bit floating point type
Definition: Type.h:56
@ TargetExtTyID
Target extension type.
Definition: Type.h:78
@ ScalableVectorTyID
Scalable SIMD vector type.
Definition: Type.h:76
@ LabelTyID
Labels.
Definition: Type.h:64
@ FloatTyID
32-bit floating point type
Definition: Type.h:58
@ StructTyID
Structures.
Definition: Type.h:73
@ IntegerTyID
Arbitrary bit width integers.
Definition: Type.h:70
@ FixedVectorTyID
Fixed width SIMD vector type.
Definition: Type.h:75
@ BFloatTyID
16-bit floating point type (7-bit significand)
Definition: Type.h:57
@ DoubleTyID
64-bit floating point type
Definition: Type.h:59
@ X86_FP80TyID
80-bit floating point type (X87)
Definition: Type.h:60
@ PPC_FP128TyID
128-bit floating point type (two 64-bits, PowerPC)
Definition: Type.h:62
@ PointerTyID
Pointers.
Definition: Type.h:72
@ FP128TyID
128-bit floating point type (112-bit significand)
Definition: Type.h:61
static IntegerType * getIntNTy(LLVMContext &C, unsigned N)
bool isSized(SmallPtrSetImpl< Type * > *Visited=nullptr) const
Return true if it makes sense to take the size of this type.
Definition: Type.h:298
LLVMContext & getContext() const
Return the LLVMContext in which this type was uniqued.
Definition: Type.h:128
bool isPtrOrPtrVectorTy() const
Return true if this is a pointer type or a vector of pointer types.
Definition: Type.h:258
bool isScalableTy() const
Return true if this is a type whose size is a known multiple of vscale.
TypeID getTypeID() const
Return the type id for the type.
Definition: Type.h:136
Type * getScalarType() const
If this is a vector type, return the element type, otherwise return 'this'.
Definition: Type.h:343
LLVM Value Representation.
Definition: Value.h:74
Base class of all SIMD vector types.
Definition: DerivedTypes.h:403
static VectorType * get(Type *ElementType, ElementCount EC)
This static method is the primary way to construct an VectorType.
Definition: Type.cpp:664
constexpr ScalarTy getFixedValue() const
Definition: TypeSize.h:202
static constexpr bool isKnownLE(const FixedOrScalableQuantity &LHS, const FixedOrScalableQuantity &RHS)
Definition: TypeSize.h:232
constexpr bool isScalable() const
Returns whether the quantity is scaled by a runtime quantity (vscale).
Definition: TypeSize.h:171
constexpr ScalarTy getKnownMinValue() const
Returns the minimum value this quantity can represent.
Definition: TypeSize.h:168
static constexpr bool isKnownGT(const FixedOrScalableQuantity &LHS, const FixedOrScalableQuantity &RHS)
Definition: TypeSize.h:225
TypeSize getSequentialElementStride(const DataLayout &DL) const
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
@ C
The default llvm calling convention, compatible with C.
Definition: CallingConv.h:34
constexpr double e
Definition: MathExtras.h:47
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
@ Offset
Definition: DWP.cpp:480
bool isUIntN(unsigned N, uint64_t x)
Checks if an unsigned integer fits into the given (dynamic) bit width.
Definition: MathExtras.h:255
bool isAligned(Align Lhs, uint64_t SizeInBytes)
Checks that SizeInBytes is a multiple of the alignment.
Definition: Alignment.h:145
std::error_code inconvertibleErrorCode()
The value returned by this function can be returned from convertToErrorCode for Error values where no...
Definition: Error.cpp:98
AddressSpace
Definition: NVPTXBaseInfo.h:21
auto partition_point(R &&Range, Predicate P)
Binary search for the first iterator in a range where a predicate is false.
Definition: STLExtras.h:2008
constexpr bool isPowerOf2_64(uint64_t Value)
Return true if the argument is a power of two > 0 (64 bit edition.)
Definition: MathExtras.h:296
gep_type_iterator gep_type_end(const User *GEP)
Error createStringError(std::error_code EC, char const *Fmt, const Ts &... Vals)
Create formatted StringError object.
Definition: Error.h:1286
uint64_t PowerOf2Ceil(uint64_t A)
Returns the power of two which is greater than or equal to the given value.
Definition: MathExtras.h:394
void report_fatal_error(Error Err, bool gen_crash_diag=true)
Report a serious error, calling any installed error handler.
Definition: Error.cpp:167
LLVM_ATTRIBUTE_RETURNS_NONNULL void * safe_malloc(size_t Sz)
Definition: MemAlloc.h:25
constexpr T divideCeil(U Numerator, V Denominator)
Returns the integer ceil(Numerator / Denominator).
Definition: MathExtras.h:403
@ Other
Any other memory.
auto lower_bound(R &&Range, T &&Value)
Provide wrappers to std::lower_bound which take ranges instead of having to pass begin/end explicitly...
Definition: STLExtras.h:1954
uint64_t alignTo(uint64_t Size, Align A)
Returns a multiple of A needed to store Size bytes.
Definition: Alignment.h:155
auto max_element(R &&Range)
Definition: STLExtras.h:1986
constexpr unsigned BitWidth
Definition: BitmaskEnum.h:191
gep_type_iterator gep_type_begin(const User *GEP)
Align assumeAligned(uint64_t Value)
Treats the value 0 as a 1, so Align is always at least 1.
Definition: Alignment.h:111
unsigned Log2(Align A)
Returns the log2 of the alignment.
Definition: Alignment.h:208
AlignTypeEnum
Enum used to categorize the alignment types stored by LayoutAlignElem.
Definition: DataLayout.h:54
@ FLOAT_ALIGN
Definition: DataLayout.h:57
@ VECTOR_ALIGN
Definition: DataLayout.h:56
@ INTEGER_ALIGN
Definition: DataLayout.h:55
@ AGGREGATE_ALIGN
Definition: DataLayout.h:58
This struct is a compact representation of a valid (non-zero power of two) alignment.
Definition: Alignment.h:39
Description of the encoding of one expression Op.
Layout alignment element.
Definition: DataLayout.h:72
static LayoutAlignElem get(Align ABIAlign, Align PrefAlign, uint32_t BitWidth)
Definition: DataLayout.cpp:125
bool operator==(const LayoutAlignElem &rhs) const
Definition: DataLayout.cpp:135
This struct is a compact representation of a valid (power of two) or undefined (0) alignment.
Definition: Alignment.h:117
Layout pointer alignment element.
Definition: DataLayout.h:89
bool operator==(const PointerAlignElem &rhs) const
Definition: DataLayout.cpp:159
static PointerAlignElem getInBits(uint32_t AddressSpace, Align ABIAlign, Align PrefAlign, uint32_t TypeBitWidth, uint32_t IndexBitWidth)
Initializer.
Definition: DataLayout.cpp:144