一、背景
USB在持续通信几十万次后,会出现USB IN中断丢失几次的情况,分析是中断优先级不够高,导
致USB中断在排队,然而排队还未完成,又有新的USB中断发生,致使其中断丢失。LPC1769的所有中
断默认为最高优先级""(数字越低,优先级越高),因此能想到的第一个解决办法既是降低除USB外所
有中断的优先级。
本篇即对LPC1769的中断优先级及优先级分组做个概述。
附:LPC1768/LPC1769除支持最高主频不同外,其他暂时没发现有什么差别。 二、正文
首先,说说中断优先级,所有中断均有一个优先级,
、 更低的优先级数字代表着更高优先级
、 除了RESET, Hard fault, NMI等系统级中断,其他所有中断优先级均可配置为"0~31"。
如果软件没有配置这些中断的优先级,那么所有中断的优先级默认为最高优先级""。此处
实例说明这个中断优先级的概念,假设三个外部中断"A,B,C","A,B"配置为"","C"配置为"",
、 如果三个中断同时产生,那么"A,B"中断优先"C"中断运行。
、 "A,B"中断同时产生,谁更优先执行呢?那就根据中断向量表的排号,低的优先执行。
、 若是"C"的中断正在运行,此时"A"的中断发生,那么"A"的中断会抢占"C"的执行权限,优先
执行。
、 若是"A"的中断正在运行,此时"B"的中断发生,那么新产生的"B"中断会进入等待状态,等
待"A"执行完毕再执行。
以上,只是单纯的判断优先级值来控制中断的顺序,为了增强中断的控制逻辑,ARM新增了优先级
组的概念。即相同的优先级等级可以分配在一组优先级内,在这一组优先级内再来定义次优先级,具
体是怎么一个概念呢?还是假设有四个中断"A,B,C,D","A,B,C"配置在优先级组""内,"A,B"中断配
置次优先级"","C"配置为次优先级"","D"则配置为优先级组""
、 若"A,D"中断同时产生,则优先级高的"A"会优于"D"中断执行。
、 若"A,C"中断同时产生,则优先级次优先级高的"A"会优先执行。
、 若"A,B"中断同时产生,则根据中断向量表的位置,排号低的优先执行。
、 若"D"正在执行中断,此时"A"中断来了,那么"A"中断会抢占"D"中断优先执行。因为"A"所
在的优先级组高于"D"。
、 若"C"正在执行中断,此时"A"中断来了,那么"A"中断会等待"C"执行完毕再执行。因为属于
同一优先级组。
ARM用了一个8位寄存器来定义优先级组和次优先级的概念。中间可以选择一个端点,高位表示有
多少个主优先级,低位表示有多少个次优先级。
而LPC1769只用了其中5位。具体如下图:

**********************************************************************************

        以上图的1768选定的端点为例,上图表示有"2^3=8"个优先级组,因为高三位用来定义优先级
组,同理,低二位用来定义次优先级有"2^2=4"个。
接着用实例来解释:
在LPC1769提供的"core_cm3.h"提供了定义优先级组和次优先级的函数。
定义优先级组函数:
__STATIC_INLINE void NVIC_SetPriorityGrouping(uint32_t PriorityGroup)
// PriorityGroup参数按上文所写,由于LPC1769只用了5位,所以传入的参数范围为"2~7"
// 对应的优先级组与次优先级如下图

        // 我选择的优先级组为8个,次优先级为4个。代码如下:
NVIC_SetPriorityGrouping(0x04);
接着,定义次优先级函数:
__STATIC_INLINE void NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority)
// 参数IRQn代表中断向量值,该值定义在文件"LPC17xx.h"内
/** @brief IRQ interrupt source definition */
typedef enum IRQn
{
/****** Cortex-M3 Processor Exceptions Numbers ********************/
...
Reset_IRQn = -,
... /****** LPC17xx Specific Interrupt Numbers *************************/ ...
USB_IRQn = ,
...
} IRQn_Type;
// 参数priority
// 代表中断优先级值,范围还是为"0~31",因此需要我们自己算好优先级组所处的位置
// 以我定义的8个优先级组来说,那么值"0~3"为优先级组"0",..."28~31"为优先级组"7"。
NVIC_SetPriority(USB_IRQn,); //处于优先级组"0"
NVIC_SetPriority(TIMER0_IRQn,); // 处于优先级组"1" 至此,记录完毕。 记录时间:--
记录地点:深圳WZ

LPC1768\1769之中断优先级与中断优先级组的更多相关文章

  1. LPC1768/1769之CAN控制器概述(附库函数下载地址)

    一.背景: 使用LPC1769来做CAN的收发,在此对使用LPC1769的CAN控制器进行收发做个总结和记录,以备下 次开发快速上手使用. 附:LPC1768/1769除了支持最高频率不同以外,其它基 ...

  2. STM32中断编程三步曲教你弄会中断设置以及中断优先级设置

    中断作为stm32中必不可少的一个功能,其重要性是不言而喻的因此把中断学习好是根本. 所以今天就来好好啃一下中断配置的知识,俗话说:磨刀不误砍柴工.问题是什么呢?项目中我用到了一个触摸键盘TTP229 ...

  3. MCS-51系统中断优先级的软扩展

    摘要:鉴于MCS-51系统只提供“二级中断嵌套”,提出扩展51系统中断优先级的纯软件方法.其利用51系统内建的中断允许寄存器IE和中断优先级寄存器IP,通过屏蔽字机制来实现:以C51的形式,给出这种扩 ...

  4. 【STM32】IIC的基本原理(实例:普通IO口模拟IIC时序读取24C02)(转载)

     版权声明:本文为博主原创文章,允许转载,但希望标注转载来源. https://blog.csdn.net/qq_38410730/article/details/80312357 IIC的基本介绍 ...

  5. FreeRTOS笔记

    任务的创建和删除(静态方法) 任务创建后要开启调度器. FreeRTOSConfig.h 1. 改宏 使能静态创建函数. 会出现,有两个函数未定义. Cortex-M中断管理(上) NVIC:嵌套向量 ...

  6. stm32f103的低功耗开启和关闭

    stm32f103低功耗分为WFI等待中断和WFE等待事件,我只用到等待中断,这里没有细究. 待机模式最低功耗2uA,只有备份寄存器和待机电路供电,PLL,HSI,HSE断开,寄存器和SRAM复位,除 ...

  7. FreeRTOS相关转载-(朱工的专栏)

    FreeRTOS系列第1篇---为什么选择FreeRTOS? 1.为什么学习RTOS? 作为基于ARM7.Cortex-M3硬件开发的嵌入式工程师,我一直反对使用RTOS.不仅因为不恰当的使用RTOS ...

  8. FreeRTOS初步认识

    源:FreeRTOS初步认识 用了半天时间对FreeRTOS有了一个初步的认识,大概总结一下,其中混杂了系统实现和实际应用方面的问题. 现只是以应用为目的,实现方面待以后进一步研究. 1.FreeRT ...

  9. STM32学习笔记(四)——串口控制LED(中断方式)

    目录: 一.时钟使能,包括GPIO的时钟和串口的时钟使能 二.设置引脚复用映射 三.GPIO的初始化配置,注意要设置为复用模式 四.串口参数初始化配置 五.中断分组和中断优先级配置 六.设置串口中断类 ...

随机推荐

  1. Dynamic Programming [Algorithm]

    今天学习动态规划01背包问题,从一篇非常不错的文章中学习甚多.转载于此,感谢作者的分享! 原文地址 通过金矿模型介绍动态规划 对于动态规划,每个刚接触的人都需要一段时间来理解,特别是第一次接触的时候总 ...

  2. uva 129 krypton factors ——yhx

     Krypton Factor  You have been employed by the organisers of a Super Krypton Factor Contest in which ...

  3. LeetCode题解-----Sliding Window Maximum

    题目描述: Given an array nums, there is a sliding window of size k which is moving from the very left of ...

  4. 跨应用使用Spoon框架截图的方法

    spoon框架是一个很棒的用例驱动跟测试结果生成加工的框架.但在使用spoon-client时,传入参数需要被测应用的activity实例,跨应用测试会很受限(当然也可能是因为我对android不熟导 ...

  5. [LeetCode] Flip Game 翻转游戏之二

    You are playing the following Flip Game with your friend: Given a string that contains only these tw ...

  6. .net core 源码解析-web app是如何启动并接收处理请求

    最近.net core 1.1也发布了,蹒跚学步的小孩又长高了一些,园子里大家也都非常积极的在学习,闲来无事,扒拔源码,涨涨见识. 先来见识一下web站点是如何启动的,如何接受请求,.net core ...

  7. SpringMVC的小总结

    ---恢复内容开始--- 前言: springMVC是我接触的第一个框架,当时在学校学习的时候还是各种懂,最简单的springMVC框架的配置还是比较熟,后来工作之后,虽然主要用的确实是springM ...

  8. 【BZOJ 4580】【Usaco2016 Open】248

    http://www.lydsy.com/JudgeOnline/problem.php?id=4580 区间dp,f(i,j)表示区间[i,j]全部合成一个数,这个数是多少. 可以归纳证明[i,j] ...

  9. neo4j初次使用学习简单操作-cypher语言使用

    Neo4j 使用cypher语言进行操作 Cypher语言是在学习Neo4j时用到数据库操作语言(DML),涵盖对图数据的增删改查  neo4j数据库简单除暴理解的概念: Neo4j中不存在表的概念, ...

  10. [转]Android自定义控件三部曲系列完全解析(动画, 绘图, 自定义View)

    来源:http://blog.csdn.net/harvic880925/article/details/50995268 一.自定义控件三部曲之动画篇 1.<自定义控件三部曲之动画篇(一)—— ...