aboutsummaryrefslogtreecommitdiff
path: root/contrib/llvm-project/llvm/utils/TableGen/GlobalISel/GIMatchDagPredicateDependencyEdge.h
blob: af91afc6073d58f5f7d6af70b0de423f79092b6b (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
//===- 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