1 | //===- SDNodeProperties.h ---------------------------------------*- 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 | #ifndef LLVM_UTILS_TABLEGEN_SDNODEPROPERTIES_H |
10 | #define LLVM_UTILS_TABLEGEN_SDNODEPROPERTIES_H |
11 | |
12 | namespace llvm { |
13 | |
14 | class Record; |
15 | |
16 | // SelectionDAG node properties. |
17 | // SDNPMemOperand: indicates that a node touches memory and therefore must |
18 | // have an associated memory operand that describes the access. |
19 | enum SDNP { |
20 | SDNPCommutative, |
21 | SDNPAssociative, |
22 | SDNPHasChain, |
23 | SDNPOutGlue, |
24 | SDNPInGlue, |
25 | SDNPOptInGlue, |
26 | SDNPMayLoad, |
27 | SDNPMayStore, |
28 | SDNPSideEffect, |
29 | SDNPMemOperand, |
30 | SDNPVariadic, |
31 | SDNPWantRoot, |
32 | SDNPWantParent |
33 | }; |
34 | |
35 | unsigned parseSDPatternOperatorProperties(Record *R); |
36 | |
37 | } // namespace llvm |
38 | |
39 | #endif |
40 | |