cutter/src/cutter.h

375 lines
9.1 KiB
C
Raw Normal View History

#ifndef CUTTER_H
2017-09-25 12:55:41 +00:00
#define CUTTER_H
2017-10-03 12:42:31 +00:00
// Workaround for compile errors on Windows
2017-03-30 03:07:34 +00:00
#ifdef _WIN32
#include <r_addr_interval_msvc.h>
#endif //_WIN32
2017-03-30 03:07:34 +00:00
#include "r_core.h"
2017-10-03 12:42:31 +00:00
// Workaround for compile errors on Windows
2017-03-30 03:07:34 +00:00
#ifdef _WIN32
#undef min
2017-10-03 12:42:31 +00:00
#undef max
2017-03-30 03:07:34 +00:00
#endif //_WIN32
#include <QMap>
#include <QDebug>
#include <QObject>
#include <QStringList>
#include <QMessageBox>
#include <QJsonDocument>
#define HAVE_LATEST_LIBR2 false
2017-09-25 17:51:49 +00:00
#define CutterRListForeach(list, it, type, x) \
if (list) for (it = list->head; it && ((x=(type*)it->data)); it = it->n)
#define __alert(x) QMessageBox::question (this, "Alert", QString(x), QMessageBox::Ok)
#define __question(x) (QMessageBox::Yes==QMessageBox::question (this, "Alert", QString(x), QMessageBox::Yes| QMessageBox::No))
2017-09-25 12:55:41 +00:00
#define APPNAME "Cutter"
#define CUTTER_VERSION "1.0"
2017-09-25 12:55:41 +00:00
#define Core() (CutterCore::getInstance())
2017-10-03 18:38:34 +00:00
typedef ut64 RVA;
#define RVA_INVALID UT64_MAX
2017-04-09 18:42:45 +00:00
class RCoreLocked
{
2017-04-09 19:55:06 +00:00
RCore *core;
2017-04-09 18:42:45 +00:00
public:
2017-04-09 19:55:06 +00:00
explicit RCoreLocked(RCore *core);
RCoreLocked(const RCoreLocked &) = delete;
RCoreLocked &operator=(const RCoreLocked &) = delete;
RCoreLocked(RCoreLocked &&);
~RCoreLocked();
2017-04-09 19:55:06 +00:00
operator RCore *() const;
RCore *operator->() const;
2017-10-03 18:38:34 +00:00
RVA seek(RVA offset);
RVA getSeek();
};
inline QString RAddressString(RVA addr)
{
return QString::asprintf("%#010llx", addr);
}
inline QString RSizeString(RVA size)
{
return QString::asprintf("%lld", size);
}
struct FunctionDescription
{
RVA offset;
RVA size;
QString name;
bool contains(RVA addr) const { return addr >= offset && addr < offset + size; }
};
struct ImportDescription
{
RVA plt;
int ordinal;
QString bind;
QString type;
QString name;
};
struct ExportDescription
{
RVA vaddr;
RVA paddr;
RVA size;
QString type;
QString name;
QString flag_name;
};
struct SymbolDescription
{
RVA vaddr;
QString bind;
QString type;
QString name;
};
struct CommentDescription
{
RVA offset;
QString name;
};
struct RelocDescription
{
RVA vaddr;
RVA paddr;
QString type;
QString name;
};
struct StringDescription
{
RVA vaddr;
QString string;
};
struct FlagspaceDescription
{
QString name;
};
struct FlagDescription
{
RVA offset;
RVA size;
QString name;
};
struct SectionDescription
{
RVA vaddr;
RVA paddr;
RVA size;
RVA vsize;
QString name;
QString flags;
};
struct EntrypointDescription
{
RVA vaddr;
RVA paddr;
RVA baddr;
RVA laddr;
RVA haddr;
QString type;
};
struct XrefDescription
2017-06-07 10:56:55 +00:00
{
RVA from;
2017-11-27 16:05:10 +00:00
QString from_str;
2017-06-07 10:56:55 +00:00
RVA to;
2017-11-27 16:05:10 +00:00
QString to_str;
2017-06-07 10:56:55 +00:00
QString type;
};
struct RBinPluginDescription
{
QString name;
QString description;
QString license;
QString type;
};
Q_DECLARE_METATYPE(FunctionDescription)
Q_DECLARE_METATYPE(ImportDescription)
Q_DECLARE_METATYPE(ExportDescription)
Q_DECLARE_METATYPE(SymbolDescription)
Q_DECLARE_METATYPE(CommentDescription)
Q_DECLARE_METATYPE(RelocDescription)
Q_DECLARE_METATYPE(StringDescription)
Q_DECLARE_METATYPE(FlagspaceDescription)
Q_DECLARE_METATYPE(FlagDescription)
Q_DECLARE_METATYPE(XrefDescription)
Q_DECLARE_METATYPE(EntrypointDescription)
Q_DECLARE_METATYPE(RBinPluginDescription)
2017-09-25 12:55:41 +00:00
class CutterCore: public QObject
{
Q_OBJECT
2017-10-09 18:08:35 +00:00
friend class ccClass;
public:
2017-09-25 12:55:41 +00:00
explicit CutterCore(QObject *parent = 0);
~CutterCore();
static CutterCore *getInstance();
2017-10-09 18:08:35 +00:00
/* Getters */
2017-09-25 12:55:41 +00:00
RVA getOffset() const { return core_->offset; }
int getCycloComplex(ut64 addr);
int getFcnSize(ut64 addr);
int fcnCyclomaticComplexity(ut64 addr);
int fcnBasicBlockCount(ut64 addr);
int fcnEndBbs(RVA addr);
2017-10-09 18:08:35 +00:00
static QString sanitizeStringForCommand(QString s);
QString cmd(const QString &str);
QJsonDocument cmdj(const QString &str);
QStringList cmdList(const QString &str) { auto l = cmd(str).split("\n"); l.removeAll(""); return l; }
void renameFunction(QString prev_name, QString new_name);
2017-11-27 08:22:52 +00:00
void renameFlag(QString old_name, QString new_name);
void setComment(RVA addr, const QString &cmt);
void delComment(ut64 addr);
void setImmediateBase(const QString &r2BaseName, RVA offset = RVA_INVALID);
void setOptions(QString key);
bool loadFile(QString path, uint64_t loadaddr = 0LL, uint64_t mapaddr = 0LL, bool rw = false, int va = 0, int idx = 0, bool loadbin = false, const QString &forceBinPlugin = nullptr);
bool tryFile(QString path, bool rw);
void analyze(int level, QList<QString> advanced);
2017-10-16 19:00:47 +00:00
// Seek functions
void seek(QString addr);
void seek(ut64 offset);
2017-10-16 19:00:47 +00:00
void seekPrev();
void seekNext();
RVA getOffset();
RVA prevOpAddr(RVA startAddr, int count);
RVA nextOpAddr(RVA startAddr, int count);
// Disassembly/Graph/Hexdump/Pseudocode view priority
enum class MemoryWidgetType { Disassembly, Graph, Hexdump, Pseudocode };
MemoryWidgetType getMemoryWidgetPriority() const { return memoryWidgetPriority; }
void setMemoryWidgetPriority(MemoryWidgetType type) { memoryWidgetPriority = type; }
void triggerRaisePrioritizedMemoryWidget() { emit raisePrioritizedMemoryWidget(memoryWidgetPriority); }
2017-10-22 10:21:44 +00:00
ut64 math(const QString &expr);
2017-04-09 19:55:06 +00:00
QString itoa(ut64 num, int rdx = 16);
2017-10-09 18:08:35 +00:00
/* Config related */
void setConfig(const QString &k, const QString &v);
void setConfig(const QString &k, int v);
void setConfig(const QString &k, bool v);
void setConfig(const QString &k, const char *v) { setConfig(k, QString(v)); }
2017-09-02 08:17:48 +00:00
int getConfigi(const QString &k);
bool getConfigb(const QString &k);
2017-09-02 08:17:48 +00:00
QString getConfig(const QString &k);
QString assemble(const QString &code);
QString disassemble(const QString &hex);
2017-06-07 15:48:36 +00:00
QString disassembleSingleInstruction(RVA addr);
void setDefaultCPU();
2017-04-13 14:24:23 +00:00
void setCPU(QString arch, QString cpu, int bits, bool temporary = false);
2017-04-09 19:55:06 +00:00
RAnalFunction *functionAt(ut64 addr);
QString cmdFunctionAt(QString addr);
QString cmdFunctionAt(RVA addr);
2017-10-09 18:08:35 +00:00
QString createFunctionAt(RVA addr, QString name);
void markString(RVA addr);
2017-10-09 18:08:35 +00:00
/* SDB */
QList<QString> sdbList(QString path);
QList<QString> sdbListKeys(QString path);
QString sdbGet(QString path, QString key);
bool sdbSet(QString path, QString key, QString val);
int get_size();
ulong get_baddr();
QList<QList<QString>> get_exec_sections();
QString getOffsetInfo(QString addr);
2017-11-28 11:56:38 +00:00
RVA getOffsetJump(RVA addr);
QString getDecompiledCode(RVA addr);
QString getDecompiledCode(QString addr);
QString getFileInfo();
QStringList getStats();
QString getSimpleGraph(QString function);
QString binStart;
QString binEnd;
void getOpcodes();
QList<QString> opcodes;
QList<QString> regs;
void setSettings();
void loadPDB(const QString &file);
QList<RVA> getSeekHistory();
QStringList getAsmPluginNames();
QStringList getAnalPluginNames();
QStringList getProjectNames();
void openProject(const QString &name);
void saveProject(const QString &name);
static bool isProjectNameValid(const QString &name);
const QString &getNotes() const { return notes; }
void setNotes(const QString &notes);
QList<RBinPluginDescription> getRBinPluginDescriptions(const QString &type = nullptr);
QList<FunctionDescription> getAllFunctions();
QList<ImportDescription> getAllImports();
QList<ExportDescription> getAllExports();
QList<SymbolDescription> getAllSymbols();
QList<CommentDescription> getAllComments(const QString &filterType);
QList<RelocDescription> getAllRelocs();
QList<StringDescription> getAllStrings();
QList<FlagspaceDescription> getAllFlagspaces();
QList<FlagDescription> getAllFlags(QString flagspace = NULL);
QList<SectionDescription> getAllSections();
QList<EntrypointDescription> getAllEntrypoint();
QList<XrefDescription> getXRefs(RVA addr, bool to, bool whole_function, const QString &filterType = QString::null);
2017-06-07 10:56:55 +00:00
void addFlag(RVA offset, QString name, RVA size);
void triggerFlagsChanged();
void triggerVarsChanged();
void triggerFunctionRenamed(const QString &prevName, const QString &newName);
void triggerRefreshAll();
void triggerAsmOptionsChanged();
void resetDefaultAsmOptions();
void saveDefaultAsmOptions();
RCoreLocked core() const;
/* fields */
Sdb *db;
signals:
void refreshAll();
void functionRenamed(QString prev_name, QString new_name);
void varsChanged();
void flagsChanged();
void commentsChanged();
void instructionChanged(RVA offset);
void notesChanged(const QString &notes);
void projectSaved(const QString &name);
/*!
* emitted when config regarding disassembly display changes
*/
void asmOptionsChanged();
2017-10-09 18:08:35 +00:00
/*!
* \brief seekChanged is emitted each time radare2 seek value is modified
* \param offset
*/
void seekChanged(RVA offset);
void raisePrioritizedMemoryWidget(CutterCore::MemoryWidgetType type);
public slots:
private:
QString default_arch;
QString default_cpu;
int default_bits;
MemoryWidgetType memoryWidgetPriority;
QString notes;
RCore *core_;
};
2017-10-09 18:08:35 +00:00
class ccClass : public CutterCore
{
};
2017-09-25 12:55:41 +00:00
#endif // CUTTER_H