diff options
| author | Akira Hatanaka <ahatanaka@apple.com> | 2015-11-14 05:20:05 +0000 |
|---|---|---|
| committer | Akira Hatanaka <ahatanaka@apple.com> | 2015-11-14 05:20:05 +0000 |
| commit | bd9fc28444c256bd1ed1e29a59bd938160c60674 (patch) | |
| tree | 905195e51ee810f5d0d601dc8422a872783a529a /llvm/lib/Target/Hexagon/AsmParser | |
| parent | 90717ad7318074ed5069cfbd14e36f10082262ea (diff) | |
| download | bcm5719-llvm-bd9fc28444c256bd1ed1e29a59bd938160c60674.tar.gz bcm5719-llvm-bd9fc28444c256bd1ed1e29a59bd938160c60674.zip | |
[MCTargetAsmParser] Move the member varialbes that reference
MCSubtargetInfo in the subclasses into MCTargetAsmParser and define a
member function getSTI.
This is done in preparation for making changes to shrink the size of
MCRelaxableFragment. (see http://reviews.llvm.org/D14346).
llvm-svn: 253124
Diffstat (limited to 'llvm/lib/Target/Hexagon/AsmParser')
| -rw-r--r-- | llvm/lib/Target/Hexagon/AsmParser/HexagonAsmParser.cpp | 15 |
1 files changed, 7 insertions, 8 deletions
diff --git a/llvm/lib/Target/Hexagon/AsmParser/HexagonAsmParser.cpp b/llvm/lib/Target/Hexagon/AsmParser/HexagonAsmParser.cpp index 3b64ad7cbff..9fccd9afe52 100644 --- a/llvm/lib/Target/Hexagon/AsmParser/HexagonAsmParser.cpp +++ b/llvm/lib/Target/Hexagon/AsmParser/HexagonAsmParser.cpp @@ -76,7 +76,6 @@ class HexagonAsmParser : public MCTargetAsmParser { return static_cast<HexagonTargetStreamer &>(TS); } - MCSubtargetInfo &STI; MCAsmParser &Parser; MCAssembler *Assembler; MCInstrInfo const &MCII; @@ -136,10 +135,9 @@ class HexagonAsmParser : public MCTargetAsmParser { public: HexagonAsmParser(MCSubtargetInfo &_STI, MCAsmParser &_Parser, const MCInstrInfo &MII, const MCTargetOptions &Options) - : MCTargetAsmParser(Options), STI(_STI), Parser(_Parser), + : MCTargetAsmParser(Options, _STI), Parser(_Parser), MCII (MII), MCB(HexagonMCInstrInfo::createBundle()), InBrackets(false) { - setAvailableFeatures( - ComputeAvailableFeatures(_STI.getFeatureBits())); + setAvailableFeatures(ComputeAvailableFeatures(getSTI().getFeatureBits())); MCAsmParserExtension::Initialize(_Parser); @@ -627,10 +625,11 @@ bool HexagonAsmParser::finishBundle(SMLoc IDLoc, MCStreamer &Out) { // Check the bundle for errors. const MCRegisterInfo *RI = getContext().getRegisterInfo(); - HexagonMCChecker Check(MCII, STI, MCB, MCB, *RI); + HexagonMCChecker Check(MCII, getSTI(), MCB, MCB, *RI); - bool CheckOk = HexagonMCInstrInfo::canonicalizePacket(MCII, STI, getContext(), - MCB, &Check); + bool CheckOk = HexagonMCInstrInfo::canonicalizePacket(MCII, getSTI(), + getContext(), MCB, + &Check); while (Check.getNextErrInfo() == true) { unsigned Reg = Check.getErrRegister(); @@ -715,7 +714,7 @@ bool HexagonAsmParser::finishBundle(SMLoc IDLoc, MCStreamer &Out) { // Empty packets are valid yet aren't emitted return false; } - Out.EmitInstruction(MCB, STI); + Out.EmitInstruction(MCB, getSTI()); } else { // If compounding and duplexing didn't reduce the size below // 4 or less we have a packet that is too big. |

