LLVM 23.0.0git
BasicBlock.h
Go to the documentation of this file.
1//===- llvm/BasicBlock.h - Represent a basic block in the VM ----*- C++ -*-===//
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 contains the declaration of the BasicBlock class.
10//
11//===----------------------------------------------------------------------===//
12
13#ifndef LLVM_IR_BASICBLOCK_H
14#define LLVM_IR_BASICBLOCK_H
15
16#include "llvm-c/Types.h"
17#include "llvm/ADT/DenseMap.h"
18#include "llvm/ADT/Twine.h"
19#include "llvm/ADT/ilist.h"
20#include "llvm/ADT/ilist_node.h"
21#include "llvm/ADT/iterator.h"
24#include "llvm/IR/Instruction.h"
26#include "llvm/IR/Value.h"
28#include <cassert>
29#include <cstddef>
30#include <iterator>
31
32namespace llvm {
33
35class CallInst;
36class DataLayout;
37class Function;
38class LandingPadInst;
39class LLVMContext;
40class Module;
41class PHINode;
44class DbgMarker;
45
46/// LLVM Basic Block Representation
47///
48/// This represents a single basic block in LLVM. A basic block is simply a
49/// container of instructions that execute sequentially. Basic blocks are Values
50/// because they are referenced by instructions such as branches and switch
51/// tables. The type of a BasicBlock is "Type::LabelTy" because the basic block
52/// represents a label to which a branch can jump.
53///
54/// A well formed basic block is formed of a list of non-terminating
55/// instructions followed by a single terminator instruction. Terminator
56/// instructions may not occur in the middle of basic blocks, and must terminate
57/// the blocks. The BasicBlock class allows malformed basic blocks to occur
58/// because it may be useful in the intermediate stage of constructing or
59/// modifying a program. However, the verifier will ensure that basic blocks are
60/// "well formed".
61class BasicBlock final : public Value, // Basic blocks are data objects also
62 public ilist_node_with_parent<BasicBlock, Function> {
63public:
66
67private:
68 // Allow Function to renumber blocks.
69 friend class Function;
70 /// Per-function unique number.
71 unsigned Number = ~0u;
72
73 friend class BlockAddress;
74 friend class SymbolTableListTraits<BasicBlock>;
75
76 InstListType InstList;
77 Function *Parent;
78
79public:
80 /// Attach a DbgMarker to the given instruction. Enables the storage of any
81 /// debug-info at this position in the program.
84
85 /// Convert variable location debugging information stored in dbg.value
86 /// intrinsics into DbgMarkers / DbgRecords. Deletes all dbg.values in
87 /// the process and sets IsNewDbgInfoFormat = true.
89
90 /// Convert variable location debugging information stored in DbgMarkers and
91 /// DbgRecords into the dbg.value intrinsic representation. Sets
92 /// IsNewDbgInfoFormat = false.
94
95 unsigned getNumber() const {
96 assert(getParent() && "only basic blocks in functions have valid numbers");
97 return Number;
98 }
99
100 /// Record that the collection of DbgRecords in \p M "trails" after the last
101 /// instruction of this block. These are equivalent to dbg.value intrinsics
102 /// that exist at the end of a basic block with no terminator (a transient
103 /// state that occurs regularly).
105
106 /// Fetch the collection of DbgRecords that "trail" after the last instruction
107 /// of this block, see \ref setTrailingDbgRecords. If there are none, returns
108 /// nullptr.
110
111 /// Delete any trailing DbgRecords at the end of this block, see
112 /// \ref setTrailingDbgRecords.
114
115 LLVM_ABI void dumpDbgValues() const;
116
117 /// Return the DbgMarker for the position given by \p It, so that DbgRecords
118 /// can be inserted there. This will either be nullptr if not present, a
119 /// DbgMarker, or TrailingDbgRecords if It is end().
121
122 /// Return the DbgMarker for the position that comes after \p I. \see
123 /// BasicBlock::getMarker, this can be nullptr, a DbgMarker, or
124 /// TrailingDbgRecords if there is no next instruction.
126
127 /// Insert a DbgRecord into a block at the position given by \p I.
129
130 /// Insert a DbgRecord into a block at the position given by \p Here.
133
134 /// Eject any debug-info trailing at the end of a block. DbgRecords can
135 /// transiently be located "off the end" of a block if the blocks terminator
136 /// is temporarily removed. Once a terminator is re-inserted this method will
137 /// move such DbgRecords back to the right place (ahead of the terminator).
139
140 /// In rare circumstances instructions can be speculatively removed from
141 /// blocks, and then be re-inserted back into that position later. When this
142 /// happens in RemoveDIs debug-info mode, some special patching-up needs to
143 /// occur: inserting into the middle of a sequence of dbg.value intrinsics
144 /// does not have an equivalent with DbgRecords.
145 LLVM_ABI void
147 std::optional<DbgRecord::self_iterator> Pos);
148
149private:
150 void setParent(Function *parent);
151
152 /// Constructor.
153 ///
154 /// If the function parameter is specified, the basic block is automatically
155 /// inserted at either the end of the function (if InsertBefore is null), or
156 /// before the specified basic block.
157 LLVM_ABI explicit BasicBlock(LLVMContext &C, const Twine &Name = "",
158 Function *Parent = nullptr,
159 BasicBlock *InsertBefore = nullptr);
160
161public:
162 BasicBlock(const BasicBlock &) = delete;
163 BasicBlock &operator=(const BasicBlock &) = delete;
165
166 /// Get the context in which this basic block lives.
168
169 /// Instruction iterators...
174
175 // These functions and classes need access to the instruction list.
180 friend class llvm::SymbolTableListTraits<
181 llvm::Instruction, ilist_iterator_bits<true>, ilist_parent<BasicBlock>>;
182 friend class llvm::ilist_node_with_parent<llvm::Instruction, llvm::BasicBlock,
183 ilist_iterator_bits<true>,
184 ilist_parent<BasicBlock>>;
185
186 // Friendly methods that need to access us for the maintenence of
187 // debug-info attachments.
188 friend void Instruction::insertBefore(BasicBlock::iterator InsertPos);
189 friend void Instruction::insertAfter(Instruction *InsertPos);
190 friend void Instruction::insertAfter(BasicBlock::iterator InsertPos);
191 friend void Instruction::insertBefore(BasicBlock &BB,
192 InstListType::iterator InsertPos);
193 friend void Instruction::moveBeforeImpl(BasicBlock &BB,
194 InstListType::iterator I,
195 bool Preserve);
196 friend iterator_range<DbgRecord::self_iterator>
198 const Instruction *From, std::optional<DbgRecord::self_iterator> FromHere,
199 bool InsertAtHead);
200
201 /// Creates a new BasicBlock.
202 ///
203 /// If the Parent parameter is specified, the basic block is automatically
204 /// inserted at either the end of the function (if InsertBefore is 0), or
205 /// before the specified basic block.
206 static BasicBlock *Create(LLVMContext &Context, const Twine &Name = "",
207 Function *Parent = nullptr,
208 BasicBlock *InsertBefore = nullptr) {
209 return new BasicBlock(Context, Name, Parent, InsertBefore);
210 }
211
212 /// Return the enclosing method, or null if none.
213 const Function *getParent() const { return Parent; }
214 Function *getParent() { return Parent; }
215
216 /// Return the module owning the function this basic block belongs to, or
217 /// nullptr if the function does not have a module.
218 ///
219 /// Note: this is undefined behavior if the block does not have a parent.
220 LLVM_ABI const Module *getModule() const;
222 return const_cast<Module *>(
223 static_cast<const BasicBlock *>(this)->getModule());
224 }
225
226 /// Get the data layout of the module this basic block belongs to.
227 ///
228 /// Requires the basic block to have a parent module.
229 LLVM_ABI const DataLayout &getDataLayout() const;
230
231 /// Returns whether the block has a terminator.
233 return !InstList.empty() && InstList.back().isTerminator();
234 }
235
236 /// Returns the terminator instruction; assumes that the block is well-formed.
238 assert(hasTerminator() && "cannot get terminator of non-well-formed block");
239 return &InstList.back();
240 }
242 return const_cast<Instruction *>(
243 static_cast<const BasicBlock *>(this)->getTerminator());
244 }
245
246 /// Returns the terminator instruction if the block is well formed or
247 /// null if the block is not well formed.
249 return hasTerminator() ? getTerminator() : nullptr;
250 }
252 return hasTerminator() ? getTerminator() : nullptr;
253 }
254
255 /// Returns the call instruction calling \@llvm.experimental.deoptimize
256 /// prior to the terminating return instruction of this basic block, if such
257 /// a call is present. Otherwise, returns null.
260 return const_cast<CallInst *>(
261 static_cast<const BasicBlock *>(this)->getTerminatingDeoptimizeCall());
262 }
263
264 /// Returns the call instruction calling \@llvm.experimental.deoptimize
265 /// that is present either in current basic block or in block that is a unique
266 /// successor to current block, if such call is present. Otherwise, returns
267 /// null.
270 return const_cast<CallInst *>(static_cast<const BasicBlock *>(this)
271 ->getPostdominatingDeoptimizeCall());
272 }
273
274 /// Returns the call instruction marked 'musttail' prior to the terminating
275 /// return instruction of this basic block, if such a call is present.
276 /// Otherwise, returns null.
279 return const_cast<CallInst *>(
280 static_cast<const BasicBlock *>(this)->getTerminatingMustTailCall());
281 }
282
283 /// Returns a pointer to the first instruction in this block that is not a
284 /// PHINode instruction.
285 ///
286 /// When adding instructions to the beginning of the basic block, they should
287 /// be added before the returned value, not before the first instruction,
288 /// which might be PHI. Returns 0 is there's no non-PHI instruction.
289 ///
290 /// Deprecated in favour of getFirstNonPHIIt, which returns an iterator that
291 /// preserves some debugging information.
292 LLVM_ABI LLVM_DEPRECATED("Use iterators as instruction positions",
293 "getFirstNonPHIIt") const
294 Instruction *getFirstNonPHI() const;
295 LLVM_ABI LLVM_DEPRECATED("Use iterators as instruction positions instead",
296 "getFirstNonPHIIt") Instruction *getFirstNonPHI();
297
298 /// Returns an iterator to the first instruction in this block that is not a
299 /// PHINode instruction.
300 ///
301 /// When adding instructions to the beginning of the basic block, they should
302 /// be added before the returned value, not before the first instruction,
303 /// which might be PHI. Returns end() if there's no non-PHI instruction.
304 ///
305 /// Avoid unwrapping the iterator to an Instruction* before inserting here,
306 /// as important debug-info is preserved in the iterator.
310 static_cast<const BasicBlock *>(this)->getFirstNonPHIIt().getNonConst();
311 It.setHeadBit(true);
312 return It;
313 }
314
315 /// Returns a pointer to the first instruction in this block that is not a
316 /// PHINode or a debug intrinsic, or any pseudo operation if \c SkipPseudoOp
317 /// is true.
319 getFirstNonPHIOrDbg(bool SkipPseudoOp = true) const;
320 InstListType::iterator getFirstNonPHIOrDbg(bool SkipPseudoOp = true) {
321 return static_cast<const BasicBlock *>(this)
322 ->getFirstNonPHIOrDbg(SkipPseudoOp)
323 .getNonConst();
324 }
325
326 /// Returns a pointer to the first instruction in this block that is not a
327 /// PHINode, a debug intrinsic, or a lifetime intrinsic, or any pseudo
328 /// operation if \c SkipPseudoOp is true.
330 getFirstNonPHIOrDbgOrLifetime(bool SkipPseudoOp = true) const;
332 getFirstNonPHIOrDbgOrLifetime(bool SkipPseudoOp = true) {
333 return static_cast<const BasicBlock *>(this)
334 ->getFirstNonPHIOrDbgOrLifetime(SkipPseudoOp)
335 .getNonConst();
336 }
337
338 /// Returns an iterator to the first instruction in this block that is
339 /// suitable for inserting a non-PHI instruction.
340 ///
341 /// In particular, it skips all PHIs and LandingPad instructions.
344 return static_cast<const BasicBlock *>(this)
346 .getNonConst();
347 }
348
349 /// Returns true if there is a valid insertion point for non-PHI instructions
350 /// in this block. Returns false for blocks that can only contain PHI nodes,
351 /// such as blocks with a catchswitch terminator.
352 ///
353 /// This is an O(1) check, unlike getFirstInsertionPt() which must scan
354 /// through all PHI nodes.
355 bool hasInsertionPt() const {
356 const Instruction *Term = getTerminator();
357 return Term && Term->getOpcode() != Instruction::CatchSwitch;
358 }
359
360 /// Returns an iterator to the first instruction in this block that is
361 /// not a PHINode, a debug intrinsic, a static alloca or any pseudo operation.
364 return static_cast<const BasicBlock *>(this)
366 .getNonConst();
367 }
368
369 /// Returns the first potential AsynchEH faulty instruction
370 /// currently it checks for loads/stores (which may dereference a null
371 /// pointer) and calls/invokes (which may propagate exceptions)
374 return const_cast<Instruction *>(
375 static_cast<const BasicBlock *>(this)->getFirstMayFaultInst());
376 }
377
378 /// Unlink 'this' from the containing function, but do not delete it.
380
381 /// Unlink 'this' from the containing function and delete it.
382 ///
383 // \returns an iterator pointing to the element after the erased one.
385
386 /// Unlink this basic block from its current function and insert it into
387 /// the function that \p MovePos lives in, right before \p MovePos.
388 inline void moveBefore(BasicBlock *MovePos) {
389 moveBefore(MovePos->getIterator());
390 }
392
393 /// Unlink this basic block from its current function and insert it
394 /// right after \p MovePos in the function \p MovePos lives in.
395 LLVM_ABI void moveAfter(BasicBlock *MovePos);
396
397 /// Insert unlinked basic block into a function.
398 ///
399 /// Inserts an unlinked basic block into \c Parent. If \c InsertBefore is
400 /// provided, inserts before that basic block, otherwise inserts at the end.
401 ///
402 /// \pre \a getParent() is \c nullptr.
403 LLVM_ABI void insertInto(Function *Parent,
404 BasicBlock *InsertBefore = nullptr);
405
406 /// Return the predecessor of this block if it has a single predecessor
407 /// block. Otherwise return a null pointer.
409 BasicBlock *getSinglePredecessor() {
410 return const_cast<BasicBlock *>(
411 static_cast<const BasicBlock *>(this)->getSinglePredecessor());
412 }
413
414 /// Return the predecessor of this block if it has a unique predecessor
415 /// block. Otherwise return a null pointer.
416 ///
417 /// Note that unique predecessor doesn't mean single edge, there can be
418 /// multiple edges from the unique predecessor to this block (for example a
419 /// switch statement with multiple cases having the same destination).
421 BasicBlock *getUniquePredecessor() {
422 return const_cast<BasicBlock *>(
423 static_cast<const BasicBlock *>(this)->getUniquePredecessor());
424 }
425
426 /// Return true if this block has exactly N predecessors.
427 LLVM_ABI bool hasNPredecessors(unsigned N) const;
428
429 /// Return true if this block has N predecessors or more.
430 LLVM_ABI bool hasNPredecessorsOrMore(unsigned N) const;
431
432 /// Return the successor of this block if it has a single successor.
433 /// Otherwise return a null pointer.
434 ///
435 /// This method is analogous to getSinglePredecessor above.
437 BasicBlock *getSingleSuccessor() {
438 return const_cast<BasicBlock *>(
439 static_cast<const BasicBlock *>(this)->getSingleSuccessor());
440 }
441
442 /// Return the successor of this block if it has a unique successor.
443 /// Otherwise return a null pointer.
444 ///
445 /// This method is analogous to getUniquePredecessor above.
447 BasicBlock *getUniqueSuccessor() {
448 return const_cast<BasicBlock *>(
449 static_cast<const BasicBlock *>(this)->getUniqueSuccessor());
450 }
451
452 /// Print the basic block to an output stream with an optional
453 /// AssemblyAnnotationWriter.
454 LLVM_ABI void print(raw_ostream &OS, AssemblyAnnotationWriter *AAW = nullptr,
455 bool ShouldPreserveUseListOrder = false,
456 bool IsForDebug = false) const;
457
458 //===--------------------------------------------------------------------===//
459 /// Instruction iterator methods
460 ///
461 inline iterator begin() {
462 iterator It = InstList.begin();
463 // Set the head-inclusive bit to indicate that this iterator includes
464 // any debug-info at the start of the block. This is a no-op unless the
465 // appropriate CMake flag is set.
466 It.setHeadBit(true);
467 return It;
468 }
469 inline const_iterator begin() const {
470 const_iterator It = InstList.begin();
471 It.setHeadBit(true);
472 return It;
473 }
474 inline iterator end() { return InstList.end(); }
475 inline const_iterator end() const { return InstList.end(); }
476
477 inline reverse_iterator rbegin() { return InstList.rbegin(); }
478 inline const_reverse_iterator rbegin() const { return InstList.rbegin(); }
479 inline reverse_iterator rend() { return InstList.rend(); }
480 inline const_reverse_iterator rend() const { return InstList.rend(); }
481
482 inline size_t size() const { return InstList.size(); }
483 inline bool empty() const { return InstList.empty(); }
484 inline const Instruction &front() const { return InstList.front(); }
485 inline Instruction &front() { return InstList.front(); }
486 inline const Instruction &back() const { return InstList.back(); }
487 inline Instruction &back() { return InstList.back(); }
488
489 /// Iterator to walk just the phi nodes in the basic block.
490 template <typename PHINodeT = PHINode, typename BBIteratorT = iterator>
491 class phi_iterator_impl
492 : public iterator_facade_base<phi_iterator_impl<PHINodeT, BBIteratorT>,
493 std::forward_iterator_tag, PHINodeT> {
494 friend BasicBlock;
495
496 PHINodeT *PN;
497
498 phi_iterator_impl(PHINodeT *PN) : PN(PN) {}
499
500 public:
501 // Allow default construction to build variables, but this doesn't build
502 // a useful iterator.
503 phi_iterator_impl() = default;
504
505 // Allow conversion between instantiations where valid.
506 template <typename PHINodeU, typename BBIteratorU,
507 typename = std::enable_if_t<
508 std::is_convertible<PHINodeU *, PHINodeT *>::value>>
509 phi_iterator_impl(const phi_iterator_impl<PHINodeU, BBIteratorU> &Arg)
510 : PN(Arg.PN) {}
511
512 bool operator==(const phi_iterator_impl &Arg) const { return PN == Arg.PN; }
513
514 PHINodeT &operator*() const { return *PN; }
515
516 using phi_iterator_impl::iterator_facade_base::operator++;
517 phi_iterator_impl &operator++() {
518 assert(PN && "Cannot increment the end iterator!");
519 PN = dyn_cast<PHINodeT>(std::next(BBIteratorT(PN)));
520 return *this;
521 }
522 };
526
527 /// Returns a range that iterates over the phis in the basic block.
528 ///
529 /// Note that this cannot be used with basic blocks that have no terminator.
531 return const_cast<BasicBlock *>(this)->phis();
532 }
534
535private:
536 /// Return the underlying instruction list container.
537 /// This is deliberately private because we have implemented an adequate set
538 /// of functions to modify the list, including BasicBlock::splice(),
539 /// BasicBlock::erase(), Instruction::insertInto() etc.
540 const InstListType &getInstList() const { return InstList; }
541 InstListType &getInstList() { return InstList; }
542
543 /// Returns a pointer to a member of the instruction list.
544 /// This is private on purpose, just like `getInstList()`.
545 static InstListType BasicBlock::*getSublistAccess(Instruction *) {
546 return &BasicBlock::InstList;
547 }
548
549 /// Dedicated function for splicing debug-info: when we have an empty
550 /// splice (i.e. zero instructions), the caller may still intend any
551 /// debug-info in between the two "positions" to be spliced.
552 void spliceDebugInfoEmptyBlock(BasicBlock::iterator ToIt, BasicBlock *FromBB,
553 BasicBlock::iterator FromBeginIt,
554 BasicBlock::iterator FromEndIt);
555
556 /// Perform any debug-info specific maintenence for the given splice
557 /// activity. In the DbgRecord debug-info representation, debug-info is not
558 /// in instructions, and so it does not automatically move from one block
559 /// to another.
560 void spliceDebugInfo(BasicBlock::iterator ToIt, BasicBlock *FromBB,
561 BasicBlock::iterator FromBeginIt,
562 BasicBlock::iterator FromEndIt);
563 void spliceDebugInfoImpl(BasicBlock::iterator ToIt, BasicBlock *FromBB,
564 BasicBlock::iterator FromBeginIt,
565 BasicBlock::iterator FromEndIt);
566
567 enum {
568 HasAddressTaken = 1 << 0,
569 InstrOrderValid = 1 << 1,
570 };
571
572 void setHasAddressTaken(bool B) {
573 if (B)
574 SubclassOptionalData |= HasAddressTaken;
575 else
576 SubclassOptionalData &= ~HasAddressTaken;
577 }
578
579 /// Shadow Value::setValueSubclassData with a private forwarding method so
580 /// that any future subclasses cannot accidentally use it.
581 void setValueSubclassData(unsigned short D) {
583 }
584
585public:
586 /// Returns a pointer to the symbol table if one exists.
587 LLVM_ABI ValueSymbolTable *getValueSymbolTable();
588
589 /// Methods for support type inquiry through isa, cast, and dyn_cast.
590 static bool classof(const Value *V) {
591 return V->getValueID() == Value::BasicBlockVal;
592 }
593
594 /// Cause all subinstructions to "let go" of all the references that said
595 /// subinstructions are maintaining.
596 ///
597 /// This allows one to 'delete' a whole class at a time, even though there may
598 /// be circular references... first all references are dropped, and all use
599 /// counts go to zero. Then everything is delete'd for real. Note that no
600 /// operations are valid on an object that has "dropped all references",
601 /// except operator delete.
603
604 /// Update PHI nodes in this BasicBlock before removal of predecessor \p Pred.
605 /// Note that this function does not actually remove the predecessor.
606 ///
607 /// If \p KeepOneInputPHIs is true then don't remove PHIs that are left with
608 /// zero or one incoming values, and don't simplify PHIs with all incoming
609 /// values the same.
611 bool KeepOneInputPHIs = false);
612
613 LLVM_ABI bool canSplitPredecessors() const;
614
615 /// Split the basic block into two basic blocks at the specified instruction.
616 ///
617 /// Note that all instructions BEFORE the specified iterator
618 /// stay as part of the original basic block, an unconditional branch is added
619 /// to the original BB, and the rest of the instructions in the BB are moved
620 /// to the new BB, including the old terminator. The newly formed basic block
621 /// is returned. This function invalidates the specified iterator.
622 ///
623 /// Note that this only works on well formed basic blocks (must have a
624 /// terminator), and \p 'I' must not be the end of instruction list (which
625 /// would cause a degenerate basic block to be formed, having a terminator
626 /// inside of the basic block).
627 ///
628 /// Also note that this doesn't preserve any passes. To split blocks while
629 /// keeping loop information consistent, use the SplitBlock utility function.
630 LLVM_ABI BasicBlock *splitBasicBlock(iterator I, const Twine &BBName = "");
631 BasicBlock *splitBasicBlock(Instruction *I, const Twine &BBName = "") {
632 return splitBasicBlock(I->getIterator(), BBName);
633 }
634
635 /// Split the basic block into two basic blocks at the specified instruction
636 /// and insert the new basic blocks as the predecessor of the current block.
637 ///
638 /// This function ensures all instructions AFTER and including the specified
639 /// iterator \p I are part of the original basic block. All Instructions
640 /// BEFORE the iterator \p I are moved to the new BB and an unconditional
641 /// branch is added to the new BB. The new basic block is returned.
642 ///
643 /// Note that this only works on well formed basic blocks (must have a
644 /// terminator), and \p 'I' must not be the end of instruction list (which
645 /// would cause a degenerate basic block to be formed, having a terminator
646 /// inside of the basic block). \p 'I' cannot be a iterator for a PHINode
647 /// with multiple incoming blocks.
648 ///
649 /// Also note that this doesn't preserve any passes. To split blocks while
650 /// keeping loop information consistent, use the SplitBlockBefore utility
651 /// function.
653 const Twine &BBName = "");
654 BasicBlock *splitBasicBlockBefore(Instruction *I, const Twine &BBName = "") {
655 return splitBasicBlockBefore(I->getIterator(), BBName);
656 }
657
658 /// Transfer all instructions from \p FromBB to this basic block at \p ToIt.
659 void splice(BasicBlock::iterator ToIt, BasicBlock *FromBB) {
660 splice(ToIt, FromBB, FromBB->begin(), FromBB->end());
661 }
662
663 /// Transfer one instruction from \p FromBB at \p FromIt to this basic block
664 /// at \p ToIt.
665 void splice(BasicBlock::iterator ToIt, BasicBlock *FromBB,
666 BasicBlock::iterator FromIt) {
667 auto FromItNext = std::next(FromIt);
668 // Single-element splice is a noop if destination == source.
669 if (ToIt == FromIt || ToIt == FromItNext)
670 return;
671 splice(ToIt, FromBB, FromIt, FromItNext);
672 }
673
674 /// Transfer a range of instructions that belong to \p FromBB from \p
675 /// FromBeginIt to \p FromEndIt, to this basic block at \p ToIt.
677 BasicBlock::iterator FromBeginIt,
678 BasicBlock::iterator FromEndIt);
679
680 /// Erases a range of instructions from \p FromIt to (not including) \p ToIt.
681 /// \Returns \p ToIt.
684
685 /// Returns true if there are any uses of this basic block other than
686 /// direct branches, switches, etc. to it.
687 bool hasAddressTaken() const {
688 return SubclassOptionalData & HasAddressTaken;
689 }
690
691 /// Update all phi nodes in this basic block to refer to basic block \p New
692 /// instead of basic block \p Old.
694
695 /// Update all phi nodes in this basic block's successors to refer to basic
696 /// block \p New instead of basic block \p Old.
698
699 /// Update all phi nodes in this basic block's successors to refer to basic
700 /// block \p New instead of to it.
702
703 /// Return true if this basic block is an exception handling block.
704 bool isEHPad() const { return getFirstNonPHIIt()->isEHPad(); }
705
706 /// Return true if this basic block is a landing pad.
707 ///
708 /// Being a ``landing pad'' means that the basic block is the destination of
709 /// the 'unwind' edge of an invoke instruction.
710 LLVM_ABI bool isLandingPad() const;
711
712 /// Return the landingpad instruction associated with the landing pad.
715 return const_cast<LandingPadInst *>(
716 static_cast<const BasicBlock *>(this)->getLandingPadInst());
717 }
718
719 /// Return true if it is legal to hoist instructions into this block.
720 LLVM_ABI bool isLegalToHoistInto() const;
721
722 /// Return true if this is the entry block of the containing function.
723 /// This method can only be used on blocks that have a parent function.
724 LLVM_ABI bool isEntryBlock() const;
725
726 LLVM_ABI std::optional<uint64_t> getIrrLoopHeaderWeight() const;
727
728 /// Returns true if the Order field of child Instructions is valid.
729 bool isInstrOrderValid() const {
730 return SubclassOptionalData & InstrOrderValid;
731 }
732
733 /// Mark instruction ordering invalid. Done on every instruction insert.
736 SubclassOptionalData &= ~InstrOrderValid;
737 }
738
739 /// Renumber instructions and mark the ordering as valid.
741
742 /// Asserts that instruction order numbers are marked invalid, or that they
743 /// are in ascending order. This is constant time if the ordering is invalid,
744 /// and linear in the number of instructions if the ordering is valid. Callers
745 /// should be careful not to call this in ways that make common operations
746 /// O(n^2). For example, it takes O(n) time to assign order numbers to
747 /// instructions, so the order should be validated no more than once after
748 /// each ordering to ensure that transforms have the same algorithmic
749 /// complexity when asserts are enabled as when they are disabled.
751};
752
753// Create wrappers for C Binding types (see CBindingWrapping.h).
755
756/// Advance \p It while it points to a debug instruction and return the result.
757/// This assumes that \p It is not at the end of a block.
759
760#ifdef NDEBUG
761/// In release builds, this is a no-op. For !NDEBUG builds, the checks are
762/// implemented in the .cpp file to avoid circular header deps.
763inline void BasicBlock::validateInstrOrdering() const {}
764#endif
765
766// Specialize DenseMapInfo for iterators, so that ththey can be installed into
767// maps and sets. The iterator is made up of its node pointer, and the
768// debug-info "head" bit.
769template <> struct DenseMapInfo<BasicBlock::iterator> {
771 return BasicBlock::iterator(nullptr);
772 }
773
775 BasicBlock::iterator It(nullptr);
776 It.setHeadBit(true);
777 return It;
778 }
779
780 static unsigned getHashValue(const BasicBlock::iterator &It) {
782 reinterpret_cast<void *>(It.getNodePtr())) ^
783 (unsigned)It.getHeadBit();
784 }
785
786 static bool isEqual(const BasicBlock::iterator &LHS,
787 const BasicBlock::iterator &RHS) {
788 return LHS == RHS && LHS.getHeadBit() == RHS.getHeadBit();
789 }
790};
791
792} // end namespace llvm
793
794#endif // LLVM_IR_BASICBLOCK_H
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
aarch64 promote const
static GCRegistry::Add< StatepointGC > D("statepoint-example", "an example strategy for statepoint")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
#define DEFINE_SIMPLE_CONVERSION_FUNCTIONS(ty, ref)
#define LLVM_ABI
Definition Compiler.h:213
#define LLVM_READONLY
Definition Compiler.h:322
#define LLVM_ABI_FOR_TEST
Definition Compiler.h:218
This file defines the DenseMap class.
#define I(x, y, z)
Definition MD5.cpp:57
Value * RHS
Value * LHS
Iterator to walk just the phi nodes in the basic block.
Definition BasicBlock.h:493
bool operator==(const phi_iterator_impl &Arg) const
Definition BasicBlock.h:512
phi_iterator_impl(const phi_iterator_impl< PHINodeU, BBIteratorU > &Arg)
Definition BasicBlock.h:509
phi_iterator_impl & operator++()
Definition BasicBlock.h:517
LLVM Basic Block Representation.
Definition BasicBlock.h:62
LLVM_ABI BasicBlock::iterator erase(BasicBlock::iterator FromIt, BasicBlock::iterator ToIt)
Erases a range of instructions from FromIt to (not including) ToIt.
LLVM_ABI LLVM_DEPRECATED("Use iterators as instruction positions", "getFirstNonPHIIt") const Instruction *getFirstNonPHI() const
Returns a pointer to the first instruction in this block that is not a PHINode instruction.
bool hasInsertionPt() const
Returns true if there is a valid insertion point for non-PHI instructions in this block.
Definition BasicBlock.h:355
phi_iterator_impl<> phi_iterator
Definition BasicBlock.h:523
LLVM_ABI void replaceSuccessorsPhiUsesWith(BasicBlock *Old, BasicBlock *New)
Update all phi nodes in this basic block's successors to refer to basic block New instead of basic bl...
BasicBlock(const BasicBlock &)=delete
iterator end()
Definition BasicBlock.h:474
unsigned getNumber() const
Definition BasicBlock.h:95
Instruction * getFirstMayFaultInst()
Definition BasicBlock.h:373
iterator begin()
Instruction iterator methods.
Definition BasicBlock.h:461
LLVM_ABI void deleteTrailingDbgRecords()
Delete any trailing DbgRecords at the end of this block, see setTrailingDbgRecords.
iterator_range< const_phi_iterator > phis() const
Returns a range that iterates over the phis in the basic block.
Definition BasicBlock.h:530
LLVM_ABI const LandingPadInst * getLandingPadInst() const
Return the landingpad instruction associated with the landing pad.
LLVM_ABI void setTrailingDbgRecords(DbgMarker *M)
Record that the collection of DbgRecords in M "trails" after the last instruction of this block.
LLVM_ABI const_iterator getFirstInsertionPt() const
Returns an iterator to the first instruction in this block that is suitable for inserting a non-PHI i...
LLVM_ABI BasicBlock * splitBasicBlock(iterator I, const Twine &BBName="")
Split the basic block into two basic blocks at the specified instruction.
const Function * getParent() const
Return the enclosing method, or null if none.
Definition BasicBlock.h:213
reverse_iterator rbegin()
Definition BasicBlock.h:477
bool hasTerminator() const LLVM_READONLY
Returns whether the block has a terminator.
Definition BasicBlock.h:232
static bool classof(const Value *V)
Methods for support type inquiry through isa, cast, and dyn_cast.
Definition BasicBlock.h:590
InstListType::iterator getFirstNonPHIOrDbgOrLifetime(bool SkipPseudoOp=true)
Definition BasicBlock.h:332
LLVM_ABI void renumberInstructions()
Renumber instructions and mark the ordering as valid.
bool empty() const
Definition BasicBlock.h:483
LLVM_ABI DbgMarker * createMarker(Instruction *I)
Attach a DbgMarker to the given instruction.
const Instruction & back() const
Definition BasicBlock.h:486
LLVM_ABI BasicBlock * splitBasicBlockBefore(iterator I, const Twine &BBName="")
Split the basic block into two basic blocks at the specified instruction and insert the new basic blo...
bool hasAddressTaken() const
Returns true if there are any uses of this basic block other than direct branches,...
Definition BasicBlock.h:687
LLVM_ABI InstListType::const_iterator getFirstNonPHIIt() const
Returns an iterator to the first instruction in this block that is not a PHINode instruction.
LLVM_ABI void insertDbgRecordBefore(DbgRecord *DR, InstListType::iterator Here)
Insert a DbgRecord into a block at the position given by Here.
BasicBlock * splitBasicBlockBefore(Instruction *I, const Twine &BBName="")
Definition BasicBlock.h:654
void invalidateOrders()
Mark instruction ordering invalid. Done on every instruction insert.
Definition BasicBlock.h:734
friend void Instruction::removeFromParent()
LLVM_ABI void convertToNewDbgValues()
Convert variable location debugging information stored in dbg.value intrinsics into DbgMarkers / DbgR...
LLVM_ABI void print(raw_ostream &OS, AssemblyAnnotationWriter *AAW=nullptr, bool ShouldPreserveUseListOrder=false, bool IsForDebug=false) const
Print the basic block to an output stream with an optional AssemblyAnnotationWriter.
InstListType::const_iterator const_iterator
Definition BasicBlock.h:171
BasicBlock * getUniqueSuccessor()
Definition BasicBlock.h:447
Module * getModule()
Definition BasicBlock.h:221
Instruction & front()
Definition BasicBlock.h:485
static BasicBlock * Create(LLVMContext &Context, const Twine &Name="", Function *Parent=nullptr, BasicBlock *InsertBefore=nullptr)
Creates a new BasicBlock.
Definition BasicBlock.h:206
BasicBlock * getSingleSuccessor()
Definition BasicBlock.h:437
friend BasicBlock::iterator Instruction::eraseFromParent()
LLVM_ABI bool isEntryBlock() const
Return true if this is the entry block of the containing function.
LLVM_ABI ValueSymbolTable * getValueSymbolTable()
Returns a pointer to the symbol table if one exists.
BasicBlock * getUniquePredecessor()
Definition BasicBlock.h:421
LLVM_ABI void moveAfter(BasicBlock *MovePos)
Unlink this basic block from its current function and insert it right after MovePos in the function M...
LLVM_ABI InstListType::const_iterator getFirstNonPHIOrDbg(bool SkipPseudoOp=true) const
Returns a pointer to the first instruction in this block that is not a PHINode or a debug intrinsic,...
LLVM_ABI bool hasNPredecessors(unsigned N) const
Return true if this block has exactly N predecessors.
BasicBlock * getSinglePredecessor()
Definition BasicBlock.h:409
LLVM_ABI void convertFromNewDbgValues()
Convert variable location debugging information stored in DbgMarkers and DbgRecords into the dbg....
LLVM_ABI const BasicBlock * getUniqueSuccessor() const
Return the successor of this block if it has a unique successor.
LLVM_ABI const BasicBlock * getSinglePredecessor() const
Return the predecessor of this block if it has a single predecessor block.
LLVM_ABI std::optional< uint64_t > getIrrLoopHeaderWeight() const
const Instruction & front() const
Definition BasicBlock.h:484
LLVM_ABI void dumpDbgValues() const
LLVM_ABI const CallInst * getTerminatingDeoptimizeCall() const
Returns the call instruction calling @llvm.experimental.deoptimize prior to the terminating return in...
Instruction & back()
Definition BasicBlock.h:487
InstListType::reverse_iterator reverse_iterator
Definition BasicBlock.h:172
LLVM_ABI void replacePhiUsesWith(BasicBlock *Old, BasicBlock *New)
Update all phi nodes in this basic block to refer to basic block New instead of basic block Old.
LLVM_ABI const BasicBlock * getUniquePredecessor() const
Return the predecessor of this block if it has a unique predecessor block.
const Instruction * getTerminatorOrNull() const LLVM_READONLY
Returns the terminator instruction if the block is well formed or null if the block is not well forme...
Definition BasicBlock.h:248
LLVM_ABI const BasicBlock * getSingleSuccessor() const
Return the successor of this block if it has a single successor.
SymbolTableList< Instruction, ilist_iterator_bits< true >, ilist_parent< BasicBlock > > InstListType
Definition BasicBlock.h:64
LLVM_ABI void flushTerminatorDbgRecords()
Eject any debug-info trailing at the end of a block.
void splice(BasicBlock::iterator ToIt, BasicBlock *FromBB, BasicBlock::iterator FromIt)
Transfer one instruction from FromBB at FromIt to this basic block at ToIt.
Definition BasicBlock.h:665
Function * getParent()
Definition BasicBlock.h:214
InstListType::iterator getFirstNonPHIOrDbg(bool SkipPseudoOp=true)
Definition BasicBlock.h:320
LLVM_ABI const DataLayout & getDataLayout() const
Get the data layout of the module this basic block belongs to.
const_reverse_iterator rend() const
Definition BasicBlock.h:480
reverse_iterator rend()
Definition BasicBlock.h:479
LLVM_ABI void insertDbgRecordAfter(DbgRecord *DR, Instruction *I)
Insert a DbgRecord into a block at the position given by I.
LLVM_ABI_FOR_TEST void validateInstrOrdering() const
Asserts that instruction order numbers are marked invalid, or that they are in ascending order.
LLVM_ABI DbgMarker * getMarker(InstListType::iterator It)
Return the DbgMarker for the position given by It, so that DbgRecords can be inserted there.
LLVM_ABI ~BasicBlock()
InstListType::iterator iterator
Instruction iterators...
Definition BasicBlock.h:170
LLVM_ABI LLVMContext & getContext() const
Get the context in which this basic block lives.
CallInst * getPostdominatingDeoptimizeCall()
Definition BasicBlock.h:269
const_iterator begin() const
Definition BasicBlock.h:469
LLVM_ABI const_iterator getFirstNonPHIOrDbgOrAlloca() const
Returns an iterator to the first instruction in this block that is not a PHINode, a debug intrinsic,...
friend class BlockAddress
Definition BasicBlock.h:73
Instruction * getTerminator()
Definition BasicBlock.h:241
BasicBlock & operator=(const BasicBlock &)=delete
iterator getFirstNonPHIOrDbgOrAlloca()
Definition BasicBlock.h:363
CallInst * getTerminatingDeoptimizeCall()
Definition BasicBlock.h:259
friend class Function
Definition BasicBlock.h:69
LLVM_ABI void dropAllReferences()
Cause all subinstructions to "let go" of all the references that said subinstructions are maintaining...
size_t size() const
Definition BasicBlock.h:482
LLVM_ABI void reinsertInstInDbgRecords(Instruction *I, std::optional< DbgRecord::self_iterator > Pos)
In rare circumstances instructions can be speculatively removed from blocks, and then be re-inserted ...
void moveBefore(BasicBlock *MovePos)
Unlink this basic block from its current function and insert it into the function that MovePos lives ...
Definition BasicBlock.h:388
LLVM_ABI InstListType::const_iterator getFirstNonPHIOrDbgOrLifetime(bool SkipPseudoOp=true) const
Returns a pointer to the first instruction in this block that is not a PHINode, a debug intrinsic,...
LLVM_ABI bool isLandingPad() const
Return true if this basic block is a landing pad.
BasicBlock * splitBasicBlock(Instruction *I, const Twine &BBName="")
Definition BasicBlock.h:631
InstListType::const_reverse_iterator const_reverse_iterator
Definition BasicBlock.h:173
bool isEHPad() const
Return true if this basic block is an exception handling block.
Definition BasicBlock.h:704
LLVM_ABI DbgMarker * getTrailingDbgRecords()
Fetch the collection of DbgRecords that "trail" after the last instruction of this block,...
CallInst * getTerminatingMustTailCall()
Definition BasicBlock.h:278
phi_iterator_impl< const PHINode, BasicBlock::const_iterator > const_phi_iterator
Definition BasicBlock.h:524
LLVM_ABI bool canSplitPredecessors() const
const_iterator end() const
Definition BasicBlock.h:475
LLVM_ABI const CallInst * getTerminatingMustTailCall() const
Returns the call instruction marked 'musttail' prior to the terminating return instruction of this ba...
friend BasicBlock::iterator Instruction::insertInto(BasicBlock *BB, BasicBlock::iterator It)
LLVM_ABI bool isLegalToHoistInto() const
Return true if it is legal to hoist instructions into this block.
LLVM_ABI bool hasNPredecessorsOrMore(unsigned N) const
Return true if this block has N predecessors or more.
bool isInstrOrderValid() const
Returns true if the Order field of child Instructions is valid.
Definition BasicBlock.h:729
LLVM_ABI const CallInst * getPostdominatingDeoptimizeCall() const
Returns the call instruction calling @llvm.experimental.deoptimize that is present either in current ...
Instruction * getTerminatorOrNull()
Definition BasicBlock.h:251
const Instruction * getTerminator() const LLVM_READONLY
Returns the terminator instruction; assumes that the block is well-formed.
Definition BasicBlock.h:237
LLVM_ABI DbgMarker * getNextMarker(Instruction *I)
Return the DbgMarker for the position that comes after I.
LLVM_ABI const Instruction * getFirstMayFaultInst() const
Returns the first potential AsynchEH faulty instruction currently it checks for loads/stores (which m...
void splice(BasicBlock::iterator ToIt, BasicBlock *FromBB)
Transfer all instructions from FromBB to this basic block at ToIt.
Definition BasicBlock.h:659
const_reverse_iterator rbegin() const
Definition BasicBlock.h:478
LandingPadInst * getLandingPadInst()
Definition BasicBlock.h:714
LLVM_ABI const Module * getModule() const
Return the module owning the function this basic block belongs to, or nullptr if the function does no...
iterator getFirstInsertionPt()
Definition BasicBlock.h:343
LLVM_ABI void removePredecessor(BasicBlock *Pred, bool KeepOneInputPHIs=false)
Update PHI nodes in this BasicBlock before removal of predecessor Pred.
This class represents a function call, abstracting a target machine's calling convention.
A parsed version of the target data layout string in and methods for querying it.
Definition DataLayout.h:64
Per-instruction record of debug-info.
Base class for non-instruction debug metadata records that have positions within IR.
Record of a variable value-assignment, aka a non instruction representation of the dbg....
LLVM_ABI void removeFromParent()
This method unlinks 'this' from the containing basic block, but does not delete it.
LLVM_ABI iterator_range< simple_ilist< DbgRecord >::iterator > cloneDebugInfoFrom(const Instruction *From, std::optional< simple_ilist< DbgRecord >::iterator > FromHere=std::nullopt, bool InsertAtHead=false)
Clone any debug-info attached to From onto this instruction.
LLVM_ABI void insertBefore(InstListType::iterator InsertPos)
Insert an unlinked instruction into a basic block immediately before the specified position.
LLVM_ABI InstListType::iterator eraseFromParent()
This method unlinks 'this' from the containing basic block and deletes it.
LLVM_ABI void insertAfter(Instruction *InsertPos)
Insert an unlinked instruction into a basic block immediately after the specified instruction.
LLVM_ABI InstListType::iterator insertInto(BasicBlock *ParentBB, InstListType::iterator It)
Inserts an unlinked instruction into ParentBB at position It and returns the iterator of the inserted...
This is an important class for using LLVM in a threaded context.
Definition LLVMContext.h:68
The landingpad instruction holds all of the information necessary to generate correct exception handl...
A Module instance is used to store all the information related to an LLVM module.
Definition Module.h:67
List that automatically updates parent links and symbol tables.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
Definition Twine.h:82
This class provides a symbol table of name/value pairs.
LLVM_ABI Value(Type *Ty, unsigned scid)
Definition Value.cpp:53
unsigned char SubclassOptionalData
Hold subclass data that can be dropped.
Definition Value.h:85
void setValueSubclassData(unsigned short D)
Definition Value.h:897
self_iterator getIterator()
Definition ilist_node.h:123
An ilist node that can access its parent list.
Definition ilist_node.h:316
typename base_list_type::const_reverse_iterator const_reverse_iterator
Definition ilist.h:124
typename base_list_type::reverse_iterator reverse_iterator
Definition ilist.h:123
typename base_list_type::iterator iterator
Definition ilist.h:121
typename base_list_type::const_iterator const_iterator
Definition ilist.h:122
CRTP base class which implements the entire standard iterator facade in terms of a minimal subset of ...
Definition iterator.h:80
A range adaptor for a pair of iterators.
This class implements an extremely fast bulk output stream that can only output to a stream.
Definition raw_ostream.h:53
struct LLVMOpaqueBasicBlock * LLVMBasicBlockRef
Represents a basic block of instructions in LLVM IR.
Definition Types.h:82
This file defines classes to implement an intrusive doubly linked list class (i.e.
This file defines the ilist_node class template, which is a convenient base class for creating classe...
This provides a very simple, boring adaptor for a begin and end iterator into a range type.
@ C
The default llvm calling convention, compatible with C.
Definition CallingConv.h:34
This is an optimization pass for GlobalISel generic memory operations.
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:643
LLVM_ABI BasicBlock::iterator skipDebugIntrinsics(BasicBlock::iterator It)
Advance It while it points to a debug instruction and return the result.
#define N
static BasicBlock::iterator getEmptyKey()
Definition BasicBlock.h:770
static unsigned getHashValue(const BasicBlock::iterator &It)
Definition BasicBlock.h:780
static bool isEqual(const BasicBlock::iterator &LHS, const BasicBlock::iterator &RHS)
Definition BasicBlock.h:786
static BasicBlock::iterator getTombstoneKey()
Definition BasicBlock.h:774
An information struct used to provide DenseMap with the various necessary components for a given valu...
Option to add extra bits to the ilist_iterator.
Option to add a pointer to this list's owner in every node.