| //===- 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 "llvm/Support/Compiler.h" |
| |
| namespace llvm { |
| class GIMatchDagInstr; |
| class GIMatchDagPredicate; |
| class GIMatchDagOperand; |
| |
| class raw_ostream; |
| |
| /// 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 |