mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-22 18:54:02 +01:00
b94988cc08
This change was originally landed in: 5000a1b4b9edeb9e994f2a5b36da8d48599bea49 It was reverted in: 061e071d8c9b98526f35cad55a918a4f1615afd4 This change adds support for a new WASM_SEG_FLAG_STRINGS flag in the object format which works in a similar fashion to SHF_STRINGS in the ELF world. Unlike the ELF linker this support is currently limited: - No support for SHF_MERGE (non-string merging) - Always do full tail merging ("lo" can be merged with "hello") - Only support single byte strings (p2align 0) Like the ELF linker merging is only performed at `-O1` and above. This fixes part of https://bugs.llvm.org/show_bug.cgi?id=48828, although crucially it doesn't not currently support debug sections because they are not represented by data segments (they are custom sections) Differential Revision: https://reviews.llvm.org/D97657
95 lines
3.0 KiB
C++
95 lines
3.0 KiB
C++
//===- MCSectionWasm.h - Wasm 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file declares the MCSectionWasm class.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_MC_MCSECTIONWASM_H
|
|
#define LLVM_MC_MCSECTIONWASM_H
|
|
|
|
#include "llvm/MC/MCSection.h"
|
|
|
|
namespace llvm {
|
|
|
|
class MCSymbol;
|
|
class MCSymbolWasm;
|
|
class StringRef;
|
|
class raw_ostream;
|
|
|
|
/// This represents a section on wasm.
|
|
class MCSectionWasm final : public MCSection {
|
|
unsigned UniqueID;
|
|
|
|
const MCSymbolWasm *Group;
|
|
|
|
// The offset of the MC function/data section in the wasm code/data section.
|
|
// For data relocations the offset is relative to start of the data payload
|
|
// itself and does not include the size of the section header.
|
|
uint64_t SectionOffset = 0;
|
|
|
|
// For data sections, this is the index of of the corresponding wasm data
|
|
// segment
|
|
uint32_t SegmentIndex = 0;
|
|
|
|
// For data sections, whether to use a passive segment
|
|
bool IsPassive = false;
|
|
|
|
// For data sections, bitfield of WasmSegmentFlag
|
|
unsigned SegmentFlags;
|
|
|
|
// The storage of Name is owned by MCContext's WasmUniquingMap.
|
|
friend class MCContext;
|
|
MCSectionWasm(StringRef Name, SectionKind K, unsigned SegmentFlags,
|
|
const MCSymbolWasm *Group, unsigned UniqueID, MCSymbol *Begin)
|
|
: MCSection(SV_Wasm, Name, K, Begin), UniqueID(UniqueID), Group(Group),
|
|
SegmentFlags(SegmentFlags) {}
|
|
|
|
public:
|
|
/// Decides whether a '.section' directive should be printed before the
|
|
/// section name
|
|
bool shouldOmitSectionDirective(StringRef Name, const MCAsmInfo &MAI) const;
|
|
|
|
const MCSymbolWasm *getGroup() const { return Group; }
|
|
unsigned getSegmentFlags() const { return SegmentFlags; }
|
|
|
|
void PrintSwitchToSection(const MCAsmInfo &MAI, const Triple &T,
|
|
raw_ostream &OS,
|
|
const MCExpr *Subsection) const override;
|
|
bool UseCodeAlign() const override;
|
|
bool isVirtualSection() const override;
|
|
|
|
bool isWasmData() const {
|
|
return Kind.isGlobalWriteableData() || Kind.isReadOnly() ||
|
|
Kind.isThreadLocal();
|
|
}
|
|
|
|
bool isUnique() const { return UniqueID != ~0U; }
|
|
unsigned getUniqueID() const { return UniqueID; }
|
|
|
|
uint64_t getSectionOffset() const { return SectionOffset; }
|
|
void setSectionOffset(uint64_t Offset) { SectionOffset = Offset; }
|
|
|
|
uint32_t getSegmentIndex() const { return SegmentIndex; }
|
|
void setSegmentIndex(uint32_t Index) { SegmentIndex = Index; }
|
|
|
|
bool getPassive() const {
|
|
assert(isWasmData());
|
|
return IsPassive;
|
|
}
|
|
void setPassive(bool V = true) {
|
|
assert(isWasmData());
|
|
IsPassive = V;
|
|
}
|
|
static bool classof(const MCSection *S) { return S->getVariant() == SV_Wasm; }
|
|
};
|
|
|
|
} // end namespace llvm
|
|
|
|
#endif
|