mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-22 02:33:06 +01:00
2b967460b4
- This patch consists of the bare basic code needed in order to generate some assembly for the z/OS target. - Only the .text and the .bss sections are added for now. - The relevant MCSectionGOFF/Symbol interfaces have been added. This enables us to print out the GOFF machine code sections. - This patch enables us to add simple lit tests wherever possible, and contribute to the testing coverage for the z/OS target - Further improvements and additions will be made in future patches. Reviewed By: tmatheson Differential Revision: https://reviews.llvm.org/D106380
47 lines
1.4 KiB
C++
47 lines
1.4 KiB
C++
//===-- llvm/MC/MCSectionGOFF.h - GOFF Machine Code Sections ----*- C++ -*-===//
|
|
//
|
|
// 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
///
|
|
/// \file
|
|
/// This file declares the MCSectionGOFF class, which contains all of the
|
|
/// necessary machine code sections for the GOFF file format.
|
|
///
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_MC_MCSECTIONGOFF_H
|
|
#define LLVM_MC_MCSECTIONGOFF_H
|
|
|
|
#include "llvm/MC/MCSection.h"
|
|
#include "llvm/Support/raw_ostream.h"
|
|
|
|
namespace llvm {
|
|
|
|
class MCExpr;
|
|
|
|
class MCSectionGOFF final : public MCSection {
|
|
private:
|
|
friend class MCContext;
|
|
MCSectionGOFF(StringRef Name, SectionKind K)
|
|
: MCSection(SV_GOFF, Name, K, nullptr) {}
|
|
|
|
public:
|
|
void PrintSwitchToSection(const MCAsmInfo &MAI, const Triple &T,
|
|
raw_ostream &OS,
|
|
const MCExpr *Subsection) const override {
|
|
OS << "\t.section\t\"" << getName() << "\"\n";
|
|
}
|
|
|
|
bool UseCodeAlign() const override { return false; }
|
|
|
|
bool isVirtualSection() const override { return false; }
|
|
|
|
static bool classof(const MCSection *S) { return S->getVariant() == SV_GOFF; }
|
|
};
|
|
} // end namespace llvm
|
|
|
|
#endif
|