2015-05-24 00:15:10 +08:00
|
|
|
//===- AArch64TargetStreamer.cpp - AArch64TargetStreamer class ------------===//
|
2014-06-25 00:21:38 +08:00
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2014-06-25 00:21:38 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file implements the AArch64TargetStreamer class.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2015-05-24 00:15:10 +08:00
|
|
|
#include "AArch64TargetStreamer.h"
|
|
|
|
#include "llvm/MC/ConstantPools.h"
|
2019-04-12 15:40:01 +08:00
|
|
|
#include "llvm/MC/MCSection.h"
|
2018-10-27 14:13:06 +08:00
|
|
|
#include "llvm/MC/MCSubtargetInfo.h"
|
2017-01-06 08:30:53 +08:00
|
|
|
|
2014-06-25 00:21:38 +08:00
|
|
|
using namespace llvm;
|
|
|
|
|
|
|
|
//
|
|
|
|
// AArch64TargetStreamer Implemenation
|
|
|
|
//
|
|
|
|
AArch64TargetStreamer::AArch64TargetStreamer(MCStreamer &S)
|
|
|
|
: MCTargetStreamer(S), ConstantPools(new AssemblerConstantPools()) {}
|
|
|
|
|
2017-01-06 08:30:53 +08:00
|
|
|
AArch64TargetStreamer::~AArch64TargetStreamer() = default;
|
2014-06-25 00:21:38 +08:00
|
|
|
|
|
|
|
// The constant pool handling is shared by all AArch64TargetStreamer
|
|
|
|
// implementations.
|
2014-07-19 00:05:14 +08:00
|
|
|
const MCExpr *AArch64TargetStreamer::addConstantPoolEntry(const MCExpr *Expr,
|
2015-11-17 00:25:47 +08:00
|
|
|
unsigned Size,
|
|
|
|
SMLoc Loc) {
|
|
|
|
return ConstantPools->addEntry(Streamer, Expr, Size, Loc);
|
2014-06-25 00:21:38 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void AArch64TargetStreamer::emitCurrentConstantPool() {
|
|
|
|
ConstantPools->emitForCurrentSection(Streamer);
|
|
|
|
}
|
|
|
|
|
|
|
|
// finish() - write out any non-empty assembler constant pools.
|
|
|
|
void AArch64TargetStreamer::finish() { ConstantPools->emitAll(Streamer); }
|
2014-10-23 04:35:57 +08:00
|
|
|
|
2018-07-31 17:26:52 +08:00
|
|
|
void AArch64TargetStreamer::emitInst(uint32_t Inst) {
|
|
|
|
char Buffer[4];
|
|
|
|
|
|
|
|
// We can't just use EmitIntValue here, as that will swap the
|
|
|
|
// endianness on big-endian systems (instructions are always
|
|
|
|
// little-endian).
|
|
|
|
for (unsigned I = 0; I < 4; ++I) {
|
|
|
|
Buffer[I] = uint8_t(Inst);
|
|
|
|
Inst >>= 8;
|
|
|
|
}
|
|
|
|
|
|
|
|
getStreamer().EmitBytes(StringRef(Buffer, 4));
|
|
|
|
}
|
2018-10-27 14:13:06 +08:00
|
|
|
|
|
|
|
namespace llvm {
|
|
|
|
|
|
|
|
MCTargetStreamer *
|
|
|
|
createAArch64ObjectTargetStreamer(MCStreamer &S, const MCSubtargetInfo &STI) {
|
|
|
|
const Triple &TT = STI.getTargetTriple();
|
|
|
|
if (TT.isOSBinFormatELF())
|
|
|
|
return new AArch64TargetELFStreamer(S);
|
|
|
|
if (TT.isOSBinFormatCOFF())
|
|
|
|
return new AArch64TargetWinCOFFStreamer(S);
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
} // end namespace llvm
|