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