mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-21 03:32:21 +00:00
70 lines
2.6 KiB
C
70 lines
2.6 KiB
C
|
//===-- llvm/MC/MCObjectDisassembler.h --------------------------*- C++ -*-===//
|
||
|
//
|
||
|
// The LLVM Compiler Infrastructure
|
||
|
//
|
||
|
// This file is distributed under the University of Illinois Open Source
|
||
|
// License. See LICENSE.TXT for details.
|
||
|
//
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
//
|
||
|
// This file contains the declaration of the MCObjectDisassembler class, which
|
||
|
// can be used to construct an MCModule and an MC CFG from an ObjectFile.
|
||
|
//
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
|
||
|
#ifndef LLVM_MC_MCOBJECTDISASSEMBLER_H
|
||
|
#define LLVM_MC_MCOBJECTDISASSEMBLER_H
|
||
|
|
||
|
namespace llvm {
|
||
|
|
||
|
namespace object {
|
||
|
class ObjectFile;
|
||
|
}
|
||
|
|
||
|
class MCBasicBlock;
|
||
|
class MCDisassembler;
|
||
|
class MCFunction;
|
||
|
class MCInstrAnalysis;
|
||
|
class MCModule;
|
||
|
|
||
|
/// \brief Disassemble an ObjectFile to an MCModule and MCFunctions.
|
||
|
/// This class builds on MCDisassembler to disassemble whole sections, creating
|
||
|
/// MCAtom (MCTextAtom for disassembled sections and MCDataAtom for raw data).
|
||
|
/// It can also be used to create a control flow graph consisting of MCFunctions
|
||
|
/// and MCBasicBlocks.
|
||
|
class MCObjectDisassembler {
|
||
|
const object::ObjectFile &Obj;
|
||
|
const MCDisassembler &Dis;
|
||
|
const MCInstrAnalysis &MIA;
|
||
|
|
||
|
public:
|
||
|
MCObjectDisassembler(const object::ObjectFile &Obj,
|
||
|
const MCDisassembler &Dis,
|
||
|
const MCInstrAnalysis &MIA);
|
||
|
|
||
|
/// \brief Build an MCModule, creating atoms and optionally functions.
|
||
|
/// \param withCFG Also build a CFG by adding MCFunctions to the Module.
|
||
|
/// If withCFG is false, the MCModule built only contains atoms, representing
|
||
|
/// what was found in the object file. If withCFG is true, MCFunctions are
|
||
|
/// created, containing MCBasicBlocks. All text atoms are split to form basic
|
||
|
/// block atoms, which then each back an MCBasicBlock.
|
||
|
MCModule *buildModule(bool withCFG = false);
|
||
|
|
||
|
private:
|
||
|
/// \brief Fill \p Module by creating an atom for each section.
|
||
|
/// This could be made much smarter, using information like symbols, but also
|
||
|
/// format-specific features, like mach-o function_start or data_in_code LCs.
|
||
|
void buildSectionAtoms(MCModule *Module);
|
||
|
|
||
|
/// \brief Enrich \p Module with a CFG consisting of MCFunctions.
|
||
|
/// \param Module An MCModule returned by buildModule, with no CFG.
|
||
|
/// NOTE: Each MCBasicBlock in a MCFunction is backed by a single MCTextAtom.
|
||
|
/// When the CFG is built, contiguous instructions that were previously in a
|
||
|
/// single MCTextAtom will be split in multiple basic block atoms.
|
||
|
void buildCFG(MCModule *Module);
|
||
|
};
|
||
|
|
||
|
}
|
||
|
|
||
|
#endif
|