llvm-project/llvm/utils/TableGen/Basic/SDNodeProperties.cpp
Pierre van Houtryve fa3d789df1
[RFC][TableGen] Restructure TableGen Source (#80847)
Refactor of the llvm-tblgen source into:
- a "Basic" library, which contains the bare minimum utilities to build
`llvm-min-tablegen`
- a "Common" library which contains all of the helpers for TableGen
backends. Such helpers can be shared by more than one backend, and even
unit tested (e.g. CodeExpander is, maybe we can add more over time)

Fixes #80647
2024-03-25 09:40:35 +01:00

41 lines
1.7 KiB
C++

//===- SDNodeProperties.cpp -----------------------------------------------===//
//
// 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
//
//===----------------------------------------------------------------------===//
#include "SDNodeProperties.h"
#include "llvm/ADT/StringSwitch.h"
#include "llvm/TableGen/Error.h"
#include "llvm/TableGen/Record.h"
using namespace llvm;
unsigned llvm::parseSDPatternOperatorProperties(Record *R) {
unsigned Properties = 0;
for (Record *Property : R->getValueAsListOfDefs("Properties")) {
auto Offset = StringSwitch<unsigned>(Property->getName())
.Case("SDNPCommutative", SDNPCommutative)
.Case("SDNPAssociative", SDNPAssociative)
.Case("SDNPHasChain", SDNPHasChain)
.Case("SDNPOutGlue", SDNPOutGlue)
.Case("SDNPInGlue", SDNPInGlue)
.Case("SDNPOptInGlue", SDNPOptInGlue)
.Case("SDNPMayStore", SDNPMayStore)
.Case("SDNPMayLoad", SDNPMayLoad)
.Case("SDNPSideEffect", SDNPSideEffect)
.Case("SDNPMemOperand", SDNPMemOperand)
.Case("SDNPVariadic", SDNPVariadic)
.Default(-1u);
if (Offset != -1u)
Properties |= 1 << Offset;
else
PrintFatalError(R->getLoc(), "Unknown SD Node property '" +
Property->getName() + "' on node '" +
R->getName() + "'!");
}
return Properties;
}