xref: /freebsd/contrib/llvm-project/llvm/utils/TableGen/Basic/SDNodeProperties.h (revision 4b15965daa99044daf184221b7c283bf7f2d7e66)
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