Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Kernel
SYSTICK_心跳时钟节拍
SysTick和pendSV的中断优先级问题
发布于 2019-08-15 10:21:18 浏览:3508
订阅该版
问题描述: SysTick和pendSV的中断优先级分别设置为0和15,这样的设置可能会存在一个问题,SysTick优先级太高会抢占用户自己设置的外设的中断。 代码证明: PendSV优先级设置寄存器地址为0xe000ed22 SysTick优先级设置寄存器地址为0xe000ed23 RT-Thread中设置pendSV中断优先级的代码在cpu文件夹下context_rvds.S的汇编部分,中断优先级设置为15,代码如下;![1565833486(1).jpg](/uploads/201908/15/094528rfbzbk77glyg0i1l.jpg) ![1565833594(1).jpg](/uploads/201908/15/094700u3q7l705qla5wx7d.jpg) SysTick的中断优先级设置在Drivers文件夹下的drv_common.c,优先级设置为0 ![1565833738(1).jpg](/uploads/201908/15/094922do8tataaooto91uo.jpg) 总结为SysTick和pendSV的中断优先级分别设置为0和15,通过MDK软件仿真证明如下: ![15818522a65e429572c6ef64628d0e4.png](/uploads/201908/15/095111uqfoe1nqqkopt212.png) 中断优先级设置逻辑: SysTick系统嘀嗒定时器是Cortex内核的部分,尤其对于有实时操作系统的软件,它一般会作为整个系统的时基,所以这个对操作系统非常重要。 在NVIC 有一个专门的寄存器:中断优先级寄存器NVIC_IPRx(在F429 中,x=0...90)用来配置外部中断的优先级,IPR 宽度为8bit,原则上每个外部中断可配置的优先级为 0~255,数值越小,优先级越高。但是绝大多数CM4 芯片都会精简设计,以致实际上支持的优先级数减少,在M4中,只使用了高4bit,如下所示: ![1565834651(1).jpg](/uploads/201908/15/100434nq2trtytt1q22s7j.jpg) 优先级的分组由内核外设SCB 的应用程序中断及复位控制寄存器AIRCR 的PRIGROUP[10:8]位决定,使用NVIC_PriorityGroupConfig()实现: ![1565834743(1).jpg](/uploads/201908/15/100559hgq706lt7z96xzhh.jpg) 优先级设置有HAL_NVIC_SetPriority()函数实现。 中断分为内核中断和外设的中断,配置的寄存器位置不同。外设的中断配置在NVIC的IP内,内核的中断配置在SCB内。 建议更改SysTick的中断优先级的方法: 把汇编部分的NVIC_PENDSV_PRI EQU 0x00FF0000 改为 NVIC_PENDSV_PRI EQU 0xF0F00000 ;这样就可以在任务切换的时候把SysTick和pendSV的中断优先级一起改为15。 ![1565835520(1).png](/uploads/201908/15/101912eme7fedynedrpz2k.png)
查看更多
5
个回答
默认排序
按发布时间排序
aozima
2019-08-15
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
楼主研究得挺深入啊,赞一个!
Aladdin
2019-08-15
这家伙很懒,什么也没写!
>楼主研究得挺深入啊,赞一个! --- 一起研究下
Aladdin
2019-08-15
这家伙很懒,什么也没写!
顺便提一下,在调度器启动第一个线程的时候调用rt_hw_context_switch_to()这个函数,进入的汇编代码,改了优先级,调度器启动以后就不会再改变优先级了。 rt_hw_context_switch_to()中的汇编代码解读: ``` ; set the PendSV exception priority设置PendSV的中断优先级 LDR r0, =NVIC_SYSPRI2 ;r0中加载中断优先级寄存器2的地址 LDR r1, =NVIC_PENDSV_PRI ; r1中加载设置PendSV中断为低优先级的数据地址 LDR.W r2, [r0,#0x00] ; 读取r0中断优先级寄存器2地址上的数据,存入r2 ORR r1,r1,r2 ; r2与r1相或的结果存入r1中 STR r1, [r0] ; 设置PendSV中断优先级为低优先级 ``` 在rtthread_startup()中先调用rt_hw_board_init()设置了systic的优先级(根据参数设置中断优先级寄存器2),后调用rt_system_scheduler_start()函数设置pendSV优先级(如果在汇编中设置了中断优先级寄存器2的高四位值systic的优先级低于在rt_hw_board_init()设置的systic的优先级,这段汇编代码会改变systic的优先级为更低优先级,否则不会改变systic的优先级)。
Aladdin
2019-08-15
这家伙很懒,什么也没写!
博客描述的更清晰:[https://blog.csdn.net/sinat_31039061/article/details/99640944](https://blog.csdn.net/sinat_31039061/article/details/99640944)
aozima
2020-06-01
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
感谢楼主反馈 [https://github.com/RT-Thread/rt-thread/pull/3637](https://github.com/RT-Thread/rt-thread/pull/3637) 已更新
撰写答案
登录
注册新账号
关注者
0
被浏览
3.5k
关于作者
Aladdin
这家伙很懒,什么也没写!
提问
2
回答
3
被采纳
0
关注TA
发私信
相关问题
1
请教cpu使用率分析
2
选择FreeRTOS, 还是RT-Thread。
3
thread heap stack overflow ?
4
rtt消息队列delay问题
5
释放被删除线程的内存地方在哪里啊
6
请教:各线程结束后,释放其中的内存的连续性问题
7
STM32F103中断关于信号量、邮箱问题
8
RTT中的线程栈大小如何控制
9
关于线程由执行态变为挂起态的代码实现,,,
10
rt_malloc(rt_size_t size)内存分配函数最小分配尺寸问题
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
2
RT-Thread 发布 EtherKit开源以太网硬件!
3
rt-thread使用cherryusb实现虚拟串口
4
《C++20 图形界面程序:速度与渲染效率的双重优化秘籍》
5
《原子操作:程序世界里的“最小魔法单位”解析》
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
WIZnet_W5500
UART
ota在线升级
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
keil_MDK
rt_mq_消息队列_msg_queue
at_device
ulog
C++_cpp
本月问答贡献
踩姑娘的小蘑菇
7
个答案
3
次被采纳
a1012112796
13
个答案
2
次被采纳
张世争
9
个答案
2
次被采纳
rv666
5
个答案
2
次被采纳
用户名由3_15位
11
个答案
1
次被采纳
本月文章贡献
程序员阿伟
7
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
3
次点赞
ThinkCode
1
篇文章
1
次点赞
Betrayer
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部