1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
|
//===-- LanaiMCAsmInfo.cpp - Lanai asm properties -----------------------===//
//
// 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
//
//===----------------------------------------------------------------------===//
//
// This file contains the declarations of the LanaiMCAsmInfo properties.
//
//===----------------------------------------------------------------------===//
#include "LanaiMCAsmInfo.h"
#include "llvm/MC/MCExpr.h"
#include "llvm/Support/raw_ostream.h"
#include "llvm/TargetParser/Triple.h"
using namespace llvm;
void LanaiMCAsmInfo::anchor() {}
LanaiMCAsmInfo::LanaiMCAsmInfo(const Triple & /*TheTriple*/,
const MCTargetOptions &Options) {
IsLittleEndian = false;
PrivateGlobalPrefix = ".L";
WeakRefDirective = "\t.weak\t";
ExceptionsType = ExceptionHandling::DwarfCFI;
// Lanai assembly requires ".section" before ".bss"
UsesELFSectionDirectiveForBSS = true;
// Use '!' as comment string to correspond with old toolchain.
CommentString = "!";
// Target supports emission of debugging information.
SupportsDebugInformation = true;
// Set the instruction alignment. Currently used only for address adjustment
// in dwarf generation.
MinInstAlignment = 4;
}
void LanaiMCAsmInfo::printSpecifierExpr(raw_ostream &OS,
const MCSpecifierExpr &Expr) const {
if (Expr.getSpecifier() == 0) {
printExpr(OS, *Expr.getSubExpr());
return;
}
switch (Expr.getSpecifier()) {
default:
llvm_unreachable("Invalid kind!");
case Lanai::S_ABS_HI:
OS << "hi";
break;
case Lanai::S_ABS_LO:
OS << "lo";
break;
}
OS << '(';
printExpr(OS, *Expr.getSubExpr());
OS << ')';
}
|