[llvm] [SystemZ][z/OS] Simplify the GOFF section handling (PR #101068)
Kai Nacke via llvm-commits
llvm-commits at lists.llvm.org
Mon Jul 29 12:17:36 PDT 2024
https://github.com/redstar created https://github.com/llvm/llvm-project/pull/101068
The z/OS part of the backend makes use of subsections. This change simplifies the handling:
- Removes the parent section and subsectionid from the factory method in MCContext
- Changes all calls to the createGOFFSection() function
- The PPA1 is emitted into a subsection of .text
- The only instance of PPA2 is directly emitted into .text
- The tests for PPA1 and PPA2 are updated
>From 25e3357db7673ff70062b537c98506ff3cbd6f2c Mon Sep 17 00:00:00 2001
From: Kai Nacke <kai.peter.nacke at ibm.com>
Date: Mon, 29 Jul 2024 14:57:28 -0400
Subject: [PATCH] [SystemZ][z/OS] Simplify the section handling
The z/OS part of the backend makes use of subsections. This change simplifies the handling:
- Removes the parent section and subsectionid from the factory method in MCContext
- Changes all calls to the createGOFFSection() function
- The PPA1 is emitted into a subsection of .text
- The only instance of PPA2 is directly emitted into .text
- The tests for PPA1 and PPA2 are updated
---
llvm/include/llvm/BinaryFormat/GOFF.h | 1 -
llvm/include/llvm/MC/MCContext.h | 3 +-
llvm/include/llvm/MC/MCObjectFileInfo.h | 4 --
llvm/include/llvm/MC/MCSectionGOFF.h | 17 +++-----
.../CodeGen/TargetLoweringObjectFileImpl.cpp | 5 +--
llvm/lib/MC/MCContext.cpp | 8 ++--
llvm/lib/MC/MCObjectFileInfo.cpp | 17 +++-----
llvm/lib/Target/SystemZ/SystemZAsmPrinter.cpp | 9 ++--
llvm/test/CodeGen/SystemZ/zos-ppa1.ll | 42 +++++++++++++++++++
llvm/test/CodeGen/SystemZ/zos-ppa2.ll | 36 ++++++++--------
llvm/test/MC/GOFF/ppa1.ll | 35 ----------------
11 files changed, 83 insertions(+), 94 deletions(-)
create mode 100644 llvm/test/CodeGen/SystemZ/zos-ppa1.ll
delete mode 100644 llvm/test/MC/GOFF/ppa1.ll
diff --git a/llvm/include/llvm/BinaryFormat/GOFF.h b/llvm/include/llvm/BinaryFormat/GOFF.h
index 443bcfc9479a8..f1a30e41b736b 100644
--- a/llvm/include/llvm/BinaryFormat/GOFF.h
+++ b/llvm/include/llvm/BinaryFormat/GOFF.h
@@ -167,7 +167,6 @@ enum ENDEntryPointRequest : uint8_t {
// \brief Subsections of the primary C_CODE section in the object file.
enum SubsectionKind : uint8_t {
SK_PPA1 = 2,
- SK_PPA2 = 4,
};
} // end namespace GOFF
diff --git a/llvm/include/llvm/MC/MCContext.h b/llvm/include/llvm/MC/MCContext.h
index 57ba40f7ac26f..4f7290d5cd538 100644
--- a/llvm/include/llvm/MC/MCContext.h
+++ b/llvm/include/llvm/MC/MCContext.h
@@ -606,8 +606,7 @@ class MCContext {
unsigned Flags,
unsigned EntrySize);
- MCSectionGOFF *getGOFFSection(StringRef Section, SectionKind Kind,
- MCSection *Parent, uint32_t Subsection = 0);
+ MCSectionGOFF *getGOFFSection(StringRef Section, SectionKind Kind);
MCSectionCOFF *getCOFFSection(StringRef Section, unsigned Characteristics,
StringRef COMDATSymName, int Selection,
diff --git a/llvm/include/llvm/MC/MCObjectFileInfo.h b/llvm/include/llvm/MC/MCObjectFileInfo.h
index dda3e8a020f3a..b331aff2923f7 100644
--- a/llvm/include/llvm/MC/MCObjectFileInfo.h
+++ b/llvm/include/llvm/MC/MCObjectFileInfo.h
@@ -226,8 +226,6 @@ class MCObjectFileInfo {
MCSection *GLJMPSection = nullptr;
// GOFF specific sections.
- MCSection *PPA1Section = nullptr;
- MCSection *PPA2Section = nullptr;
MCSection *PPA2ListSection = nullptr;
MCSection *ADASection = nullptr;
MCSection *IDRLSection = nullptr;
@@ -433,8 +431,6 @@ class MCObjectFileInfo {
MCSection *getGLJMPSection() const { return GLJMPSection; }
// GOFF specific sections.
- MCSection *getPPA1Section() const { return PPA1Section; }
- MCSection *getPPA2Section() const { return PPA2Section; }
MCSection *getPPA2ListSection() const { return PPA2ListSection; }
MCSection *getADASection() const { return ADASection; }
MCSection *getIDRLSection() const { return IDRLSection; }
diff --git a/llvm/include/llvm/MC/MCSectionGOFF.h b/llvm/include/llvm/MC/MCSectionGOFF.h
index 11c0f95364037..2d6acfd94172d 100644
--- a/llvm/include/llvm/MC/MCSectionGOFF.h
+++ b/llvm/include/llvm/MC/MCSectionGOFF.h
@@ -15,7 +15,6 @@
#ifndef LLVM_MC_MCSECTIONGOFF_H
#define LLVM_MC_MCSECTIONGOFF_H
-#include "llvm/BinaryFormat/GOFF.h"
#include "llvm/MC/MCSection.h"
#include "llvm/Support/raw_ostream.h"
@@ -25,26 +24,22 @@ class MCExpr;
class MCSectionGOFF final : public MCSection {
private:
- MCSection *Parent;
- uint32_t Subsection;
-
friend class MCContext;
- MCSectionGOFF(StringRef Name, SectionKind K, MCSection *P, uint32_t Sub)
- : MCSection(SV_GOFF, Name, K.isText(), /*IsVirtual=*/false, nullptr),
- Parent(P), Subsection(Sub) {}
+ MCSectionGOFF(StringRef Name, SectionKind K)
+ : MCSection(SV_GOFF, Name, K.isText(), /*IsVirtual=*/false, nullptr) {}
public:
void printSwitchToSection(const MCAsmInfo &MAI, const Triple &T,
raw_ostream &OS,
- uint32_t /*Subsection*/) const override {
+ uint32_t Subsection) const override {
OS << "\t.section\t\"" << getName() << "\"\n";
+ if (Subsection) {
+ OS << "\t.subsection\t" << Subsection << '\n';
+ }
}
bool useCodeAlign() const override { return false; }
- MCSection *getParent() const { return Parent; }
- uint32_t getSubsection() const { return Subsection; }
-
static bool classof(const MCSection *S) { return S->getVariant() == SV_GOFF; }
};
} // end namespace llvm
diff --git a/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp b/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp
index 0d3e4ba5662e0..7c529fbdab366 100644
--- a/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp
+++ b/llvm/lib/CodeGen/TargetLoweringObjectFileImpl.cpp
@@ -2726,15 +2726,14 @@ MCSection *TargetLoweringObjectFileGOFF::getExplicitSectionGlobal(
MCSection *TargetLoweringObjectFileGOFF::getSectionForLSDA(
const Function &F, const MCSymbol &FnSym, const TargetMachine &TM) const {
std::string Name = ".gcc_exception_table." + F.getName().str();
- return getContext().getGOFFSection(Name, SectionKind::getData(), nullptr, 0);
+ return getContext().getGOFFSection(Name, SectionKind::getData());
}
MCSection *TargetLoweringObjectFileGOFF::SelectSectionForGlobal(
const GlobalObject *GO, SectionKind Kind, const TargetMachine &TM) const {
auto *Symbol = TM.getSymbol(GO);
if (Kind.isBSS())
- return getContext().getGOFFSection(Symbol->getName(), SectionKind::getBSS(),
- nullptr, 0);
+ return getContext().getGOFFSection(Symbol->getName(), SectionKind::getBSS());
return getContext().getObjectFileInfo()->getTextSection();
}
diff --git a/llvm/lib/MC/MCContext.cpp b/llvm/lib/MC/MCContext.cpp
index 228c4fb03a276..b2cebfaa1725f 100644
--- a/llvm/lib/MC/MCContext.cpp
+++ b/llvm/lib/MC/MCContext.cpp
@@ -672,9 +672,7 @@ MCContext::getELFUniqueIDForEntsize(StringRef SectionName, unsigned Flags,
: std::nullopt;
}
-MCSectionGOFF *MCContext::getGOFFSection(StringRef Section, SectionKind Kind,
- MCSection *Parent,
- uint32_t Subsection) {
+MCSectionGOFF *MCContext::getGOFFSection(StringRef Section, SectionKind Kind) {
// Do the lookup. If we don't have a hit, return a new section.
auto IterBool =
GOFFUniquingMap.insert(std::make_pair(Section.str(), nullptr));
@@ -683,8 +681,8 @@ MCSectionGOFF *MCContext::getGOFFSection(StringRef Section, SectionKind Kind,
return Iter->second;
StringRef CachedName = Iter->first;
- MCSectionGOFF *GOFFSection = new (GOFFAllocator.Allocate())
- MCSectionGOFF(CachedName, Kind, Parent, Subsection);
+ MCSectionGOFF *GOFFSection =
+ new (GOFFAllocator.Allocate()) MCSectionGOFF(CachedName, Kind);
Iter->second = GOFFSection;
allocInitialFragment(*GOFFSection);
return GOFFSection;
diff --git a/llvm/lib/MC/MCObjectFileInfo.cpp b/llvm/lib/MC/MCObjectFileInfo.cpp
index 6dadd9752646f..d879e51a18ae7 100644
--- a/llvm/lib/MC/MCObjectFileInfo.cpp
+++ b/llvm/lib/MC/MCObjectFileInfo.cpp
@@ -546,18 +546,11 @@ void MCObjectFileInfo::initELFMCObjectFileInfo(const Triple &T, bool Large) {
}
void MCObjectFileInfo::initGOFFMCObjectFileInfo(const Triple &T) {
- TextSection = Ctx->getGOFFSection(".text", SectionKind::getText(), nullptr);
- BSSSection = Ctx->getGOFFSection(".bss", SectionKind::getBSS(), nullptr);
- PPA1Section = Ctx->getGOFFSection(".ppa1", SectionKind::getMetadata(),
- TextSection, GOFF::SK_PPA1);
- PPA2Section = Ctx->getGOFFSection(".ppa2", SectionKind::getMetadata(),
- TextSection, GOFF::SK_PPA2);
-
- PPA2ListSection =
- Ctx->getGOFFSection(".ppa2list", SectionKind::getData(), nullptr);
-
- ADASection = Ctx->getGOFFSection(".ada", SectionKind::getData(), nullptr);
- IDRLSection = Ctx->getGOFFSection("B_IDRL", SectionKind::getData(), nullptr);
+ TextSection = Ctx->getGOFFSection(".text", SectionKind::getText());
+ BSSSection = Ctx->getGOFFSection(".bss", SectionKind::getBSS());
+ PPA2ListSection = Ctx->getGOFFSection(".ppa2list", SectionKind::getData());
+ ADASection = Ctx->getGOFFSection(".ada", SectionKind::getData());
+ IDRLSection = Ctx->getGOFFSection("B_IDRL", SectionKind::getData());
}
void MCObjectFileInfo::initCOFFMCObjectFileInfo(const Triple &T) {
diff --git a/llvm/lib/Target/SystemZ/SystemZAsmPrinter.cpp b/llvm/lib/Target/SystemZ/SystemZAsmPrinter.cpp
index 3d025a99b3d83..b5fa3c79512ec 100644
--- a/llvm/lib/Target/SystemZ/SystemZAsmPrinter.cpp
+++ b/llvm/lib/Target/SystemZ/SystemZAsmPrinter.cpp
@@ -19,6 +19,7 @@
#include "TargetInfo/SystemZTargetInfo.h"
#include "llvm/ADT/StringExtras.h"
#include "llvm/BinaryFormat/ELF.h"
+#include "llvm/BinaryFormat/GOFF.h"
#include "llvm/CodeGen/MachineModuleInfoImpls.h"
#include "llvm/CodeGen/TargetLoweringObjectFileImpl.h"
#include "llvm/IR/Mangler.h"
@@ -1124,7 +1125,8 @@ void SystemZAsmPrinter::emitFunctionBodyEnd() {
OutStreamer->emitLabel(FnEndSym);
OutStreamer->pushSection();
- OutStreamer->switchSection(getObjFileLowering().getPPA1Section());
+ OutStreamer->switchSection(getObjFileLowering().getTextSection(),
+ GOFF::SK_PPA1);
emitPPA1(FnEndSym);
OutStreamer->popSection();
@@ -1428,8 +1430,6 @@ void SystemZAsmPrinter::emitStartOfAsmFile(Module &M) {
}
void SystemZAsmPrinter::emitPPA2(Module &M) {
- OutStreamer->pushSection();
- OutStreamer->switchSection(getObjFileLowering().getPPA2Section());
MCContext &OutContext = OutStreamer->getContext();
// Make CELQSTRT symbol.
const char *StartSymbolName = "CELQSTRT";
@@ -1532,8 +1532,9 @@ void SystemZAsmPrinter::emitPPA2(Module &M) {
OutStreamer->emitInt16(0x0000); // Service level string length.
- // The binder requires that the offset to the PPA2 be emitted in a different,
+ // The runtime requires that the offset to the PPA2 be emitted in a different,
// specially-named section.
+ OutStreamer->pushSection();
OutStreamer->switchSection(getObjFileLowering().getPPA2ListSection());
// Emit 8 byte alignment.
// Emit pointer to PPA2 label.
diff --git a/llvm/test/CodeGen/SystemZ/zos-ppa1.ll b/llvm/test/CodeGen/SystemZ/zos-ppa1.ll
new file mode 100644
index 0000000000000..28e9b7b7343f8
--- /dev/null
+++ b/llvm/test/CodeGen/SystemZ/zos-ppa1.ll
@@ -0,0 +1,42 @@
+; RUN: llc -mtriple s390x-ibm-zos < %s | FileCheck %s
+
+; CHECK: L#EPM_void_test_0: * @void_test
+; CHECK-NEXT: * XPLINK Routine Layout Entry
+; CHECK-NEXT: .long 12779717 * Eyecatcher 0x00C300C500C500
+; CHECK-NEXT: .short 197
+; CHECK-NEXT: .byte 0
+; CHECK-NEXT: .byte 241 * Mark Type C'1'
+; CHECK-NEXT: .long L#PPA1_void_test_0-L#EPM_void_test_0 * Offset to PPA1
+; CHECK-NEXT: .long 8 * DSA Size 0x0
+; CHECK-NEXT: * Entry Flags
+; CHECK-NEXT: * Bit 1: 1 = Leaf function
+; CHECK-NEXT: * Bit 2: 0 = Does not use alloca
+;
+; CHECK: L#func_end0:
+; CHECK-NEXT: .section ".text"
+; CHECK-NEXT: .subsection 2
+; CHECK-NEXT: L#PPA1_void_test_0: * PPA1
+; CHECK-NEXT: .byte 2 * Version
+; CHECK-NEXT: .byte 206 * LE Signature X'CE'
+; CHECK-NEXT: .short 0 * Saved GPR Mask
+; CHECK-NEXT: .long L#PPA2-L#PPA1_void_test_0 * Offset to PPA2
+; CHECK-NEXT: .byte 128 * PPA1 Flags 1
+; CHECK-NEXT: * Bit 0: 1 = 64-bit DSA
+; CHECK-NEXT: .byte 128 * PPA1 Flags 2
+; CHECK-NEXT: * Bit 0: 1 = External procedure
+; CHECK-NEXT: * Bit 3: 0 = STACKPROTECT is not enabled
+; CHECK-NEXT: .byte 0 * PPA1 Flags 3
+; CHECK-NEXT: .byte 129 * PPA1 Flags 4
+; CHECK-NEXT: * Bit 7: 1 = Name Length and Name
+; CHECK-NEXT: .short 0 * Length/4 of Parms
+; CHECK-NEXT: .long L#func_end0-L#EPM_void_test_0 * Length of Code
+; CHECK-NEXT: .short 9 * Length of Name
+; CHECK-NEXT: .ascii "\245\226\211\204m\243\205\242\243" * Name of Function
+; CHECK-NEXT: .space 1
+; CHECK-NEXT: .long L#EPM_void_test_0-L#PPA1_void_test_0
+; CHECK-NEXT: .section ".text"
+; CHECK-NEXT: * -- End function
+define void @void_test() {
+entry:
+ ret void
+}
diff --git a/llvm/test/CodeGen/SystemZ/zos-ppa2.ll b/llvm/test/CodeGen/SystemZ/zos-ppa2.ll
index 07025091fb240..9c8f7fff54956 100644
--- a/llvm/test/CodeGen/SystemZ/zos-ppa2.ll
+++ b/llvm/test/CodeGen/SystemZ/zos-ppa2.ll
@@ -1,22 +1,24 @@
; RUN: llc -mtriple s390x-ibm-zos -mcpu=z15 -asm-verbose=true < %s | FileCheck %s
-; CHECK: .section ".ppa2"
-; CHECK: L#PPA2:
-; CHECK: .byte 3
-; CHECK: .byte 231
-; CHECK: .byte 34
-; CHECK: .byte 4
-; CHECK: .long CELQSTRT-L#PPA2
-; CHECK: .long 0
-; CHECK: .long L#DVS-L#PPA2
-; CHECK: .long 0
-; CHECK: .byte 129
-; CHECK: .byte 0
-; CHECK: .short 0
-; CHECK: L#DVS:
-; CHECK: .ascii "\361\371\367\360\360\361\360\361\360\360\360\360\360\360"
-; CHECK: .short 0
-; CHECK: .quad L#PPA2-CELQSTRT * A(PPA2-CELQSTRT)
+; CHECK: .section ".text"
+; CHECK-NEXT: L#PPA2:
+; CHECK-NEXT: .byte 3
+; CHECK-NEXT: .byte 231
+; CHECK-NEXT: .byte 34
+; CHECK-NEXT: .byte 4
+; CHECK-NEXT: .long CELQSTRT-L#PPA2
+; CHECK-NEXT: .long 0
+; CHECK-NEXT: .long L#DVS-L#PPA2
+; CHECK-NEXT: .long 0
+; CHECK-NEXT: .byte 129
+; CHECK-NEXT: .byte 0
+; CHECK-NEXT: .short 0
+; CHECK-NEXT: L#DVS:
+; CHECK-NEXT: .ascii "\361\371\367\360\360\361\360\361\360\360\360\360\360\360"
+; CHECK-NEXT: .ascii "\362\360\360\360\360\360"
+; CHECK-NEXT: .short 0
+; CHECK-NEXT: .section ".ppa2list"
+; CHECK-NEXT: .quad L#PPA2-CELQSTRT * A(PPA2-CELQSTRT)
; CHECK: L#PPA1_void_test_0:
; CHECK: .long L#PPA2-L#PPA1_void_test_0 * Offset to PPA2
; CHECK: .section "B_IDRL"
diff --git a/llvm/test/MC/GOFF/ppa1.ll b/llvm/test/MC/GOFF/ppa1.ll
deleted file mode 100644
index 13971c7ec8e72..0000000000000
--- a/llvm/test/MC/GOFF/ppa1.ll
+++ /dev/null
@@ -1,35 +0,0 @@
-; RUN: llc -mtriple s390x-ibm-zos < %s | FileCheck %s
-; REQUIRES: systemz-registered-target
-
-; CHECK: L#EPM_void_test_0: * @void_test
-; CHECK: * XPLINK Routine Layout Entry
-; CHECK: .long 12779717 * Eyecatcher 0x00C300C500C500
-; CHECK: .short 197
-; CHECK: .byte 0
-; CHECK: .byte 241 * Mark Type C'1'
-; CHECK: .long 8 * DSA Size 0x0
-; CHECK: * Entry Flags
-; CHECK: * Bit 1: 1 = Leaf function
-; CHECK: * Bit 2: 0 = Does not use alloca
-; CHECK: L#func_end0:
-; CHECK: .section ".ppa1"
-; CHECK: L#PPA1_void_test_0: * PPA1
-; CHECK: .byte 2 * Version
-; CHECK: .byte 206 * LE Signature X'CE'
-; CHECK: .short 0 * Saved GPR Mask
-; CHECK: .byte 128 * PPA1 Flags 1
-; CHECK: * Bit 0: 1 = 64-bit DSA
-; CHECK: .byte 128 * PPA1 Flags 2
-; CHECK: * Bit 0: 1 = External procedure
-; CHECK: * Bit 3: 0 = STACKPROTECT is not enabled
-; CHECK: .byte 0 * PPA1 Flags 3
-; CHECK: .byte 129 * PPA1 Flags 4
-; CHECK: .short 0 * Length/4 of Parms
-; CHECK: .long L#func_end0-L#EPM_void_test_0 * Length of Code
-; CHECK: .long L#EPM_void_test_0-L#PPA1_void_test_0
-; CHECK: .section ".text"
-; CHECK: * -- End function
-define void @void_test() {
-entry:
- ret void
-}
More information about the llvm-commits
mailing list