【ARM Cortex-M 系列 2.3 -- Cortex-M7 Debug event 详细介绍】

news2025/1/10 20:34:39


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


文章目录

    • Cortex-M7 Debug event
      • Debug events

Cortex-M7 Debug event

在ARM Cortex-M7架构中,调试事件(Debug Event)是由于调试原因而触发的事件。一个调试事件会导致以下几种情况之一发生:

  1. 进入调试状态:如果启用了停滞调试(Halting Debug),一个调试事件会使处理器在调试状态下停滞。通过将DHCSR.C_DEBUGEN位设置为1来启用停滞调试。一个导致进入调试状态的调试事件会将DHCSR.C_HALT设置为1。在这里插入图片描述

  2. DebugMonitor异常:如果停滞调试被禁用且 DebugMonitor 异常被启用,当 DebugMonitor 异常的组优先级大于当前执行优先级时,一个调试事件会导致DebugMonitor异常。停滞调试被禁用是通过将DHCSR.C_DEBUGEN位设置为0或通过调试认证接口禁用,在这里插入图片描述
    而 DebugMonitor 异常被启用是通过将DEMCR.MON_EN位设置为1。在这里插入图片描述

MON_EN, bit[16] Enable the DebugMonitor exception:

  • 0 DebugMonitor exception disabled.
  • 1 DebugMonitor exception enabled.

如果DebugMonitor组优先级小于或等于当前执行优先级:

  • 处理器会将由执行BKPT指令生成的断点调试事件升级为HardFault。
  • 处理器升级由FPB生成的断点为HardFault,或忽略FPB断点,这是由具体实现定义的。然而,处理器只有在受断点影响的指令显示其架构行为时才能忽略FPB断点。
  • 处理器忽略其他调试事件。这意味着它忽略看点(Watchpoints)和外部调试请求。
  1. HardFault异常:如果停滞调试和监视器都被禁用,一个断点调试事件会升级为HardFault,并且处理器忽略其他调试事件。
  2. 在NMI或HardFault异常处理程序中发生断点时:如果在NMI或HardFault异常处理程序中断点发生时停滞调试被禁用,系统会因不可恢复的错误(Unrecoverable exception)而锁定。断点可能是由BKPT指令产生或由FPB生成的。
  3. FPB在DHCSR.C_DEBUGEN设置为0且DEMCR.MON_EN设置为0时,是否生成断点调试事件是由具体实现定义的。
  4. 导致HardFault或锁定的断点调试事件被视为不可恢复。

在ARM Cortex-M7架构中关于调试事件行为,特别是关于HardFault和锁定(Lockup)情况的触发机制,主要涉及当处理器在以下情况下执行BKPT(断点)指令时:

  • 因为禁止停滞而不设置DHCSR.C_HALT
  • 因为DebugMonitor被禁用或处理器未在比DebugMonitor优先级低的优先级上执行,而不设置DEMCR.MON_PEND

处理器的DFSR(Debug Fault Status Register,调试故障状态寄存器)包含每个调试事件的状态位。当一个调试事件导致处理器停滞或生成异常时,这些位被设置为1,并且之后通过写1来清除(write-one-to-clear)。是否在事件被忽略或导致锁定时更新这些位是由具体实现定义的。

Debug events

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1676069.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2024第16届四川教育后勤装备展6月1日举办 欢迎参观

2024第16届四川教育后勤装备展6月1日举办 欢迎参观 邀请函 主办单位: 中国西部教体融合博览会组委会 承办单位:重庆港华展览有限公司 博览会主题:责任教育 科教兴邦 组委会:交易会159交易会2351交易会9466 展会背景 成都…

matlab使用2-基础绘图

matlab使用2-基础绘图 文章目录 matlab使用2-基础绘图1. 二维平面绘图2. 三维立体绘图3. 图形窗口的分割 1. 二维平面绘图 % 创建一些二维数据 x 0:0.01:10; % x轴的数据点,从0到10,间隔为0.01 y sin(x); % y轴的数据点,是x的正弦…

实时“秒回”,像真人一样语音聊天,GPT-4o模型强到恐怖

今天凌晨OpenAl发布了 GPT-4o,这是一种新的人工智能模式,集合了文本、图片、视频、语音的全能模型。 能实时响应用户的需求,并通过语音来实时回答你,你可以随时打断它。还具有视觉能力,能识别物体并根据视觉做出快速的…

基准电流源电路仿真

1.补全电路 2.更改vpluse属性 3.添加tran仿真,因为加入启动电路主要看的就是tran仿真 4.启动仿真 5.看电路曲线 先点这个main form 不用选择ok,直接点中四条线,中间第2条曲线如果出现那样一个小波动后面没有起伏就说明成功了。

什么是Keycloak?怎么样使用Keycloak实现登录和权限验证?

什么是Keycloak?怎么样使用Keycloak实现登录和权限验证? 文章目录 什么是Keycloak?怎么样使用Keycloak实现登录和权限验证?Open Source Identity and Access Management(开源身份和访问管理)1、支持的协议:2、安装与部…

如何在 Mac 上恢复已删除的文件

点击“删除”后立即后悔?不用担心。我们的教程介绍了如何恢复已删除的 Mac 文件、电子邮件、iTunes 音乐等,即使您没有 Time Machine 备份并且无需支付软件费用。 在 macOS 中丢失文件可能会非常痛苦,如果您是点击删除的人,情况会…

稳定网络的诀窍:静态住宅代理解决方案

在数字化时代,网络稳定性对于个人和企业都至关重要。然而,由于多种因素的影响,如地理位置、网络拥堵或网络安全问题等,网络稳定性常常受到挑战。为了应对这些挑战,静态住宅代理作为一种高效且可靠的网络解决方案&#…

c++ 各版本特性介绍

c C是一种高级编程语言,以其强大的功能、灵活性和高效性而闻名。它是由Bjarne Stroustrup在20世纪80年代初期在贝尔实验室开发的,作为C语言的一个扩展。C不仅包含了C语言的所有特性,还引入了面向对象编程(OOP)的概念&…

Poe是什么?怎样订阅Poe?

Poe(全称“开放探索平台”,Platform for Open Exploration)是一款由Quora开发的移动应用程序,于2022年12月推出。该应用程序内置建基于AI技术的聊天机器人,可供用户向机器人询问专业知识、食谱、日常生活,甚…

智能AI数字人系统 打造无人直播间 主播形象任意选择!

系统概述 智能AI数字人系统是一种结合人工智能、计算机图形学、语音合成等技术的综合性系统。该系统能够模拟人类的外貌、行为和语言,为用户提供逼真的交互体验。在无人直播间场景下,智能AI数字人系统可以扮演主播角色,与观众进行实时互动&a…

Jenkins构建流程

Jenkins是DevOps【(Development和Operations的混成词)是一种重视“软件开发人员(Dev)”和“IT运维技术人员(Ops)”之间沟通合作的文化、运动或惯例)】的重要一环,是一款开源的CI&CD软件。也就是持续集成…

MongoDB 推出新项目,助力企业构建生成式 AI 现代应用程序

MongoDB AI Applications Program可为组织提供战略路线图、行业专业知识及所需技术,加速从构思到大规模部署生成式 AI 应用程序 MongoDB (纳斯达克股票代码:MDB) 近日宣布推出 MongoDB AI Applications Program (MongoDB AI应用项目,简称&am…

【PostgreSQL支持中文的全文检索插件(zhparser)】

PostgreSQL本身是支持全文检索的,提供两个数据类型(tsvector,tsquery),并且通过动态检索自然语言文档的集合,定位到最匹配的查询结果。其内置的默认的分词解析器采用空格进行分词,但是因为中文的词语之间没…

使用java.io库序列化Java对象

在我们使用诸如Redis这类缓存系统时,我们往往会存在如下需求:将Java对象保存到Redis缓存中,然后在其他机器上还原回来。 Json方案 我们可以引入Json库等方式,将Java对象序列化为Json字符串来实现这个目的,但是这样的…

【JS面试题】this

this取什么值,是在函数执行的时候确定的,不是在函数定义的时候确定的! this的6种使用场景: ① 在普通函数中使用:返回window对象 ② 使用call apply bind 调用:绑定的是哪个对象就返回哪个对象 ③ 在对象…

IP应用场景查询API接口

IP应用场景查询API接口指的是输入IP地址,查询IP应用场景信息。那么IP地址应用场景查询接口如何对接呢? 首先我们找到一家有IP地址应用场景查询API的服务商数脉API,然后注册账号,购买免费套餐 接下来就需要技术同学把IP应用场景查询接口对接到…

【线性系统理论】笔记一

一:状态空间表达式 电路系统状态空间描述列写 1:选取状态变量 状态变量定义:线性无关极大组属性。 2:列出电路原始回路方程 ps:状态变量有两个,理论上需要列写2个方程 3:规范形势 4&#xf…

比大小(打擂台)(C语言)

一、运行结果&#xff1b; 二、源代码&#xff1b; # define _CRT_SECURE_NO_WARNINGS # include <stdio.h>//声明比较大小函数max; int max(int a, int b);int main() {//初始化变量值&#xff1b;int i, n, m, a[10];//填充数组&#xff1b;printf("请输入10个数…

注意力机制篇 | YOLOv8改进之在C2f模块引入反向残差注意力模块iRMB | CVPR 2023

前言:Hello大家好,我是小哥谈。反向残差注意力模块iRMB是一种用于图像分类和目标检测的深度学习模块。它结合了反向残差和注意力机制的优点,能够有效地提高模型的性能。在iRMB中,反向残差指的是将原始的残差块进行反转,即将卷积操作和批量归一化操作放在了后面。这样做的好…

一台linux通过另一台linux访问互联网-TinyProxy

参考&#xff1a; https://blog.csdn.net/weixin_41831919/article/details/113061317https://www.yuncongz.com/archives/1.htmlhttps://blog.csdn.net/aoc68397/article/details/101893369 环境&#xff1a;ubuntu 18.04 机器1: IP 219.216.65.252 (可以访问外网) 机器2: IP…