硬件调试器是如何分辨用户空间进程的
3.14的内核,cpu是cortex-a9最近在思考硬件调试器是如何支持linux用户空间调试的
比如使用trace32这样的硬件调试器来调试linux application,例如我想使用硬件观察点
观察点和断点不同,断点可以是软断点(软件断点就是在要停止的地方用bkpt指令替换原有指令),而观察点是设置在cpu核里面的
由于不同app的地址范围都是在低3G,所以观察点必须得区分不同的进程才可以
看arm手册,看到contextidr这个寄存器,有asid和procid两个字段,其中asid是给tlb用的,procid是调试用的
arm手册上说设置观察点的时候,除了设置地址,procid也是触发条件的一部分
在内核代码中找到函数contextidr_notifier(arch/arm/mm/context.c),这个函数是在设置procid,但是用的却是线程id而不是进程id,这里我就迷惑了,这样就无法使得观察点对这个进程中的所有线程都有效了啊,实在想不明白
有谁知道这块吗
回复 1# arm-linux-gcc
在内核的切换函数里加个断点,然后在那调整你的硬件watchpoint。
页:
[1]