当前位置: 首页 > news >正文

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

 可以看到应该是每个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);
...................................................
}

暂时不写了

http://www.lryc.cn/news/185747.html

相关文章:

  • Java使用WebSocket(基础)
  • 图像处理与计算机视觉--第五章-图像分割-自适应阈值分割
  • 记一次问题排查
  • 【Spring Boot】创建一个 Spring Boot 项目
  • flutter中使用缓存
  • 京东数据分析平台:9月中上旬白酒消费市场数据分析
  • Linux安装 spark 教程详解
  • 动态内存管理函数(malloc,calloc,realloc,free)
  • 云表|都有生产管理模块,MES和ERP有什么不同,该如何选择
  • C语言 - 数组
  • Vue 中的插槽(Slot),有什么用,不同插槽的区别?
  • Linux登录自动执行脚本
  • 架构方法、模型、范式、治理
  • Linux 安全 - 内核提权
  • 数字三角形加强版题解(组合计数+快速幂+逆元)
  • MySQL:主从复制-基础复制(6)
  • 盒子模型的基础
  • Go复合类型之数组类型
  • rust闭包
  • 通过位运算,实现单字段标识多个状态位
  • ALSA pcm接口的概念解释
  • logging的基本使用教程
  • ds套dp——考虑位置转移or值域转移:CF1762F
  • stm32的GPIO寄存器操作以及GPIO外部中断,串口中断
  • 生成对抗网络入门案例
  • 多头注意力机制
  • Qt + FFmpeg 搭建 Windows 开发环境
  • [网鼎杯 2020 白虎组]PicDown python反弹shell proc/self目录的信息
  • SDL2绘制ffmpeg解析的mp4文件
  • 决策树C4.5算法的技术深度剖析、实战解读