xref: /freebsd-src/contrib/llvm-project/llvm/lib/Target/VE/VESubtarget.cpp (revision 349cc55c9796c4596a5b9904cd3281af295f878f)
1480093f4SDimitry Andric //===-- VESubtarget.cpp - VE Subtarget Information ------------------------===//
2480093f4SDimitry Andric //
3480093f4SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4480093f4SDimitry Andric // See https://llvm.org/LICENSE.txt for license information.
5480093f4SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6480093f4SDimitry Andric //
7480093f4SDimitry Andric //===----------------------------------------------------------------------===//
8480093f4SDimitry Andric //
9480093f4SDimitry Andric // This file implements the VE specific subclass of TargetSubtargetInfo.
10480093f4SDimitry Andric //
11480093f4SDimitry Andric //===----------------------------------------------------------------------===//
12480093f4SDimitry Andric 
13480093f4SDimitry Andric #include "VESubtarget.h"
14480093f4SDimitry Andric #include "VE.h"
15*349cc55cSDimitry Andric #include "llvm/MC/TargetRegistry.h"
16480093f4SDimitry Andric #include "llvm/Support/MathExtras.h"
17480093f4SDimitry Andric 
18480093f4SDimitry Andric using namespace llvm;
19480093f4SDimitry Andric 
20480093f4SDimitry Andric #define DEBUG_TYPE "ve-subtarget"
21480093f4SDimitry Andric 
22480093f4SDimitry Andric #define GET_SUBTARGETINFO_TARGET_DESC
23480093f4SDimitry Andric #define GET_SUBTARGETINFO_CTOR
24480093f4SDimitry Andric #include "VEGenSubtargetInfo.inc"
25480093f4SDimitry Andric 
anchor()26480093f4SDimitry Andric void VESubtarget::anchor() {}
27480093f4SDimitry Andric 
initializeSubtargetDependencies(StringRef CPU,StringRef FS)28480093f4SDimitry Andric VESubtarget &VESubtarget::initializeSubtargetDependencies(StringRef CPU,
29480093f4SDimitry Andric                                                           StringRef FS) {
30e8d8bef9SDimitry Andric   // Default feature settings
31e8d8bef9SDimitry Andric   EnableVPU = false;
32e8d8bef9SDimitry Andric 
33480093f4SDimitry Andric   // Determine default and user specified characteristics
345ffd83dbSDimitry Andric   std::string CPUName = std::string(CPU);
35480093f4SDimitry Andric   if (CPUName.empty())
36e8d8bef9SDimitry Andric     CPUName = "generic";
37480093f4SDimitry Andric 
38480093f4SDimitry Andric   // Parse features string.
39e8d8bef9SDimitry Andric   ParseSubtargetFeatures(CPUName, /*TuneCPU=*/CPU, FS);
40480093f4SDimitry Andric 
41480093f4SDimitry Andric   return *this;
42480093f4SDimitry Andric }
43480093f4SDimitry Andric 
VESubtarget(const Triple & TT,const std::string & CPU,const std::string & FS,const TargetMachine & TM)44480093f4SDimitry Andric VESubtarget::VESubtarget(const Triple &TT, const std::string &CPU,
45480093f4SDimitry Andric                          const std::string &FS, const TargetMachine &TM)
46e8d8bef9SDimitry Andric     : VEGenSubtargetInfo(TT, CPU, /*TuneCPU=*/CPU, FS), TargetTriple(TT),
47480093f4SDimitry Andric       InstrInfo(initializeSubtargetDependencies(CPU, FS)), TLInfo(TM, *this),
48480093f4SDimitry Andric       FrameLowering(*this) {}
49480093f4SDimitry Andric 
getAdjustedFrameSize(uint64_t FrameSize) const50e8d8bef9SDimitry Andric uint64_t VESubtarget::getAdjustedFrameSize(uint64_t FrameSize) const {
51e8d8bef9SDimitry Andric   // Calculate adjusted frame size by adding the size of RSA frame,
52e8d8bef9SDimitry Andric   // return address, and frame poitner as described in VEFrameLowering.cpp.
53e8d8bef9SDimitry Andric   const VEFrameLowering *TFL = getFrameLowering();
54480093f4SDimitry Andric 
55e8d8bef9SDimitry Andric   FrameSize += getRsaSize();
56e8d8bef9SDimitry Andric   FrameSize = alignTo(FrameSize, TFL->getStackAlign());
57480093f4SDimitry Andric 
58e8d8bef9SDimitry Andric   return FrameSize;
59480093f4SDimitry Andric }
60480093f4SDimitry Andric 
enableMachineScheduler() const61480093f4SDimitry Andric bool VESubtarget::enableMachineScheduler() const { return true; }
62