2011-07-20 19:37:35 +00:00
|
|
|
//===-- MCFunction.h ------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file defines the data structures to hold a CFG reconstructed from
|
|
|
|
// machine code.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2011-09-19 17:56:04 +00:00
|
|
|
#ifndef LLVM_OBJECTDUMP_MCFUNCTION_H
|
|
|
|
#define LLVM_OBJECTDUMP_MCFUNCTION_H
|
|
|
|
|
2011-07-20 19:37:35 +00:00
|
|
|
#include "llvm/ADT/ArrayRef.h"
|
2011-09-19 17:56:04 +00:00
|
|
|
#include "llvm/ADT/DenseSet.h"
|
2011-07-20 19:37:35 +00:00
|
|
|
#include "llvm/MC/MCInst.h"
|
|
|
|
#include <map>
|
|
|
|
|
|
|
|
namespace llvm {
|
|
|
|
|
|
|
|
class MCDisassembler;
|
2011-08-08 18:56:44 +00:00
|
|
|
class MCInstrAnalysis;
|
2011-07-20 19:37:35 +00:00
|
|
|
class MemoryObject;
|
|
|
|
class raw_ostream;
|
|
|
|
|
|
|
|
/// MCDecodedInst - Small container to hold an MCInst and associated info like
|
|
|
|
/// address and size.
|
|
|
|
struct MCDecodedInst {
|
|
|
|
uint64_t Address;
|
|
|
|
uint64_t Size;
|
|
|
|
MCInst Inst;
|
|
|
|
|
2011-09-19 17:56:04 +00:00
|
|
|
MCDecodedInst() {}
|
2011-07-20 19:37:35 +00:00
|
|
|
MCDecodedInst(uint64_t Address, uint64_t Size, MCInst Inst)
|
|
|
|
: Address(Address), Size(Size), Inst(Inst) {}
|
2011-09-19 17:56:04 +00:00
|
|
|
|
|
|
|
bool operator<(const MCDecodedInst &RHS) const {
|
|
|
|
return Address < RHS.Address;
|
|
|
|
}
|
2011-07-20 19:37:35 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/// MCBasicBlock - Consists of multiple MCDecodedInsts and a list of successing
|
|
|
|
/// MCBasicBlocks.
|
|
|
|
class MCBasicBlock {
|
2011-09-19 17:56:04 +00:00
|
|
|
std::vector<MCDecodedInst> Insts;
|
|
|
|
typedef DenseSet<uint64_t> SetTy;
|
2011-07-20 19:37:35 +00:00
|
|
|
SetTy Succs;
|
|
|
|
public:
|
|
|
|
ArrayRef<MCDecodedInst> getInsts() const { return Insts; }
|
|
|
|
|
|
|
|
typedef SetTy::const_iterator succ_iterator;
|
|
|
|
succ_iterator succ_begin() const { return Succs.begin(); }
|
|
|
|
succ_iterator succ_end() const { return Succs.end(); }
|
|
|
|
|
2011-09-19 17:56:04 +00:00
|
|
|
bool contains(uint64_t Addr) const { return Succs.count(Addr); }
|
2011-07-25 23:10:23 +00:00
|
|
|
|
2011-07-20 19:37:35 +00:00
|
|
|
void addInst(const MCDecodedInst &Inst) { Insts.push_back(Inst); }
|
2011-09-19 17:56:04 +00:00
|
|
|
void addSucc(uint64_t Addr) { Succs.insert(Addr); }
|
|
|
|
|
|
|
|
bool operator<(const MCBasicBlock &RHS) const {
|
|
|
|
return Insts.size() < RHS.Insts.size();
|
|
|
|
}
|
2011-07-20 19:37:35 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/// MCFunction - Represents a named function in machine code, containing
|
|
|
|
/// multiple MCBasicBlocks.
|
|
|
|
class MCFunction {
|
|
|
|
const StringRef Name;
|
|
|
|
// Keep BBs sorted by address.
|
2011-09-19 17:56:04 +00:00
|
|
|
typedef std::vector<std::pair<uint64_t, MCBasicBlock> > MapTy;
|
2011-07-20 19:37:35 +00:00
|
|
|
MapTy Blocks;
|
|
|
|
public:
|
|
|
|
MCFunction(StringRef Name) : Name(Name) {}
|
|
|
|
|
|
|
|
// Create an MCFunction from a region of binary machine code.
|
|
|
|
static MCFunction
|
|
|
|
createFunctionFromMC(StringRef Name, const MCDisassembler *DisAsm,
|
|
|
|
const MemoryObject &Region, uint64_t Start, uint64_t End,
|
2011-09-19 17:56:04 +00:00
|
|
|
const MCInstrAnalysis *Ana, raw_ostream &DebugOut,
|
|
|
|
SmallVectorImpl<uint64_t> &Calls);
|
2011-07-20 19:37:35 +00:00
|
|
|
|
|
|
|
typedef MapTy::iterator iterator;
|
|
|
|
iterator begin() { return Blocks.begin(); }
|
|
|
|
iterator end() { return Blocks.end(); }
|
|
|
|
|
|
|
|
StringRef getName() const { return Name; }
|
|
|
|
|
|
|
|
MCBasicBlock &addBlock(uint64_t Address, const MCBasicBlock &BB) {
|
2011-09-19 17:56:04 +00:00
|
|
|
Blocks.push_back(std::make_pair(Address, BB));
|
|
|
|
return Blocks.back().second;
|
2011-07-20 19:37:35 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
2011-09-19 17:56:04 +00:00
|
|
|
|
|
|
|
#endif
|