1349cc55cSDimitry Andric //===-- MSP430AttributeParser.cpp - MSP430 Attribute Parser ---------------===//
2349cc55cSDimitry Andric //
3349cc55cSDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4349cc55cSDimitry Andric // See https://llvm.org/LICENSE.txt for license information.
5349cc55cSDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6349cc55cSDimitry Andric //
7349cc55cSDimitry Andric //===----------------------------------------------------------------------===//
8349cc55cSDimitry Andric
9349cc55cSDimitry Andric #include "llvm/Support/MSP430AttributeParser.h"
1004eeddc0SDimitry Andric #include "llvm/ADT/ArrayRef.h"
1104eeddc0SDimitry Andric #include "llvm/Support/ErrorHandling.h"
12349cc55cSDimitry Andric
13349cc55cSDimitry Andric using namespace llvm;
14349cc55cSDimitry Andric using namespace llvm::MSP430Attrs;
15349cc55cSDimitry Andric
16349cc55cSDimitry Andric constexpr std::array<MSP430AttributeParser::DisplayHandler, 4>
17349cc55cSDimitry Andric MSP430AttributeParser::DisplayRoutines{
18349cc55cSDimitry Andric {{MSP430Attrs::TagISA, &MSP430AttributeParser::parseISA},
19349cc55cSDimitry Andric {MSP430Attrs::TagCodeModel, &MSP430AttributeParser::parseCodeModel},
20349cc55cSDimitry Andric {MSP430Attrs::TagDataModel, &MSP430AttributeParser::parseDataModel},
21349cc55cSDimitry Andric {MSP430Attrs::TagEnumSize, &MSP430AttributeParser::parseEnumSize}}};
22349cc55cSDimitry Andric
parseISA(AttrType Tag)23349cc55cSDimitry Andric Error MSP430AttributeParser::parseISA(AttrType Tag) {
24349cc55cSDimitry Andric static const char *StringVals[] = {"None", "MSP430", "MSP430X"};
25*bdd1243dSDimitry Andric return parseStringAttribute("ISA", Tag, ArrayRef(StringVals));
26349cc55cSDimitry Andric }
27349cc55cSDimitry Andric
parseCodeModel(AttrType Tag)28349cc55cSDimitry Andric Error MSP430AttributeParser::parseCodeModel(AttrType Tag) {
29349cc55cSDimitry Andric static const char *StringVals[] = {"None", "Small", "Large"};
30*bdd1243dSDimitry Andric return parseStringAttribute("Code Model", Tag, ArrayRef(StringVals));
31349cc55cSDimitry Andric }
32349cc55cSDimitry Andric
parseDataModel(AttrType Tag)33349cc55cSDimitry Andric Error MSP430AttributeParser::parseDataModel(AttrType Tag) {
34349cc55cSDimitry Andric static const char *StringVals[] = {"None", "Small", "Large", "Restricted"};
35*bdd1243dSDimitry Andric return parseStringAttribute("Data Model", Tag, ArrayRef(StringVals));
36349cc55cSDimitry Andric }
37349cc55cSDimitry Andric
parseEnumSize(AttrType Tag)38349cc55cSDimitry Andric Error MSP430AttributeParser::parseEnumSize(AttrType Tag) {
39349cc55cSDimitry Andric static const char *StringVals[] = {"None", "Small", "Integer", "Don't Care"};
40*bdd1243dSDimitry Andric return parseStringAttribute("Enum Size", Tag, ArrayRef(StringVals));
41349cc55cSDimitry Andric }
42349cc55cSDimitry Andric
handler(uint64_t Tag,bool & Handled)43349cc55cSDimitry Andric Error MSP430AttributeParser::handler(uint64_t Tag, bool &Handled) {
44349cc55cSDimitry Andric Handled = false;
45349cc55cSDimitry Andric for (const DisplayHandler &Disp : DisplayRoutines) {
46349cc55cSDimitry Andric if (uint64_t(Disp.Attribute) != Tag)
47349cc55cSDimitry Andric continue;
48349cc55cSDimitry Andric if (Error E = (this->*Disp.Routine)(static_cast<AttrType>(Tag)))
49349cc55cSDimitry Andric return E;
50349cc55cSDimitry Andric Handled = true;
51349cc55cSDimitry Andric break;
52349cc55cSDimitry Andric }
53349cc55cSDimitry Andric return Error::success();
54349cc55cSDimitry Andric }
55