xref: /freebsd-src/contrib/llvm-project/llvm/lib/Target/Lanai/LanaiSubtarget.cpp (revision 5f757f3ff9144b609b3c433dfd370cc6bdc191ad)
10b57cec5SDimitry Andric //===- LanaiSubtarget.cpp - Lanai Subtarget Information -----------*- C++ -*-=//
20b57cec5SDimitry Andric //
30b57cec5SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
40b57cec5SDimitry Andric // See https://llvm.org/LICENSE.txt for license information.
50b57cec5SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
60b57cec5SDimitry Andric //
70b57cec5SDimitry Andric //===----------------------------------------------------------------------===//
80b57cec5SDimitry Andric //
90b57cec5SDimitry Andric // This file implements the Lanai specific subclass of TargetSubtarget.
100b57cec5SDimitry Andric //
110b57cec5SDimitry Andric //===----------------------------------------------------------------------===//
120b57cec5SDimitry Andric 
130b57cec5SDimitry Andric #include "LanaiSubtarget.h"
140b57cec5SDimitry Andric 
150b57cec5SDimitry Andric #include "Lanai.h"
160b57cec5SDimitry Andric 
170b57cec5SDimitry Andric #define DEBUG_TYPE "lanai-subtarget"
180b57cec5SDimitry Andric 
190b57cec5SDimitry Andric #define GET_SUBTARGETINFO_TARGET_DESC
200b57cec5SDimitry Andric #define GET_SUBTARGETINFO_CTOR
210b57cec5SDimitry Andric #include "LanaiGenSubtargetInfo.inc"
220b57cec5SDimitry Andric 
230b57cec5SDimitry Andric using namespace llvm;
240b57cec5SDimitry Andric 
initSubtargetFeatures(StringRef CPU,StringRef FS)250b57cec5SDimitry Andric void LanaiSubtarget::initSubtargetFeatures(StringRef CPU, StringRef FS) {
265ffd83dbSDimitry Andric   std::string CPUName = std::string(CPU);
270b57cec5SDimitry Andric   if (CPUName.empty())
280b57cec5SDimitry Andric     CPUName = "generic";
290b57cec5SDimitry Andric 
30e8d8bef9SDimitry Andric   ParseSubtargetFeatures(CPUName, /*TuneCPU*/ CPUName, FS);
310b57cec5SDimitry Andric }
320b57cec5SDimitry Andric 
initializeSubtargetDependencies(StringRef CPU,StringRef FS)330b57cec5SDimitry Andric LanaiSubtarget &LanaiSubtarget::initializeSubtargetDependencies(StringRef CPU,
340b57cec5SDimitry Andric                                                                 StringRef FS) {
350b57cec5SDimitry Andric   initSubtargetFeatures(CPU, FS);
360b57cec5SDimitry Andric   return *this;
370b57cec5SDimitry Andric }
380b57cec5SDimitry Andric 
LanaiSubtarget(const Triple & TargetTriple,StringRef Cpu,StringRef FeatureString,const TargetMachine & TM,const TargetOptions &,CodeModel::Model,CodeGenOptLevel)390b57cec5SDimitry Andric LanaiSubtarget::LanaiSubtarget(const Triple &TargetTriple, StringRef Cpu,
400b57cec5SDimitry Andric                                StringRef FeatureString, const TargetMachine &TM,
410b57cec5SDimitry Andric                                const TargetOptions & /*Options*/,
420b57cec5SDimitry Andric                                CodeModel::Model /*CodeModel*/,
43*5f757f3fSDimitry Andric                                CodeGenOptLevel /*OptLevel*/)
44e8d8bef9SDimitry Andric     : LanaiGenSubtargetInfo(TargetTriple, Cpu, /*TuneCPU*/ Cpu, FeatureString),
450b57cec5SDimitry Andric       FrameLowering(initializeSubtargetDependencies(Cpu, FeatureString)),
4604eeddc0SDimitry Andric       TLInfo(TM, *this) {}
47