我試圖獲得使用intel引腳的函數參數的值。使用ManualExamples/malloctrace.cpp示例的單參數函數非常簡單。但是,當我嘗試使用多個參數獲取參數值時,我遇到了麻煩。英特爾引腳RTN_InsertCall多個函數參數
例如,試圖捕捉下面的函數的參數值:
void funcA(int a, int b, int c) {
printf("Actual: %i %i %i\n", a,b,c);
}
用下面的PIN碼
VOID funcHandler(CHAR* name, int a, int b, int c) {
printf("Pin: %s %i %i %i\n", name, a, b, c);
}
VOID Image(IMG img, VOID *v) {
RTN funcRtn = RTN_FindByName(img, "funcA");
if (RTN_Valid(funcRtn)) {
RTN_Open(funcRtn);
RTN_InsertCall(funcRtn, IPOINT_BEFORE, (AFUNPTR)funcHandler,
IARG_ADDRINT, "funcA", IARG_FUNCARG_ENTRYPOINT_VALUE,
0, IARG_END);
RTN_Close(funcRtn);
}
}
我得到以下輸出
Pin: funcA 0 -656937200 -10
Actual: 0 -10 0
Pin: funcA 1 -656937200 -9
Actual: 1 -9 20
Pin: funcA 2 -656937200 -8
Actual: 2 -8 40
我可以看到我接近,但有些東西沒有正確對齊。我知道RTN_ReplaceProbed,但我需要在jit模式下使用引腳,因爲我需要指令級儀器。