优先级 让我头疼好久啊
转一篇文章,这里还有不明白的望高手指教!
被我用红色注释的部分的值怎样选择??
(一)中断优先级概念
STM32(Cortex-M3)中有两个优先级的概念——抢占式优先级和响应优先级,有人把响应优先级称作'亚优先级'或'副优先级',每个中断源都需要被指定这两种优先级。
(二)中断响应次序
(1)具有高抢占式优先级的中断可以在具有低抢占式优先级的中断处理过程中被响应,即中断嵌套,或者说高抢占式优先级的中断可以嵌套低抢占式优先级的中断。
(2)当两个中断源的抢占式优先级相同时,这两个中断将没有嵌套关系,当一个中断到来后,如果正在处理另一个中断,这个后到来的中断就要等到前一个中断处理完之后才能被处理。
(3)如果这两个中断同时到达,则中断控制器根据他们的响应优先级高低来决定先处理哪一个;如果他们的抢占式优先级和响应优先级都相等,则根据他们在中断表中的排位顺序决定先处理哪一个。
(三)中断的优先级
在Cortex-M3中定义了8个比特位用于设置中断源的优先级,这8个比特位可以有8种分配方式,如下:
所有8位用于指定响应优先级
最高1位用于指定抢占式优先级,最低7位用于指定响应优先级
最高2位用于指定抢占式优先级,最低6位用于指定响应优先级
最高3位用于指定抢占式优先级,最低5位用于指定响应优先级
最高4位用于指定抢占式优先级,最低4位用于指定响应优先级
最高5位用于指定抢占式优先级,最低3位用于指定响应优先级
最高6位用于指定抢占式优先级,最低2位用于指定响应优先级
最高7位用于指定抢占式优先级,最低1位用于指定响应优先级
Cortex-M3允许具有较少中断源时使用较少的寄存器位指定中断源的优先级,因此STM32把指定中断优先级的寄存器位减少到4位,这4个寄存器位的分组方式如下:
第0组:所有4位用于指定响应优先级
第1组:最高1位用于指定抢占式优先级,最低3位用于指定响应优先级
第2组:最高2位用于指定抢占式优先级,最低2位用于指定响应优先级
第3组:最高3位用于指定抢占式优先级,最低1位用于指定响应优先级
第4组:所有4位用于指定抢占式优先级
(四)具体设置
可以通过调用STM32的固件库中的函数NVIC_PriorityGroupConfig()选择使用哪种优先级分组方式,这个函数的参数有下列5种:
NVIC_PriorityGroup_0 => 选择第0组
NVIC_PriorityGroup_1 => 选择第1组
NVIC_PriorityGroup_2 => 选择第2组
NVIC_PriorityGroup_3 => 选择第3组
NVIC_PriorityGroup_4 => 选择第4组
(五)举例
接下来就是指定中断源的优先级,下面以一个简单的例子说明如何指定中断源的抢占式优先级和响应优先级:
// 选择使用优先级分组第1组
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1); //这里的group0-4怎么选择
// 使能EXTI0中断
NVIC_InitStructure.NVIC_IRQChannel = EXTI0_IRQChannel;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1; // 指定抢占式优先级别1
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; // 指定响应优先级别0
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
// 使能EXTI9_5中断
NVIC_InitStructure.NVIC_IRQChannel = EXTI9_5_IRQChannel;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; // 指定抢占式优先级别0
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1; // 指定响应优先级别1
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
(六)注意事项
1)如果指定的抢占式优先级别或响应优先级别超出了选定的优先级分组所限定的范围,将可能得到意想不到的结果;
2)抢占式优先级别相同的中断源之间没有嵌套关系;
3)如果某个中断源被指定为某个抢占式优先级别,又没有其它中断源处于同一个抢占式优先级别,则可以为这个中断源指定任意有效的响应优先级别。
现在解答我最初的问题
如何设定NVIC_IRQChannelPreemptionPriority 和 NVIC_IRQChannelSubPriority 两项的值。
这个根据应用程序的需要,
例如3个任务,任务1最紧急(它到来的时候必须打断其他任务),任务2和任务3一般(即不必打断对方,但是如果同时到来需要先执行任务2),你可以设置成第1组(第1组:最高1位用于指定抢占式优先级,最低3位用于指定响应优先级)
然后做以下配置:
NVIC_InitStructure.NVIC_IRQChannel = 任务1;
//主优先级为0,最高
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
NVIC_InitStructure.NVIC_IRQChannel = 任务2;
//主优先级为1,低于任务1(能被任务1打断)
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
//次优先级为0,
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
NVIC_InitStructure.NVIC_IRQChannel = 任务3;
//主优先级为1,低于任务1(能被任务1打断)
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
//次优先级为1,低于任务2(不被任务2打断,但同时到来先执行任务2)
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
分享到:
相关推荐
单片机中断优先级是单片机系统设计中的重要概念,它涉及到系统如何处理同时发生的多个中断请求。中断优先级的设置与管理对于确保系统的实时性、可靠性和响应速度至关重要。在本文中,我们将深入探讨单片机中断优先级...
单片机中断优先级实验 本实验的主要目的在于理解AT89C51单片机中断优先级和优先权,并通过PROTEUS设计、仿真基于AT89C51单片机的中断优先级实验,掌握中断编程。实验中,我们将使用PROTEUS设计电路,编写源程序,...
中断优先级是嵌入式系统,特别是微控制器如STM32F103中的关键概念。在嵌入式系统设计中,中断处理是实时性、响应速度和系统效率的重要因素。中断优先级的理解对于开发高效、可靠的软件至关重要。 中断是处理器响应...
MSP430单片机的中断系统设计得非常灵活,提供了多种中断类型和中断优先级机制,以便于用户根据实际需求定制中断响应。 MSP430的中断分为三种:系统复位中断、不可屏蔽中断(NMI)和可屏蔽中断。系统复位中断的中断...
### XS128中断优先级设置详解 #### 一、基础知识概述 XS128是一款由飞思卡尔半导体公司推出的高性能单片机,其强大的功能和丰富的资源使其在嵌入式系统开发领域得到了广泛的应用。其中,中断机制是XS128的一个重要...
中断嵌套和中断优先级是中断系统的重要特性,对于理解和优化实时系统的性能至关重要。 首先,我们来探讨中断嵌套。中断嵌套是指在处理器正在执行一个中断服务程序(ISR)时,如果有更高优先级的中断请求到来,...
### STM32的中断优先级详解 #### 一、引言 STM32微控制器以其高性能、低功耗以及丰富的外设资源而受到广大开发者的青睐。其中,中断处理机制是实现高效实时系统的关键技术之一。本文将详细介绍STM32微控制器中的...
在嵌入式系统和微控制器的设计中,中断优先级是一个至关重要的概念,它关系到系统的实时性和稳定性。本文将深入探讨“OLED_ROSC中断优先级”这一主题,特别是针对SYD8801芯片的中断处理机制。 首先,我们需要理解...
STM32的中断系统非常灵活,支持多达84个中断源,并且允许对中断优先级进行精细的编程。 中断优先级分为两类:抢占式优先级和响应优先级。抢占式优先级决定了当一个中断正在被处理时,如果有另一个更高抢占优先级的...
单片机外中断优先级实验是单片机学习中的一个重要环节,主要目的是了解和掌握单片机如何处理不同优先级的中断请求,并在实际应用中合理配置中断优先级以优化系统响应。在这个实验中,我们将使用Proteus仿真工具进行...
中断系统涉及到中断源、中断优先级、中断嵌套等概念,下面将详细介绍这些知识点。 首先,51单片机(80C51系列)有5个中断源,它们是外部中断0(INT0)、定时/计数器0(Timer0)、外部中断1(INT1)、定时/计数器1...
AVR中断优先级以及中断嵌套处理 AVR中断优先级是由中断向量在中断向量区中的位置确定的,处于低地址的中断向量所对应的中断拥有高优先级。因此,系统复位RESET拥有最高优先级。当多个中断同时发生时,MCU将首先响应...
### Cortex-M3 的中断优先级描述及设置 #### 一、Cortex-M3 中断管理概述 在 Cortex-M3 处理器中,中断管理采用了全新的机制,与之前的 ARM7 大为不同。Cortex-M3 引入了一个称为 NVIC(Nested Vectored Interrupt...
### 51单片机中的中断优先级及嵌套机制详解 #### 一、51单片机中断系统概述 51单片机作为一种广泛应用的微控制器,在许多电子设备和控制系统中发挥着重要作用。其中断系统是其核心特性之一,能够帮助处理突发情况...
LM3S系列微控制器中断优先级应用笔记详细探讨了如何理解和应用LM3S系列微控制器中的中断优先级机制。这份笔记对于深入理解嵌入式系统中的中断管理至关重要,特别是对于那些使用ARM Cortex-M3内核的LM3S系列微控制器...
在这个名为"蓝桥杯第五个实验中断优先级.rar"的压缩包中,包含的应该是与蓝桥杯比赛相关的实践项目,特别是关于CT107D单片机中断优先级管理的实验代码。 CT107D单片机是一种常见的教学和竞赛用微控制器,它集成了...
本文将深入探讨中断优先级、中断屏蔽以及中断系统这三个关键概念,并通过实例分析如何利用中断屏蔽技术来修改中断优先级。 **中断优先级** 中断优先级是指当多个中断同时发生时,处理器根据优先级顺序决定哪个中断...
STM32中断优先级与相关使用概念.zipSTM32中断优先级与相关使用概念.zipSTM32中断优先级与相关使用概念.zipSTM32中断优先级与相关使用概念.zipSTM32中断优先级与相关使用概念.zipSTM32中断优先级与相关使用概念....
STM32中断优先级详细讲解,还有简单的例子。综述,有限级判断,优先级分组等。
理解AT89C51单片机中断优先级和优先权。 用PROTEUS设计、仿真基于AT8951单片机的中断优先级实验。掌握中断编程。 本实验借助PROTEUS仿真能形象直观地演示了AT89C51单片机高、低两级优先级工作原理.