003 File Manager
Current Path:
/usr/src/contrib/llvm-project/llvm/utils/TableGen/GlobalISel
usr
/
src
/
contrib
/
llvm-project
/
llvm
/
utils
/
TableGen
/
GlobalISel
/
📁
..
📄
CodeExpander.cpp
(2.83 KB)
📄
CodeExpander.h
(1.77 KB)
📄
CodeExpansions.h
(1.36 KB)
📄
GIMatchDag.cpp
(4.3 KB)
📄
GIMatchDag.h
(8.73 KB)
📄
GIMatchDagEdge.cpp
(1.2 KB)
📄
GIMatchDagEdge.h
(2.44 KB)
📄
GIMatchDagInstr.cpp
(1.45 KB)
📄
GIMatchDagInstr.h
(4.53 KB)
📄
GIMatchDagOperands.cpp
(4.75 KB)
📄
GIMatchDagOperands.h
(5.1 KB)
📄
GIMatchDagPredicate.cpp
(2.26 KB)
📄
GIMatchDagPredicate.h
(4.92 KB)
📄
GIMatchDagPredicateDependencyEdge.cpp
(1.17 KB)
📄
GIMatchDagPredicateDependencyEdge.h
(2.4 KB)
📄
GIMatchTree.cpp
(30.57 KB)
📄
GIMatchTree.h
(25.68 KB)
Editing: GIMatchDagPredicateDependencyEdge.h
//===- GIMatchDagPredicateDependencyEdge - Ensure predicates have inputs --===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #ifndef LLVM_UTILS_TABLEGEN_GIMATCHDAGPREDICATEEDGE_H #define LLVM_UTILS_TABLEGEN_GIMATCHDAGPREDICATEEDGE_H #include "GIMatchDagOperands.h" namespace llvm { class GIMatchDag; class GIMatchDagInstr; class GIMatchDagEdge; class GIMatchDagPredicate; /// Represents a dependency that must be met to evaluate a predicate. /// /// Instances of this class objects are owned by the GIMatchDag and are not /// shareable between instances of GIMatchDag. class GIMatchDagPredicateDependencyEdge { /// The MI that must be available in order to test the predicate. const GIMatchDagInstr *RequiredMI; /// The MO that must be available in order to test the predicate. May be /// nullptr when only the MI is required. const GIMatchDagOperand *RequiredMO; /// The Predicate that requires information from RequiredMI/RequiredMO. const GIMatchDagPredicate *Predicate; /// The Predicate operand that requires information from /// RequiredMI/RequiredMO. const GIMatchDagOperand *PredicateOp; public: GIMatchDagPredicateDependencyEdge(const GIMatchDagInstr *RequiredMI, const GIMatchDagOperand *RequiredMO, const GIMatchDagPredicate *Predicate, const GIMatchDagOperand *PredicateOp) : RequiredMI(RequiredMI), RequiredMO(RequiredMO), Predicate(Predicate), PredicateOp(PredicateOp) {} const GIMatchDagInstr *getRequiredMI() const { return RequiredMI; } const GIMatchDagOperand *getRequiredMO() const { return RequiredMO; } const GIMatchDagPredicate *getPredicate() const { return Predicate; } const GIMatchDagOperand *getPredicateOp() const { return PredicateOp; } void print(raw_ostream &OS) const; #if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP) LLVM_DUMP_METHOD void dump() const; #endif // if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP) }; raw_ostream &operator<<(raw_ostream &OS, const GIMatchDagPredicateDependencyEdge &N); } // end namespace llvm #endif // ifndef LLVM_UTILS_TABLEGEN_GIMATCHDAGPREDICATEEDGE_H
Upload File
Create Folder