1*0b57cec5SDimitry Andric //===- SDNodeProperties.cpp -----------------------------------------------===//
2*0b57cec5SDimitry Andric //
3*0b57cec5SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4*0b57cec5SDimitry Andric // See https://llvm.org/LICENSE.txt for license information.
5*0b57cec5SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6*0b57cec5SDimitry Andric //
7*0b57cec5SDimitry Andric //===----------------------------------------------------------------------===//
8*0b57cec5SDimitry Andric 
9*0b57cec5SDimitry Andric #include "SDNodeProperties.h"
10*0b57cec5SDimitry Andric #include "llvm/ADT/StringSwitch.h"
11*0b57cec5SDimitry Andric #include "llvm/TableGen/Error.h"
12*0b57cec5SDimitry Andric #include "llvm/TableGen/Record.h"
13*0b57cec5SDimitry Andric 
14*0b57cec5SDimitry Andric using namespace llvm;
15*0b57cec5SDimitry Andric 
parseSDPatternOperatorProperties(Record * R)16*0b57cec5SDimitry Andric unsigned llvm::parseSDPatternOperatorProperties(Record *R) {
17*0b57cec5SDimitry Andric   unsigned Properties = 0;
18*0b57cec5SDimitry Andric   for (Record *Property : R->getValueAsListOfDefs("Properties")) {
19*0b57cec5SDimitry Andric     auto Offset = StringSwitch<unsigned>(Property->getName())
20*0b57cec5SDimitry Andric                       .Case("SDNPCommutative", SDNPCommutative)
21*0b57cec5SDimitry Andric                       .Case("SDNPAssociative", SDNPAssociative)
22*0b57cec5SDimitry Andric                       .Case("SDNPHasChain", SDNPHasChain)
23*0b57cec5SDimitry Andric                       .Case("SDNPOutGlue", SDNPOutGlue)
24*0b57cec5SDimitry Andric                       .Case("SDNPInGlue", SDNPInGlue)
25*0b57cec5SDimitry Andric                       .Case("SDNPOptInGlue", SDNPOptInGlue)
26*0b57cec5SDimitry Andric                       .Case("SDNPMayStore", SDNPMayStore)
27*0b57cec5SDimitry Andric                       .Case("SDNPMayLoad", SDNPMayLoad)
28*0b57cec5SDimitry Andric                       .Case("SDNPSideEffect", SDNPSideEffect)
29*0b57cec5SDimitry Andric                       .Case("SDNPMemOperand", SDNPMemOperand)
30*0b57cec5SDimitry Andric                       .Case("SDNPVariadic", SDNPVariadic)
31*0b57cec5SDimitry Andric                       .Default(-1u);
32*0b57cec5SDimitry Andric     if (Offset != -1u)
33*0b57cec5SDimitry Andric       Properties |= 1 << Offset;
34*0b57cec5SDimitry Andric     else
35*0b57cec5SDimitry Andric       PrintFatalError(R->getLoc(), "Unknown SD Node property '" +
36*0b57cec5SDimitry Andric                                        Property->getName() + "' on node '" +
37*0b57cec5SDimitry Andric                                        R->getName() + "'!");
38*0b57cec5SDimitry Andric   }
39*0b57cec5SDimitry Andric   return Properties;
40*0b57cec5SDimitry Andric }
41*0b57cec5SDimitry Andric