mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-22 18:54:02 +01:00
96c406a887
FaultsMapParser lived in CodeGen and was forcing llvm-objdump to link CodeGen and everything CodeGen depends on. This was previously attempted in r240364 to fix a link failure. The CodeGen dependency was independently added to fix the same link failure, and that ended up being kept. Removing the dependency seems like the correct layering for llvm-objdump. Reviewed By: MaskRay, jhenderson Differential Revision: https://reviews.llvm.org/D95414
79 lines
2.0 KiB
C++
79 lines
2.0 KiB
C++
//===- FaultMaps.h - The "FaultMaps" section --------------------*- 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_CODEGEN_FAULTMAPS_H
|
|
#define LLVM_CODEGEN_FAULTMAPS_H
|
|
|
|
#include "llvm/MC/MCSymbol.h"
|
|
#include "llvm/Support/Endian.h"
|
|
#include <map>
|
|
#include <vector>
|
|
|
|
namespace llvm {
|
|
|
|
class AsmPrinter;
|
|
class MCExpr;
|
|
class raw_ostream;
|
|
|
|
class FaultMaps {
|
|
public:
|
|
enum FaultKind {
|
|
FaultingLoad = 1,
|
|
FaultingLoadStore,
|
|
FaultingStore,
|
|
FaultKindMax
|
|
};
|
|
|
|
explicit FaultMaps(AsmPrinter &AP);
|
|
|
|
static const char *faultTypeToString(FaultKind);
|
|
|
|
void recordFaultingOp(FaultKind FaultTy, const MCSymbol *FaultingLabel,
|
|
const MCSymbol *HandlerLabel);
|
|
void serializeToFaultMapSection();
|
|
void reset() {
|
|
FunctionInfos.clear();
|
|
}
|
|
|
|
private:
|
|
static const char *WFMP;
|
|
|
|
struct FaultInfo {
|
|
FaultKind Kind = FaultKindMax;
|
|
const MCExpr *FaultingOffsetExpr = nullptr;
|
|
const MCExpr *HandlerOffsetExpr = nullptr;
|
|
|
|
FaultInfo() = default;
|
|
|
|
explicit FaultInfo(FaultMaps::FaultKind Kind, const MCExpr *FaultingOffset,
|
|
const MCExpr *HandlerOffset)
|
|
: Kind(Kind), FaultingOffsetExpr(FaultingOffset),
|
|
HandlerOffsetExpr(HandlerOffset) {}
|
|
};
|
|
|
|
using FunctionFaultInfos = std::vector<FaultInfo>;
|
|
|
|
// We'd like to keep a stable iteration order for FunctionInfos to help
|
|
// FileCheck based testing.
|
|
struct MCSymbolComparator {
|
|
bool operator()(const MCSymbol *LHS, const MCSymbol *RHS) const {
|
|
return LHS->getName() < RHS->getName();
|
|
}
|
|
};
|
|
|
|
std::map<const MCSymbol *, FunctionFaultInfos, MCSymbolComparator>
|
|
FunctionInfos;
|
|
AsmPrinter &AP;
|
|
|
|
void emitFunctionInfo(const MCSymbol *FnLabel, const FunctionFaultInfos &FFI);
|
|
};
|
|
|
|
} // end namespace llvm
|
|
|
|
#endif // LLVM_CODEGEN_FAULTMAPS_H
|