0

我的 pintool 中有这个全局变量,我想在指令(我的检测函数)中获取它的内容。

UINT32 windowCnt=0;

LOCALFUN VOID Instruction(INS ins, VOID *v)
{

    const AFUNPTR InsRefFun = ((wcount % 2)==0 ? (AFUNPTR) InsRef_Skip : (AFUNPTR) InsRef);



    INS_InsertIfCall(
       ins, IPOINT_BEFORE, (AFUNPTR)InsRefFun,
       IARG_THREAD_ID,
       IARG_INST_PTR,
       IARG_END);
  ...
}

我怎样才能做到这一点?我已经尝试过 GLOBALVAR、LOCALVAR、const 和 static,但没有任何东西给我正确的值。

4

1 回答 1

0

静态全局变量(在文件范围内)应该可以工作:

static UINT32 foo = 0;

否则,您可以使用INS_AddInstrumentFunction的第二个参数:

int main(int argc, char * argv[])
{
    // Initialize pin
    if (PIN_Init(argc, argv)) return Usage();

    UINT32 foo = 0;

    // Register Instruction to be called to instrument instructions
    INS_AddInstrumentFunction(Instruction, &foo);

    // Register Fini to be called when the application exits
    PIN_AddFiniFunction(Fini, 0);

    // Start the program, never returns
    PIN_StartProgram();

    return 0;
}

在您的仪器功能中,还有一些东西:

// Pin calls this function every time a new instruction is encountered
VOID Instruction(INS ins, VOID *v)
{
    if(v == NULL)
        return;

    UINT32 myfoo = *((UINT32*)v); //in c++: myFoo = *reinterptet_cast<UINT32*>(v)

    // Insert a call to doSomething before every instruction, no arguments are passed
    INS_InsertCall(ins, IPOINT_BEFORE, (AFUNPTR)doSomething, IARG_END);
}
于 2016-11-24T18:14:45.777 回答