ARM硬件断点

hw_breakpoint 是由处理器提供专门断点寄存器来保存一个地址,是需要处理器支持的。处理器在执行过程中会不断去匹配,当匹配上后则会产生中断。

内核自带了硬件断点的样例linux-3.16\samples\hw_breakpoint\data_breakpoint.c

static void sample_hbp_handler(struct perf_event *bp,
			       struct perf_sample_data *data,
			       struct pt_regs *regs)
{
	printk(KERN_INFO "%s value is changed\n", ksym_name);
	dump_stack();
	printk(KERN_INFO "Dump stack from sample_hbp_handler\n");
}

static int __init hw_break_module_init(void* addr)
{
	int ret;
	struct perf_event_attr attr;

	hw_breakpoint_init(&attr);
	attr.bp_addr = addr;
	attr.bp_len = HW_BREAKPOINT_LEN_4;//监控addr开始的4字节
	attr.bp_type = HW_BREAKPOINT_W | HW_BREAKPOINT_R;//读写该地址都能触发

	sample_hbp = register_wide_hw_breakpoint(&attr, sample_hbp_handler, NULL);
	if (IS_ERR((void __force *)sample_hbp)) {
		ret = PTR_ERR((void __force *)sample_hbp);
		goto fail;
	}

	printk(KERN_INFO "HW Breakpoint for write installed\n");

	return 0;

fail:
	printk(KERN_INFO "Breakpoint registration failed\n");

	return ret;

 看网上说ARM Architecture Reference Manual Supplement ARMv8.1, for ARMv8-A architecture profile这些文档的degug register里面有。文档可以在这个网站下载

https://developer.arm.com/documentation

Documentation – Arm Developer

样例代码

#include <linux/perf_event.h>
#include <linux/hw_breakpoint.h>

struct perf_event * __percpu *sample_hbp;

static void sample_hbp_handler(struct perf_event *bp,
			       struct perf_sample_data *data,
			       struct pt_regs *regs)
{
	printk(KERN_INFO "value is changed\n");
	dump_stack();
	printk(KERN_INFO "Dump stack from sample_hbp_handler\n");
	unregister_wide_hw_breakpoint(sample_hbp);
}

static int hw_break_module_init(void* addr)
{
	int ret;
	struct perf_event_attr attr;

	hw_breakpoint_init(&attr);
	attr.bp_addr = addr;
	attr.bp_len = HW_BREAKPOINT_LEN_4;
	attr.bp_type = HW_BREAKPOINT_W;

	sample_hbp = register_wide_hw_breakpoint(&attr, sample_hbp_handler, NULL);
	if (IS_ERR((void __force *)sample_hbp)) {
		ret = PTR_ERR((void __force *)sample_hbp);
		goto fail;
	}

	printk(KERN_INFO "HW Breakpoint for write installed\n");

	return 0;

fail:
	printk(KERN_INFO "Breakpoint registration failed\n");

	return ret;
}

int arr[10] = {0};
int hw_bp_test = 0;
static int __init msm_serial_init(void)
{
	..............................
	pr_info("xxx msm_serial: driver initialized\n");
	//arr[10] = local_var_test[5];
	hw_break_module_init(&hw_bp_test);
	hw_bp_test = 1;
	return ret;
}

实际效果展示

此次实验是用qemu模拟一个aarm64环境,可以看到支持6个断点 

可以看到应该是每个cpu都注册了一个。感觉应该是在一个cpu上注册,所有cpu都会去检查(原理不清楚,上面的文档没有看明白,猜测的)

struct perf_event * __percpu *
register_wide_hw_breakpoint(struct perf_event_attr *attr,
			    perf_overflow_handler_t triggered,
			    void *context)
{
	struct perf_event * __percpu *cpu_events, *bp;
........................................
	for_each_online_cpu(cpu) {
		bp = perf_event_create_kernel_counter(attr, cpu, NULL,
						      triggered, context);
...................................................
}

暂时不写了

  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ARM debug interface v5 是一种调试接口,用于调试 ARM 架构的处理器。它提供了调试器与处理器之间的通信通道,允许开发人员对处理器进行调试、控制和监视。 ARM debug interface v5 可以通过 JTAG(Joint Test Action Group)接口与目标处理器连接。通过这个接口,调试器可以读取和写入处理器的寄存器、内存和其他调试相关的信息。它还允许调试器以停止、运行和单步执行的方式控制处理器的执行。 除了基本的调试功能外,ARM debug interface v5 还提供了一些高级功能,如硬件断点和观测点。硬件断点可以在特定的内存地址上设置断点,在处理器执行到该地址时中断程序的执行。观测点是指在某个条件满足时,触发特定操作或输出特定信息。这些功能有助于开发人员更精确地定位和解决程序的问题。 ARM debug interface v5 还支持多核处理器的调试。它可以通过不同的调试总线连接到每个核上,使开发人员能够同时调试多个核。 总之,ARM debug interface v5 是一种强大的调试接口,提供了丰富的调试功能,帮助开发人员快速定位和解决程序的问题。它对于 ARM 架构的处理器调试和开发非常有价值。 ### 回答2: ARM调试接口v5(ARM Debug Interface v5)是一种用于调试和追踪ARM架构处理器的接口标准。它定义了一套通信协议和信号电平以及操作流程,使得开发人员可以通过调试器与处理器进行交互并获取有关程序执行的详细信息。 ARM Debug Interface v5支持多种调试操作,包括断点设置、单步执行、访问寄存器和存储器等。通过调试接口,开发人员可以在程序执行的任何阶段插入断点,以便观察和分析程序的执行状态。此外,调试接口还可以提供对处理器内部寄存器和存储器的访问权限,以便进行调试。 ARM Debug Interface v5使用的是JTAG(Joint Test Action Group)接口标准,这是一种广泛应用于电路板测试和调试的标准接口。通过JTAG接口,调试器可以与处理器进行通信,并能够控制和监视处理器的执行过程。 ARM Debug Interface v5还支持追踪功能,能够记录处理器的运行轨迹。开发人员可以使用追踪信息来分析程序的性能瓶颈、优化代码以及调试复杂的软硬件交互问题。 综上所述,ARM Debug Interface v5是一种用于调试和追踪ARM架构处理器的接口标准,它使用JTAG接口进行通信,并支持多种调试操作和追踪功能,为开发人员提供了丰富的调试工具和资源,用于分析和优化程序的执行过程。 ### 回答3: ARM Debug Interface V5(ARM调试接口V5)是一种用于调试ARM架构处理器的接口标准。它是ARM公司为开发人员提供的一种调试工具,用于调试和诊断ARM系统的硬件和软件。 ARM Debug Interface V5具有以下特点: 1. 灵活性:ARM Debug Interface V5允许开发人员在不同的调试场景中进行灵活的配置和调整。它支持多种不同的调试模式和访问权限,以满足不同应用和系统的要求。 2. 高性能:ARM Debug Interface V5提供了高效的调试和诊断功能,可以帮助开发人员快速定位和解决问题。它支持高速数据传输和实时调试,可以提高开发和调试的效率。 3. 易用性:ARM Debug Interface V5提供了一套简洁、易于使用的调试工具和API,使开发人员能够快速上手并使用它进行系统调试和软件开发。它还提供了详细的文档和调试指南,帮助开发人员理解和使用这一调试接口。 4. 兼容性:ARM Debug Interface V5兼容多种ARM体系架构处理器,包括ARM Cortex-M、Cortex-R和Cortex-A系列。这意味着开发人员可以在不同的ARM处理器上使用相同的调试工具和接口,提高了开发的灵活性和可移植性。 总而言之,ARM Debug Interface V5是一种功能强大、可靠性高、易于使用的调试工具,被广泛应用于ARM处理器的软件开发和系统调试中。它为开发人员提供了一套完整的调试解决方案,帮助他们提高开发效率和系统可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值