annotate lib/Target/Lanai/LanaiSubtarget.cpp @ 145:9987f868744e

fix CbC_llvm
author mir3636
date Tue, 05 Jun 2018 21:59:34 +0900
parents 1172e4bd9c6f
children c2174574ed3a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
120
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
1 //===- LanaiSubtarget.cpp - Lanai Subtarget Information -----------*- C++ -*-=//
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
2 //
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
3 // The LLVM Compiler Infrastructure
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
4 //
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
5 // This file is distributed under the University of Illinois Open Source
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
6 // License. See LICENSE.TXT for details.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
7 //
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
8 //===----------------------------------------------------------------------===//
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
9 //
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
10 // This file implements the Lanai specific subclass of TargetSubtarget.
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
11 //
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
12 //===----------------------------------------------------------------------===//
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
13
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
14 #include "LanaiSubtarget.h"
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
15
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
16 #include "Lanai.h"
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
17
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
18 #define DEBUG_TYPE "lanai-subtarget"
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
19
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
20 #define GET_SUBTARGETINFO_TARGET_DESC
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
21 #define GET_SUBTARGETINFO_CTOR
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
22 #include "LanaiGenSubtargetInfo.inc"
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
23
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
24 using namespace llvm;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
25
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
26 void LanaiSubtarget::initSubtargetFeatures(StringRef CPU, StringRef FS) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
27 std::string CPUName = CPU;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
28 if (CPUName.empty())
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
29 CPUName = "generic";
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
30
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
31 ParseSubtargetFeatures(CPUName, FS);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
32 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
33
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
34 LanaiSubtarget &LanaiSubtarget::initializeSubtargetDependencies(StringRef CPU,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
35 StringRef FS) {
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
36 initSubtargetFeatures(CPU, FS);
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
37 return *this;
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
38 }
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
39
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
40 LanaiSubtarget::LanaiSubtarget(const Triple &TargetTriple, StringRef Cpu,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
41 StringRef FeatureString, const TargetMachine &TM,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
42 const TargetOptions & /*Options*/,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
43 CodeModel::Model /*CodeModel*/,
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
44 CodeGenOpt::Level /*OptLevel*/)
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
45 : LanaiGenSubtargetInfo(TargetTriple, Cpu, FeatureString),
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
46 FrameLowering(initializeSubtargetDependencies(Cpu, FeatureString)),
1172e4bd9c6f update 4.0.0
mir3636
parents:
diff changeset
47 InstrInfo(), TLInfo(TM, *this), TSInfo() {}