ARM Cortex-Mx 权威指南笔记

用于中断或异常屏蔽特殊寄存器细节

1、PRIMASK

在许多应用中,可能都需要暂时禁止所有中断以执行一些时序关键的任务,此时可以使用PRIMASK寄存器。PRIMASK寄存器只能在特权状态访问。PRIMASK 用于禁止除NMI和 HardFault 外的所有异常它实际上是将当前优先级改为0(最高的可编程等级)。如用 C编程可以使用CMSIS-Core 提供的函数来设置和清除PRIMASK:

void enable irq(); //清除PRIMASKvoid disable irq(); //设置PRIMASKvoid set PRIMASK(uint32 tpriMask);//设置PRIMASK为特定值uint32t get PRIMASK(void);//读取PRIMASK的数值

对于汇编编程可以利用CPS(修改处理器状态)指令修改PRIMASK寄存器的数值


CPSIEI;清除PRIMASK(使能中断)CPSIDI;设置PRIMASK(禁止中断)

PRIMASK寄存器还可通过MRS和MSR指令访问。例如;

MOVSRO,#1
MSR PRIMASK,RO;1写人PRIMASK禁止所有中断

以及

MOVSRO,#0
MSR PRIMASK,RO;0写人PRIMASK以使能中断

当PRIMASK 置位时,所有的错误事件都会触发 HardFault 异常,而不论相应的可配置错误异常(如MemManage、总线错误和使用错误)是否使能。

2、FAULTMASK

从行为来说,FAULTMASK 和 PRIMASK 很类似,只是它实际上会将当前优先级修改为-1,这样甚至是 HardFault处理也会被屏蔽。当FAULTMASK 置位时,只有NMI异常处理才能执行。

从用法来说FAULTMASK 用于将配置的错误处理如MemManage 总线错误和使用错误)的优先级提升到-1,这样这些处理就可以使用 HardFault 的一些特殊特性。其中包括:

1、旁路MPU

2、忽略用于设备/存储器探测的数据总线错误将当前优先级提升到-1后,FAULTMASK 可在可配置的错误处理执行期间,止其他异常或中断处理的执行。

FAULTMASK寄存器只能在特权状态访问,不过不能在 NMI和HardFault处理中设置。若在C编程中使用符合 CMSIS 的设备驱动则可以使用下面的CMSIS-Core 函数来设置和清除FAULTMASK:

void enable fault irq(void);  //清除 FAULTMASKvoid disable fault irq(void); //设置FAULTMASK 以禁止中断void set FAULTMASK(uint32 t faultMask);uint32 t_get FAULTMASK(void);

对于汇编语言用户,可以利用CPS 指令修改 FAULTMASK 的当前状态:

CPSIE F;清除 FAULTMASK
CPSID F;设置FAULTMASK

还可以利用MRS和MSR指令访问FAULTMASK寄存器

MOVS RO,#1
MSR FAULTMASK,RO;1写FAULTMASK禁止所有中断

以及:

MOVS RO,#0
MSR FAULTMASK,RO;0写FAULTMASK使能中断

FAULTMASK会在退出异常处理时被自动清除,从NMI处理中退出时除外。由于这个特点FAULTMASK 就有了一个很有趣的用法:若要在低优先级的异常处理中触发一个高优先级的异常(NMI 除外),但想在低优先级处理完成后再进行高优先级的处理,可以:
。设置FAULTMASK禁止所有中断和异常(NMI异常除外)
。设置高优先级中断或异常的挂起状态
。退出处理

由于在 FAULTMASK 置位时,挂起的高优先级异常处理无法执行,高优先级的异常就会在 FAULTMASK 被清除前继续保持挂起状态,低优先级处理完成后才会将其清除。因此,可以强制让高优先级处理在低优先级处理结束后开始执行。

3、使用示例

在main函数初始化外设和参数时,取消使能中断,保证不出错误。
在这里插入图片描述

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

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

相关文章

图解设计模式-中介者模式(Mediator)

中介者模式 定义 使用一个中介者对象(mediator)集中封装多个具有依赖/关联关系的对象(colleague,同事对象)之间的交互,使各对象之间不再互相引用,降低对象之间的强耦合程度,对象之…

CTF之Misc杂项干货

目录 一、常见编码 二、文件分析与处理 三、隐写工具与命令 四、隐写术实例 一、常见编码 1、base家族 2、进制转换 3、摩斯、希尔、凯撒、仿射、栏栅、维吉尼亚、培根、键盘、rabbit、rot13、AES、md5、RSA等 (md5、RSA可能不会出现在杂项里,但…

pytorch集智-1安装与简单使用

1 安装 1.1 简介 pytorch可用gpu加速,也可以不加速。gpu加速是通过cuda来实现,cuda是nvidia推出的一款运算平台,它可以利用gpu提升运算性能。 所以如果要装带加速的pytorch,需要先装cuda,再装pytorch,如…

2023年第2季社区Task挑战赛贡献者榜单

基于FISCO BCOS及Weldentity,实现SSO单点登录服务;提供食品溯源、电商运费险7天退保、电子病历等智能合约库业务场景案例;基于FISCO BCOS更新游戏体验;体验并分析解读最新发布的分布式数据协作管理解决方案DDCMS,提供相…

Java学校教务管理系统源码带微信小程序

运行环境:jdk8mysql5.7IntelliJ IDEAmaven 技术:springbootmybatislayuishirojquery 教务管理系统是一个基于网络的在线管理平台, 帮助学校管理教务系统,用一个帐号解决学校教务教学管理, 灵活的定制符合学校自己实际情况的教务系…

网络连通性批量检测工具

一、背景介绍 企业网络安全防护中,都会要求配置物理网络防火墙以及主机防火墙,加强对网络安全的防护。云改数转之际,多系统上云过程中都会申请开通大量各类网络配置,针对这些复杂且庞大的网络策略开通配置,那么在网络配…

使用Go语言实现RESTful API

RESTful架构是一种设计风格,用于构建网络应用程序的API。它基于HTTP协议,并使用不同的HTTP方法(如GET、POST、PUT、DELETE等)来处理不同的操作。在Go语言中,我们可以使用标准库中的net/http包来实现RESTful API。 下面…

【Axure高保真原型】树形表格_多选效果

今天和大家分享树形表格_多选效果的原型模板,点击树的箭头可以展开或者收起子节点,点击多选按钮可以选中或取消选择该行以及子级行内容,同时反选父级行内容,父级行内容能根据子级选中的数量自动反选,包括全选、半选和未…

SpringBoot学习(三)-整合JDBC、Druid、MyBatis

注:此为笔者学习狂神说SpringBoot的笔记,其中包含个人的笔记和理解,仅做学习笔记之用,更多详细资讯请出门左拐B站:狂神说!!! 一、整合JDBC使用(理解) 创建项目 勾选依赖启动器 查看依赖 …

Electron介绍

前言 相信很多的前端小伙伴都想过一个问题,web技术是否可以用于开发桌面应用。答案当然是可以的,Electron框架就是其中的一种解决方案。 Electron介绍 Electron是一个使用 JavaScript、HTML 和 CSS 构建桌面应用程序的框架。 Electron 并不是一门新的…

FreeRTOS——互斥信号量知识总结及其实战

1互斥信号量的概念 1)互斥信号量:是一个拥有优先级继承的二值信号量,在同步的应用中二值信号量最适合。互斥信号量适合用于那些需要互斥访问的应用中! 2)优先级继承:当一个互斥信号量正在被一个低优先级的…

python统计分析——直方图(df.hist)

使用dataframe.hist()或series.hist()函数绘制直方图 import numpy as np import pandas as pd from matplotlib import pyplot as plt.dfpd.DataFrame(data{type:[A,A,A,A,A,A,A,A,A,A,B,B,B,B,B,B,B,B,B,B],value:[2,3,3,4,4,4,4,5,5,6,5,6,6,7,7,7,7,8,8,9] }) serpd.Serie…

conda虚拟环境搭建和打包,删除,移动等全流程及相关问题汇总

私人笔记无偿分享,更多内容请访问:链接:https://pan.baidu.com/s/19mS5N9XJ_AotF20kUwSA3w?pwdp5kx 提取码:p5kx 复制这段内容后打开百度网盘手机App,操作更方便哦 4.4. anaconda虚拟环境搭建: 网址&am…

Java中的SPI机制

Java中的SPI(Service Provider Interface)机制是一种服务发现机制。它允许服务提供者在运行时被发现和加载,而不是在编译时。这种机制主要用于实现解耦,使得接口的定义与实现可以独立变化,增强了系统的可扩展性和可替换…

[PyTorch][chapter 9][李宏毅深度学习][CNN]

前言: 卷积神经网络(Convolutional Neural Networks)是一种深度学习模型或类似于人工神经网络的多层感知器,常用来分析视觉图像。卷积神经网络的创始人是着名的计算机科学家Yann LeCun,目前在Facebook工作,…

小样本学习介绍(超详细)

小样本学习介绍 本文首先介绍了什么是小样本学习,其次介绍了为什么小样本学习的很多文章都采用元学习的方法。目的是通过通俗的解释更加清楚的介绍小样本学习是什么,适合初学者的入门。当然,以下更多的是自己的思考,欢迎交流。 …

莫比乌斯函数

积性函数定义 若gcd(p,q)1,有f(p*q)f(p)*f(q),则f(x)是积性函数 其中规定f(1)1,对于积性函数有:所有的积性函数都可以用筛法求出 常见的积性函数有欧拉函数和莫比乌斯函数 筛法求莫比乌斯函数 const int N 1e9 5; const int …

用开源大语言模型开发的智能对话机器人初版原型验证

用开源大语言模型开发的智能对话机器人初版原型验证 0. 背景1. 初版检证效果展示2. 验证效果总结 0. 背景 同事要想做一个智能对话机器人,特别的需求有有些几点, 通过预置提示词(包括确认事项),让大语言模型用会话式…

OpenAI ChatGPT-4开发笔记2024-02:Chat之text completion

API而已 大模型封装在库里,库放在服务器上,服务器放在微软的云上。我们能做的,仅仅是通过API这个小小的缝隙,窥探ai的奥妙。从程序员的角度而言,水平的高低,就体现在对openai的这几个api的理解程度上。 申…

【springboot+vue项目(零)】开发项目经验积累(处理问题)

一、VUEElement UI (一)elementui下拉框默认值不是对应中文问题 v-model绑定的值必须是字符串,才会显示默认选中对应中文,如果是数字,则显示数字,修改为: handleOpenAddDialog() {this.dialogT…