16cfb4d46SJozef Lawrynowicz //===-- MSP430AttributeParser.cpp - MSP430 Attribute Parser ---------------===//
26cfb4d46SJozef Lawrynowicz //
36cfb4d46SJozef Lawrynowicz // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
46cfb4d46SJozef Lawrynowicz // See https://llvm.org/LICENSE.txt for license information.
56cfb4d46SJozef Lawrynowicz // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
66cfb4d46SJozef Lawrynowicz //
76cfb4d46SJozef Lawrynowicz //===----------------------------------------------------------------------===//
86cfb4d46SJozef Lawrynowicz 
96cfb4d46SJozef Lawrynowicz #include "llvm/Support/MSP430AttributeParser.h"
10*75e164f6Sserge-sans-paille #include "llvm/ADT/ArrayRef.h"
11*75e164f6Sserge-sans-paille #include "llvm/Support/ErrorHandling.h"
126cfb4d46SJozef Lawrynowicz 
136cfb4d46SJozef Lawrynowicz using namespace llvm;
146cfb4d46SJozef Lawrynowicz using namespace llvm::MSP430Attrs;
156cfb4d46SJozef Lawrynowicz 
166cfb4d46SJozef Lawrynowicz constexpr std::array<MSP430AttributeParser::DisplayHandler, 4>
176cfb4d46SJozef Lawrynowicz     MSP430AttributeParser::DisplayRoutines{
186cfb4d46SJozef Lawrynowicz         {{MSP430Attrs::TagISA, &MSP430AttributeParser::parseISA},
196cfb4d46SJozef Lawrynowicz          {MSP430Attrs::TagCodeModel, &MSP430AttributeParser::parseCodeModel},
206cfb4d46SJozef Lawrynowicz          {MSP430Attrs::TagDataModel, &MSP430AttributeParser::parseDataModel},
216cfb4d46SJozef Lawrynowicz          {MSP430Attrs::TagEnumSize, &MSP430AttributeParser::parseEnumSize}}};
226cfb4d46SJozef Lawrynowicz 
parseISA(AttrType Tag)236cfb4d46SJozef Lawrynowicz Error MSP430AttributeParser::parseISA(AttrType Tag) {
246cfb4d46SJozef Lawrynowicz   static const char *StringVals[] = {"None", "MSP430", "MSP430X"};
256cfb4d46SJozef Lawrynowicz   return parseStringAttribute("ISA", Tag, makeArrayRef(StringVals));
266cfb4d46SJozef Lawrynowicz }
276cfb4d46SJozef Lawrynowicz 
parseCodeModel(AttrType Tag)286cfb4d46SJozef Lawrynowicz Error MSP430AttributeParser::parseCodeModel(AttrType Tag) {
296cfb4d46SJozef Lawrynowicz   static const char *StringVals[] = {"None", "Small", "Large"};
306cfb4d46SJozef Lawrynowicz   return parseStringAttribute("Code Model", Tag, makeArrayRef(StringVals));
316cfb4d46SJozef Lawrynowicz }
326cfb4d46SJozef Lawrynowicz 
parseDataModel(AttrType Tag)336cfb4d46SJozef Lawrynowicz Error MSP430AttributeParser::parseDataModel(AttrType Tag) {
346cfb4d46SJozef Lawrynowicz   static const char *StringVals[] = {"None", "Small", "Large", "Restricted"};
356cfb4d46SJozef Lawrynowicz   return parseStringAttribute("Data Model", Tag, makeArrayRef(StringVals));
366cfb4d46SJozef Lawrynowicz }
376cfb4d46SJozef Lawrynowicz 
parseEnumSize(AttrType Tag)386cfb4d46SJozef Lawrynowicz Error MSP430AttributeParser::parseEnumSize(AttrType Tag) {
396cfb4d46SJozef Lawrynowicz   static const char *StringVals[] = {"None", "Small", "Integer", "Don't Care"};
406cfb4d46SJozef Lawrynowicz   return parseStringAttribute("Enum Size", Tag, makeArrayRef(StringVals));
416cfb4d46SJozef Lawrynowicz }
426cfb4d46SJozef Lawrynowicz 
handler(uint64_t Tag,bool & Handled)436cfb4d46SJozef Lawrynowicz Error MSP430AttributeParser::handler(uint64_t Tag, bool &Handled) {
446cfb4d46SJozef Lawrynowicz   Handled = false;
456cfb4d46SJozef Lawrynowicz   for (const DisplayHandler &Disp : DisplayRoutines) {
466cfb4d46SJozef Lawrynowicz     if (uint64_t(Disp.Attribute) != Tag)
476cfb4d46SJozef Lawrynowicz       continue;
486cfb4d46SJozef Lawrynowicz     if (Error E = (this->*Disp.Routine)(static_cast<AttrType>(Tag)))
496cfb4d46SJozef Lawrynowicz       return E;
506cfb4d46SJozef Lawrynowicz     Handled = true;
516cfb4d46SJozef Lawrynowicz     break;
526cfb4d46SJozef Lawrynowicz   }
536cfb4d46SJozef Lawrynowicz   return Error::success();
546cfb4d46SJozef Lawrynowicz }
55