Boo*_*ley 5 linux cpu-architecture instructions intel-pin
我相对较不熟悉使用英特尔Pin工具进行代码检测,并且正在尝试研究分支预测。具体来说,我想生成所有分支的列表,它们的分支目标以及是否采用它们。我知道SimpleExamples中有用于生成内存地址跟踪的pintool,例如“ pinatrace.cpp”工具,但是我看不到任何适合列出分支的需求的工具。
我可以在示例中使用的某个地方存在现有的pintool,还是需要编写一个新的pintool?
我在Linux计算机上使用pin-2.14。
谢谢!
小智 3
我不确定是否有一个示例 pintool 可以执行此操作,但这可以相对简单地完成。
如果我理解正确的话,你想要三件事:
所有条件分支的地址
目标
采取/未采取决定
1/2。这可以通过使用指令级仪器来完成。使用INS_AddInstrumentFunction(Instruction, 0)以便允许Instruction(INS ins, VOID *v)每次执行新指令时调用该函数。然后在该Instruction()函数中,您可以使用if(INS_IsBranch(ins) && INS_HasFallThrough(ins))表达式来确定当前指令是否是条件分支。如果是,则将其地址INS_Address(ins)与其目标一起存储INS_DirectBranchOrCallTargetAddress(ins)存储。也许您可以打印其反汇编代码以进行调试INS_Disassemble(ins)。
3.为了打印出决策,您必须在每个条件分支之前插入一个分析例程。使用上面的指令函数,在 中if(INS_IsBranch(ins) && INS_HasFallThrough(ins))使用此 API 调用:
INS_InsertCall(ins, IPOINT_BEFORE, (AFUNPTR)<YOUR FUNCTION NAME>, IARG_INST_PTR, IARG_BRANCH_TAKEN, IARG_END)
使用它,您可以创建一个分析例程,该例程将在每次动态执行条件分支时运行。从那里使用 IARG_BRANCH_TAKEN 参数,您可以进行简单的检查以确定分支是否已被采用。将决策存储在地图或类似地图的东西中,以便稍后您可以将其打印出来。警告:不要在分析例程中打印任何内容(打印指令的动态跟踪从来都不是一个好主意)。另请注意,条件分支可能会使用不同的已采取/未采取的决策运行多次,因此您可能必须跟踪多个决策。
希望这可以帮助。
干杯,
丹尼