第5章-stm32单片机外部中断1PPT格式课件下载.ppt

上传人:wj 文档编号:231702 上传时间:2023-04-28 格式:PPT 页数:66 大小:5.49MB
下载 相关 举报
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第1页
第1页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第2页
第2页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第3页
第3页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第4页
第4页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第5页
第5页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第6页
第6页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第7页
第7页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第8页
第8页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第9页
第9页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第10页
第10页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第11页
第11页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第12页
第12页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第13页
第13页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第14页
第14页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第15页
第15页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第16页
第16页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第17页
第17页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第18页
第18页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第19页
第19页 / 共66页
第5章-stm32单片机外部中断1PPT格式课件下载.ppt_第20页
第20页 / 共66页
亲,该文档总共66页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

第5章-stm32单片机外部中断1PPT格式课件下载.ppt

《第5章-stm32单片机外部中断1PPT格式课件下载.ppt》由会员分享,可在线阅读,更多相关《第5章-stm32单片机外部中断1PPT格式课件下载.ppt(66页珍藏版)》请在冰点文库上搜索。

第5章-stm32单片机外部中断1PPT格式课件下载.ppt

可屏蔽中断源包括:

外部中断、定时器中断、串口中断直接内存访问中断模数转换中断集成电路总线中断串行外设接口中断等。

5.2.2中断向量:

表5-1给出STM32F103中断向量表,5.3中断控制,5.3.1中断屏蔽控制中断屏蔽控制包括NVIC控制和外设中断控制EXTI。

NVIC为中断总开关,由中断设置允许寄存器(NVIC_ISER)、中断清除允许寄存器(NVIC_ICER)、中断设置挂起寄存器(NVIC_ISPR)、中断清除挂起寄存器(NVIC_ICPR)和中断状态寄存器(NVIC_IABR)控制。

除GPIO由EXTI控制中断外,其它的外设均有自己的中断屏蔽控制寄存器,如定时器中断由DMA/中断使能寄存器(TIM_DIER)控制、串口中断由状态寄存器(USART_SR)和控制寄存器3(USART_CR3)控制。

5.3.2中断控制器,NVIC为中断总开关:

支持68个可屏蔽中断。

提供16个可编程的优先级,支持中断嵌套,提供向量中断处理机制等功能。

中断发生时,自动获得服务例程入口地址并直接调用,无需软件判定中断源。

主要包括:

中断设置允许寄存器(NVIC_ISER)中断清除允许寄存器(NVIC_ICER)中断设置挂起寄存器(NVIC_ISPR)中断清除挂起寄存器(NVIC_ICPR)中断状态寄存器(NVIC_IABR)控制。

5.3.2中断控制器,与NVIC相关的寄存器在“stm32f10x_map.h”文件中定义了一个结构体,结构体的内容如下STM32F103系列单片机的中断系统在这些寄存器的控制下有序执行。

了解这些中断寄存器的含义,才能更好的理解STM32单片机中断系统的工作原理,typedefstructvu32ISER2;

u32RESERVED030;

vu32ICER2;

u32RESERVED130;

vu32ISPR2;

u32RESERVED230;

vu32ICPR2;

u32RESERVED330;

vu32IABR2;

u32RESERVED430;

vu32IPR15;

NVIC_TypeDef,5.3.2中断控制器,ISER2:

ISER全称是:

InterruptSet-EnableRegisters,中断使能寄存器组。

STM32F103系列的单片机可屏蔽外部中断有60个,用2个32位的ISER寄存器来表示,这2个32位的寄存器总共可以表示64个外部中断。

而STM32F103系列单片机只用了ISER寄存器其中的前60位。

ISER0的bit0bit31分别对应是外部中断031。

ISER1的bit027对应外部中断3259;

这样总共60个外部中断就分别对应上了。

使能某个中断,必须设置相应的ISER位为1,5.3.2中断控制器,具体有哪些外部中断,在“stm32f10x_nvic.h”这个头文件中已经定义,5.3.2中断控制器,5.3.2中断控制器,ICER2:

全称InterruptClear-EnableRegisters,是一个中断清除使能寄存器组。

该寄存器组与ISER寄存器功能相反,用来清除某个中断的使能位。

由于NVIC的这些寄存器都是写1有效的,写0是无效的。

设置一组ICER寄存器来清除相应中断使能位。

ISPR2:

全称InterruptSet-PendingRegisters,是一个中断挂起控制寄存器组。

每个位对应的外部中断和ISER内容是一样的。

通过向相应的位写1,可以将正在执行的中断挂起,去执行同级或更高级别的中断。

向这个寄存器组写0是无效的。

5.3.2中断控制器,ICPR2:

全称InterruptClear-PendingRegisters,是单片机的中断解挂寄存器组。

其功能和ISPR寄存器相反,对应位的内容也和ISER寄存器是一样的。

通过写1,可以将相应的中断解挂。

写0无效。

IABR2:

全称InterruptActiveBitRegisters,单片机中断激活标志位寄存器组。

它是一个只读寄存器,CPU通过读取这个寄存器的相应位就可以知道当前有哪些中断正在执行。

在相应的中断执行完成以后由硬件自动清零。

对应位所代表的中断内容和ISER一样,如果相应位为1,则表示该位所对应的中断正在被执行。

5.3.2中断控制器,IPR15:

全称InterruptPriorityRegisters,是一个中断优先级控制的寄存器组。

这个寄存器组比较重要,STM32F103系列单片机的外部中断分组与这个寄存器组密切相关。

因为STM32F103系列单片机的外部中断有60个,所以采用中断分组的办法来确定中断的优先级。

IPR寄存器组由15个32位的寄存器组成,每个可屏蔽中断占用8位IPR0的07,815,1623,2431分别对应中断编号为03,依此类推,总共对应60个外部中断。

而每个可屏蔽中断占用的8bit并没有全部使用,只采用高4位。

这4位,又分为抢占优先级和响应优先级。

抢占优先级在前,响应优先级在后。

5.3.2中断控制器,STM32F103系列单片机外部中断分为5个组,组04。

分组的设置是由SCB-AIRCR寄存器的bit108这3位来定义的。

具体的分配关系如下表所示:

5.3.2中断控制器,为使STM32单片机的中断系统能及时响应并处理发生的所有中断,系统根据引起中断事件的重要性和紧迫程度,STM32单片机的硬件将外设的中断源分为2个级别,这2个级别就是STM32F103系列单片机的抢占优先级和响应优先级;

如果两个中断源的抢占优先级和响应优先级都是一样的话,则看哪个中断先发生就先执行;

高抢占优先级中断是可以打断正在进行的低抢占优先级中断的。

而抢占优先级相同的中断,高响应优先级中断不可以打断正在执行的低响应优先级中断。

抢占优先级和响应优先级,响应优先级可设置为0到15级。

判断两个中断的优先级时:

(1)先看抢占优先级的高低;

(2)再看响应优先级的高低;

(3)看中断通道向量地址。

一个系统使用一个组别就完全可以满足需要,在使用一个组别后不要在系统中再改动组别。

抢占优先级和响应优先级,5.3.2中断控制器,5.3.2中断控制器,假定设置中断优先级为组2,然后设置:

中断3(RTC中断)的抢占优先级为2,响应优先级为1。

中断6(外部中断0)的抢占优先级为3,响应优先级为0。

中断7(外部中断1)的抢占优先级为2,响应优先级为0。

求这3个中断的优先级顺序?

上面例子中的中断3和中断7都可以打断中断6的中断。

而中断7和中断3却不可以相互打断(这是因为他们的抢占优先级是相同的)。

抢占优先级和响应优先级,外部中断/事件控制器EXTI,主要特性:

(1)每个中断/事件都有独立的触发和屏蔽;

(2)每个中断线都有专用的状态位;

(3)支持多达19个中断/事件请求;

(4)检测脉冲宽度低于APB2时钟宽度的外部信号。

5.3.3相关功能寄存器,1.中断屏蔽寄存器(EXTI_IMR)2.事件屏蔽寄存器(EXTI_EMR)3.上升沿触发选择寄存器(EXTI_RTSR)4.下降沿触发选择寄存器(EXTI_FTSR)5.软件中断事件寄存器(EXTI_SWIER)6.中断挂起寄存器(EXTI_PR),5.3.3相关功能寄存器,EXTI_IMR(Interruptmaskregister)中断屏蔽寄存器,5.3.3相关功能寄存器,EXTI_EMR(Eventmaskregister)中断事件屏蔽寄存器,5.3.3相关功能寄存器,EXTI_RTSR(Risingtriggerselectionregister)上升沿触发寄存器,5.3.3相关功能寄存器,EXTI_FTSR(Fallingtriggerselectionregister)下降沿触发器,5.3.3相关功能寄存器,EXTI_SWIER(Softwareinterrupteventregister)软件中断事件寄存器,5.3.3相关功能寄存器,EXTI_PR(PendingRegister)中断挂起寄存器,5.3.3相关功能寄存器,5.4中断执行过程和中断嵌套,1中断请求和优先级如果系统中存在多个中断源,处理器要先判断当前中断的优先级。

多个中断请求同时到达时,先响应优先级高的中断。

如果它们的抢占优先级相同,则先处理响应优先级高的中断。

如果内核正在执行C的中断服务程序,则能被抢占优先级更高的中断A打断;

由于B和C的抢占优先级相同,所以C不会被B打断;

但如果B和C两个中断同时到达,则响应优先级更高的B会被先执行。

5.5STM32外部中断应用设计,5.5.1STM32外部中断常用的库函数,5.5.2STM32中断的设计,1.NVIC设置

(1)根据需要对中断优先级进行分组,确定抢占优先级和响应优先级的个数。

(2)选择中断通道,不同的引脚对应不同的中断通道,在stm32f10x.h中定义了中断通道结构体IRQn_Type,包含了所有型号芯片的所有中断通道。

(3)根据系统要求设置中断优先级,包括抢占优先级和响应优先级。

(4)使能相应的中断,完成NVIC配置。

5.5.2STM32中断的设计,使用库函数NVIC_PriorityGroupConfig()实现STM32F103系列的单片机中断系统分组,5.5.2STM32中断的设计,入口参数NVIC_PriorityGroup,5.5.2STM32中断的设计,举例:

如代码的第17行所示,利用“NVIC_PriorityGroupConfig()”库函数将外部中断分为组2。

即,抢占优先级可以设置为0-3,响应优先级也是可以设置为0-3的,这是因为它们抢占优先级占2位,响应优先级也占2位。

5.5.2STM32中断的设计,结构体“NVIC_InitTypeDef”定义,typedefstructuint8_tNVIC_IRQChannel;

uint8_tNVIC_IRQChannelPreemptionPriority;

uint8_tNVIC_IRQChannelSubPriority;

FunctionalStateNVIC_IRQChannelCmd;

NVIC_InitTypeDef;

5.5.2STM32中断的设计,NVIC_IRQChannel这个参数就是让我们选择需要配置的中断向量的值,如下表所示,5.5.2STM32中断的设计,5.5.2STM32中断的设计,NVIC_IRQChannelPreemptionPriority该参数设置了成员NVIC_IRQChannel中的抢占优先级的优先级别。

NVIC_IRQChannelSubPriority该参数设置了成员NVIC_IRQChannel中的响应优先级的优先级别,5.5.2STM32中断的设计,第0组:

先占优先级(抢占优先级)占0位,从优先级(响应优先级)占4位,所以说NVIC_IRQChannelPreemptionPriority这个参数的值只能设置为0,NVIC_IRQChannelSubPriority这个参数值可以设置为0-15;

第1组:

先占优先级(抢占优先级)占1位,从优先级(响应优先级)占3位,所以说NVIC_IRQChannelPreemptionPriority这个参数的值可以设置为0-1,NVIC_IRQChannelSubPriority这个参数的值可以设置为0-7;

第2组:

先占优先级(抢占优先级)占2位,从优先级(响应优先级)占2位,所以说NVIC_IRQChannelPreemptionPriority这个参数的值可以设置为0-3,NVIC_IRQChannelSubPriority这个参数的值可以设置为0-3;

第3组:

先占优先级(抢占优先级)占3位,从优先级(响应优先级)占1位,所以说NVIC_IRQChannelPreemptionPriority值可以设置为0-7,NVIC_IRQChannelSubPriority值可以设置为0-1;

第4组:

先占优先级(抢占优先级)占4位,从优先级(响应优先级)占0位,所以说NVIC_IRQChannelPreemptionPriority这个参数的值可以设置为0-15,NVIC_IRQChannelSubPriority这个参数的值只能设置为0;

5.5.2STM32中断的设计,NVIC_IRQChannelCmd该参数用来使能或者关闭指定的IRQ通道。

下面例子给出如何用库函数配置STM32F103系列单片机的外部中断:

程序代码的第14行定义了一个“NVIC_InitTypeDef”结构体类型的变量。

第17行:

设置NVIC中断分组2,2位抢占优先级,2位响应优先级;

第18行:

设置外部I0口的第5-9引脚为中断通道;

第19行:

抢占优先级为2;

第20行:

响应优先级为2;

第21行:

使能外部中断通道;

第22行:

根据NVIC_InitStructure结构体中指定的参数初始化外设NVIC寄存器;

5.5.2STM32中断的设计,2.中断端口配置

(1)首先要对引脚进行配置,使能引脚,具体方法参考第4章,如果使用了复用功能需要打开复用时钟。

(2)然后对外部中断方式进行配置,包括中断线路设置、中断或事件选择、触发方式设置、使能中断线完成设置。

其中中断线路EXTI_Line0EXTI_Line15分别对应EXTI0EXTI15,即每个端口的16个引脚。

EXTI_Line16EXTI_Line18分别对应PVD输出事件、RTC闹钟事件和USB唤醒事件。

5.5.3STM32外部中断应用实例,通过按键中断实现LED的亮灭控制,利用STM32F10x的GPIO功能驱动LED。

采用PA8连接LED,PB6接按键开关。

STM32外部中断,STM32单片机80个通用I/O端口连接到19个外部中断/事件源上。

左图为STM32单片机通用I/O与外部中断的映射关系:

PAx、PBx、PCx、PDx和PEx端口对应的是同一个外部中断/事件源EXTIx(x:

0-15)。

5.5.3STM32外部中断应用实例,这个库函数的功能就是选择哪个IO引脚作为外部中断线路,它有2个输入参数,第一个输入参数GPIO_PortSource,作用是选择哪一组GPIO端口作为外部中断源,它的值可取下表中的任意一个值:

5.5.3STM32外部中断应用实例,输入参数GPIO_PinSource:

这个参数可以选择GPIO端口的某个引脚作为中断源的输入。

5.5.3STM32外部中断应用实例,intmain(void)NVIC_Configuration();

/NVICLED_Config();

/GPIO-LEDKEY_Config();

/GPIO-KEYGPIO_ResetBits(GPIOB,GPIO_Pin_8);

/低电平,点亮LEDwhile

(1),5.5.3STM32外部中断应用实例,voidNVIC_Configuration(void)NVIC_InitTypeDefNVIC_InitStructure;

NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);

NVIC_InitStructure.NVIC_IRQChannel=EXTI9_5_IRQn;

NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=0;

NVIC_InitStructure.NVIC_IRQChannelSubPriority=0;

NVIC_InitStructure.NVIC_IRQChannelCmd=ENABLE;

NVIC_Init(,5.5.3STM32外部中断应用实例,voidLED_Config(void)GPIO_InitTypeDefGPIO_InitStructure;

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);

GPIO_InitStructure.GPIO_Pin=GPIO_Pin_8;

GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;

GPIO_InitStructure.GPIO_Mode=GPIO_Mode_Out_PP;

GPIO_Init(GPIOA,5.5.3STM32外部中断应用实例,voidKEY_Config(void)GPIO_InitTypeDefGPIO_InitStructure;

EXTI_InitTypeDefEXTI_InitStructure;

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB|RCC_APB2Periph_AFIO,ENABLE);

GPIO_InitStructure.GPIO_Pin=GPIO_Pin_6;

GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IPU;

GPIO_Init(GPIOB,5.5.3STM32外部中断应用实例,GPIO_EXTILineConfig(GPIO_PortSourceGPIOB,GPIO_PinSource6);

EXTI_InitStructure.EXTI_Line=EXTI_Line6;

EXTI_InitStructure.EXTI_Mode=EXTI_Mode_Interrupt;

EXTI_InitStructure.EXTI_Trigger=EXTI_Trigger_Falling;

EXTI_InitStructure.EXTI_LineCmd=ENABLE;

EXTI_Init(,5.5.3STM32外部中断应用实例,voidKEY_Config(void)中定义了一个“EXTI_InitStructure”,这个结构体类型在库文件中如下定义:

Typedefstructuint32_tEXTI_Line;

EXTIMode_TypeDefEXTI_Mode;

EXTITrigger_TypeDefEXTI_Trigger;

FunctionalStateEXTI_LineCmd;

EXTI_InitTypeDef,5.5.3STM32外部中断应用实例,1:

uint32_tEXTI_Line这个参数就是让我们选择哪条外部的中断线,该参数可取的值,5.5.3STM32外部中断应用实例,EXTI_Mode该参数让我们设置中断线路的模式,是事件请求还是中断请求,该参数可取的值:

STM32单片机的中断与事件有何区别?

5.5.3STM32外部中断应用实例,5.5.3STM32外部中断应用实例,中断是需要CPU参与的,需要软件的中断服务函数才能完成,中断后产生相应的结果;

事件是靠脉冲发生器产生一个脉冲,进而由硬件自动完成这个事件,并且产生相应的结果。

可以这样简单的认为,事件机制提供了一个完全有硬件自动完成触发到产生结果的这么一个通道,不需要软件的参与,降低了CPU的负荷,节省了中断资源,提高了响应速度(硬件总快于软件),事件是利用硬件来提升CPU芯片处理事件能力的一个有效方法。

5.5.3STM32外部中断应用实例,EXTI_Trigger设置了线路的触发边沿(3种触发方式:

上升沿触发,下降沿触发和上升沿和下降沿触发)EXTI_LineCmd用来开启或者关闭选中线路。

它可以被设为ENABLE或者DISABLE。

5.5.3STM32外部中断应用实例,voidKEY_Config(void)GPIO_InitTypeDefGPIO_InitStructure;

EXTI_Init(,5.5.3STM32外部中断应用实例,RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB|RCC_APB2Periph_AFIO,ENABLE);

如果我们在编程中,用的是IO口的复用功能,就必须开启该复用时钟,当把GPIO相应的引脚作为外部中断输入的时候,就是用到了IO的复用功能,所以必须要开启复用功能时钟(AFIO)。

当KEY1按下时,就会在PB6这个引脚上面产生一个下降沿中断,这时程序就会跳到中断服务函数就执行,5.5.3STM32外部中断应用实例,5.5.3STM32外部中断应用实例,voidEXTI9_5_IRQHandler(void)if(EXTI_GetITStatus(EXTI_Line6)!

=RESET)GPIO_WriteBit(GPIOA,GPIO_Pin_8,(BitAction)(1-GPIO_ReadOutputDataBit(GPIOA,GPIO_Pin_8);

EXTI_ClearITPendingBit(EXTI_Line6);

5.5.3STM32外部中断应用

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > IT计算机 > 电脑基础知识

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2