1e5dd7070Spatrick //===--- MSP430.cpp - Implement MSP430 target feature support -------------===//
2e5dd7070Spatrick //
3e5dd7070Spatrick // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4e5dd7070Spatrick // See https://llvm.org/LICENSE.txt for license information.
5e5dd7070Spatrick // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6e5dd7070Spatrick //
7e5dd7070Spatrick //===----------------------------------------------------------------------===//
8e5dd7070Spatrick //
9e5dd7070Spatrick // This file implements MSP430 TargetInfo objects.
10e5dd7070Spatrick //
11e5dd7070Spatrick //===----------------------------------------------------------------------===//
12e5dd7070Spatrick
13e5dd7070Spatrick #include "MSP430.h"
14e5dd7070Spatrick #include "clang/Basic/MacroBuilder.h"
15e5dd7070Spatrick
16e5dd7070Spatrick using namespace clang;
17e5dd7070Spatrick using namespace clang::targets;
18e5dd7070Spatrick
19e5dd7070Spatrick const char *const MSP430TargetInfo::GCCRegNames[] = {
20e5dd7070Spatrick "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
21e5dd7070Spatrick "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15"
22e5dd7070Spatrick };
23e5dd7070Spatrick
getGCCRegNames() const24e5dd7070Spatrick ArrayRef<const char *> MSP430TargetInfo::getGCCRegNames() const {
25*12c85518Srobert return llvm::ArrayRef(GCCRegNames);
26e5dd7070Spatrick }
27e5dd7070Spatrick
getTargetDefines(const LangOptions & Opts,MacroBuilder & Builder) const28e5dd7070Spatrick void MSP430TargetInfo::getTargetDefines(const LangOptions &Opts,
29e5dd7070Spatrick MacroBuilder &Builder) const {
30e5dd7070Spatrick Builder.defineMacro("MSP430");
31e5dd7070Spatrick Builder.defineMacro("__MSP430__");
32a9ac8606Spatrick Builder.defineMacro("__ELF__");
33e5dd7070Spatrick // FIXME: defines for different 'flavours' of MCU
34e5dd7070Spatrick }
35