【ARM Cortex-M 系列 2.2 -- Cortex-M7 单步调试原理及实现详细介绍】


请阅读【嵌入式开发学习必备专栏】


紧接上篇文章 【ARM Cortex-M 系列 2.1 – Cortex-M7 Debug system registers】

单步调试概述

在ARMv7-M架构中,通过使用单步调试(Halting Debug Stepping),调试器能够从调试状态退出,执行单条指令,然后重新进入调试状态。这是一种在精确调试软件时十分有用的功能,它允许开发者逐条检查指令的执行情况。单步调试是在以下所有条件满足时激活的:

单步执行原理

  1. DHCSR.C_DEBUGEN 被设置为1,使能 debug state。
  2. DHCSR.C_STEP 被设置为1,使能单步调试。
  3. 处理器处于非调试状态。

当处理器退出调试状态并且单步调试变为活动状态时,处理器将按照如下方式执行一个单步调试:

  1. 执行以下操作之一:
    • 执行下一条指令,不生成任何异常。
    • 接受任何待处理的足够优先级的异常入口。
    • 执行下一条指令,生成一个同步异常,并接受该异常。
  2. DFSR.HALTED 位设置为1。
  3. 返回到调试状态。

调试器还可以选择性地将 DHCSR.C_MASKINTS 位设置为1,以防止PendSV、SysTick和外部可配置中断被接受。当 DHCSR.C_MASKINTS 被设置为1时,如果允许的异常变为活动状态,处理器将会在执行关联的异常处理程序的第一条指令之前停滞并进入单步调试。

此外,DHCSR.{C_HALT, C_STEP, C_MASKINTS} 可以通过对 DHCSR 的单次写入来设置。这意味着,通过一个操作即可同时配置多个调试相关的控制位,从而为调试提供更大的灵活性和控制力。

在看了上述描述外,好像还是不清楚单步调试时怎么进行的?

简单来说可以按照下面步骤进行:

  • 调试器设置 DHCSR.C_DEBUGENC_HALT 位来暂停内核。 读取 DHCSR.S_HALT 判断是否处于debug state。

  • C_STEP 位设置为 1来使能单步执行,然后将 C_HALT 位设置为 0 内核离开 debug state,内核可以单步执行, 然后再进入停止状态。具体可以从下表可以看到当 C_HALT 为 0, C_STEP 为 1 的时候就是这种情况。

Debug stepping control using the DHCSR

在这里插入图片描述

  • 27
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

主公讲 ARM

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值