annotate lib/Target/MSP430/MSP430Subtarget.cpp @ 121:803732b1fca8

LLVM 5.0
author kono
date Fri, 27 Oct 2017 17:07:41 +0900
parents afa8332a0e37
children c2174574ed3a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 //===-- MSP430Subtarget.cpp - MSP430 Subtarget Information ----------------===//
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 //
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 // The LLVM Compiler Infrastructure
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 //
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 // This file is distributed under the University of Illinois Open Source
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 // License. See LICENSE.TXT for details.
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 //
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 //===----------------------------------------------------------------------===//
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 //
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 // This file implements the MSP430 specific subclass of TargetSubtargetInfo.
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
11 //
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
12 //===----------------------------------------------------------------------===//
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
13
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
14 #include "MSP430Subtarget.h"
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 #include "MSP430.h"
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
16 #include "llvm/Support/TargetRegistry.h"
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
17
77
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
18 using namespace llvm;
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
19
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
20 #define DEBUG_TYPE "msp430-subtarget"
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
21
121
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
22 static cl::opt<MSP430Subtarget::HWMultEnum>
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
23 HWMultModeOption("mhwmult", cl::Hidden,
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
24 cl::desc("Hardware multiplier use mode for MSP430"),
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
25 cl::init(MSP430Subtarget::NoHWMult),
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
26 cl::values(
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
27 clEnumValN(MSP430Subtarget::NoHWMult, "none",
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
28 "Do not use hardware multiplier"),
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
29 clEnumValN(MSP430Subtarget::HWMult16, "16bit",
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
30 "Use 16-bit hardware multiplier"),
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
31 clEnumValN(MSP430Subtarget::HWMult32, "32bit",
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
32 "Use 32-bit hardware multiplier"),
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
33 clEnumValN(MSP430Subtarget::HWMultF5, "f5series",
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
34 "Use F5 series hardware multiplier")));
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
35
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 #define GET_SUBTARGETINFO_TARGET_DESC
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 #define GET_SUBTARGETINFO_CTOR
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
38 #include "MSP430GenSubtargetInfo.inc"
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
39
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
40 void MSP430Subtarget::anchor() { }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
41
95
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 83
diff changeset
42 MSP430Subtarget &
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 83
diff changeset
43 MSP430Subtarget::initializeSubtargetDependencies(StringRef CPU, StringRef FS) {
121
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
44 ExtendedInsts = false;
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
45 HWMultMode = NoHWMult;
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
46
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
47 std::string CPUName = CPU;
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
48 if (CPUName.empty())
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
49 CPUName = "msp430";
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
50
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
51 ParseSubtargetFeatures(CPUName, FS);
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
52
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
53 if (HWMultModeOption != NoHWMult)
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
54 HWMultMode = HWMultModeOption;
803732b1fca8 LLVM 5.0
kono
parents: 95
diff changeset
55
77
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
56 return *this;
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
57 }
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
58
95
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 83
diff changeset
59 MSP430Subtarget::MSP430Subtarget(const Triple &TT, const std::string &CPU,
77
54457678186b LLVM 3.6
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
60 const std::string &FS, const TargetMachine &TM)
83
60c9769439b8 LLVM 3.7
Tatsuki IHA <e125716@ie.u-ryukyu.ac.jp>
parents: 77
diff changeset
61 : MSP430GenSubtargetInfo(TT, CPU, FS), FrameLowering(),
95
afa8332a0e37 LLVM 3.8
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents: 83
diff changeset
62 InstrInfo(initializeSubtargetDependencies(CPU, FS)), TLInfo(TM, *this) {}