5 STM32标准库函数 之 外部中断/事件控制器(EXTI)所有函数的介绍及使用
- 1. 图片有格式
- 2 文字无格式
- 五 库函数之外部中断/事件控制器(EXTI)所有函数的介绍及使用
- 前言
- 一、图片预览,无格式(CSDN)
- 二、EXTI库函数固件库函数预览
- 2.1 函数EXTI_DeInit
- 2.2 函数EXTI_Init
- 2.3 函数EXTI_StructInit
- 2.4 函数EXTI_GenerateSWInterrupt
- 2.5 函数EXTI_GetFlagStatus
- 2.6 函数EXTI_ClearFlag
- 2.7 函数EXTI_GetITStatus
- 2.8 函数EXTI_ClearITPendingBit
- 该文档修改记录:
- 总结
函数描述格式:
函数名 | 外设函数的名称 |
---|---|
函数原形 | 原形声明 |
功能描述 | 简要解释函数是如何执行的 |
输入参数{x} | 输入参数描述 |
输出参数{x} | 输出参数描述 |
返回值 | 函数的返回值 |
先决条件 | 调用函数前应满足的要求 |
被调用函数 | 其他被该函数调用的库函数 |
缩写定义
缩写 | 外设/单元 |
---|---|
ADC | 模数转换器 |
BKP | 备份寄存器 |
CAN | 控制器局域网模块 |
DMA | 直接内存存取控制器 |
EXTI | 外部中断事件控制器 |
FLASH | 闪存存储器 |
GPIO | 通用输入输出 |
I2C | 内部集成电路 |
IWDG | 独立看门狗 |
NVIC | 嵌套中断向量列表控制器 |
PWR | 电源/功耗控制 |
RCC | 复位与时钟控制器 |
RTC | 实时时钟 |
SPI | 串行外设接口 |
SysTick | 系统嘀嗒定时器 |
TIM | 通用定时器 |
TIM1 | 高级控制定时器 |
USART | 通用同步异步接收发射端 |
WWDG | 窗口看门狗 |
1. 图片有格式
因为从OneNote复制到CSDN上只能是图片,粘贴不了文字,所以就显示图片,在该博客后半部分会补充上相关函数的文字。
如果只是学习了解函数可以看图片,图片有格式,比较友好;需要使用某个函数,可以去博客后半部分copy使用。
2 文字无格式
五 库函数之外部中断/事件控制器(EXTI)所有函数的介绍及使用
前言
外部中断/事件控制器由 19 个产生事件/中断要求的边沿检测器组成。每个输入线可以独立地配置输入类型 (脉冲或挂起)和对应的触发事件(上升沿或下降沿或者双边沿都触发)。每个输入线都可以被独立的屏 蔽。挂起寄存器保持着状态线的中断要求。
函数描述格式:
函数名 外设函数的名称
函数原形 原形声明
功能描述 简要解释函数是如何执行的
输入参数{x} 输入参数描述
输出参数{x} 输出参数描述
返回值 函数的返回值
先决条件 调用函数前应满足的要求
被调用函数 其他被该函数调用的库函数
一、图片预览,无格式(CSDN)
二、EXTI库函数固件库函数预览
函数名 描述
EXTI_DeInit 将外设 EXTI 寄存器重设为缺省值
EXTI_Init 根据 EXTI_InitStruct 中指定的参数初始化外设 EXTI 寄存器
EXTI_StructInit 把 EXTI_InitStruct 中的每一个参数按缺省值填入
EXTI_GenerateSWInterrupt 产生一个软件中断
EXTI_GetFlagStatus 检查指定的 EXTI 线路标志位设置与否
EXTI_ClearFlag 清除 EXTI 线路挂起标志位
EXTI_GetITStatus 检查指定的 EXTI 线路触发请求发生与否
EXTI_ClearITPendingBit 清除 EXTI 线路挂起位
2.1 函数EXTI_DeInit
函数名 EXTI_DeInit
函数原形 void EXTI_DeInit(void)
功能描述 将外设 EXTI 寄存器重设为缺省值
输入参数 无
输出参数 无
返回值 无
先决条件 无
被调用函数 无
例:
/* Resets the EXTI registers to their default reset value */
EXTI_DeInit();
2.2 函数EXTI_Init
函数名 EXTI_Init
函数原形 void EXTI_Init(EXTI_InitTypeDef* EXTI_InitStruct)
功能描述 根据 EXTI_InitStruct 中指定的参数初始化外设 EXTI 寄存器
输入参数 EXTI_InitStruct:指向结构 EXTI_InitTypeDef 的指针,包含了外设 EXTI 的配置信息 参阅 Section:EXTI_InitTypeDef 查阅更多该参数允许取值范围
输出参数 无
返回值 无
先决条件 无
被调用函数 无
EXTI_InitTypeDef structure
typedef struct
{
u32 EXTI_Line;
EXTIMode_TypeDef EXTI_Mode;
EXTIrigger_TypeDef EXTI_Trigger;
FunctionalState EXTI_LineCmd;
} EXTI_InitTypeDef;
EXTI_Line
EXTI_Line 选择了待使能或者失能的外部线路。
_
EXTI_Line 描述
EXTI_Line0 外部中断线 0
EXTI_Line1 外部中断线 1
EXTI_Line2 外部中断线 2
EXTI_Line3 外部中断线 3
EXTI_Line4 外部中断线 4
EXTI_Line5 外部中断线 5
EXTI_Line6 外部中断线 6
EXTI_Line7 外部中断线 7
EXTI_Line8 外部中断线 8
EXTI_Line9 外部中断线 9
EXTI_Line10 外部中断线 10
EXTI_Line11 外部中断线 11
EXTI_Line12 外部中断线 12
EXTI_Line13 外部中断线 13
EXTI_Line14 外部中断线 14
EXTI_Line15 外部中断线 15
EXTI_Line16 外部中断线 16
EXTI_Line17 外部中断线 17
EXTI_Line18 外部中断线 18
EXTI_Mode
EXTI_Mode 设置了被使能线路的模式。
_
EXTI_Mode 描述
EXTI_Mode_Event 设置 EXTI 线路为事件请求
EXTI_Mode_Interrupt 设置 EXTI 线路为中断请求
EXTI_Trigger
EXTI_Trigger 设置了被使能线路的触发边沿。
EXTI_Trigger 描述
EXTI_Trigger_Falling 设置输入线路下降沿为中断请求
EXTI_Trigger_Rising 设置输入线路上升沿为中断请求
EXTI_Trigger_Rising_Falling 设置输入线路上升沿和下降沿为中断请求
EXTI_LineCmd
EXTI_LineCmd 用来定义选中线路的新状态。它可以被设为 ENABLE 或者 DISABLE。 例:
/* Enables external lines 12 and 14 interrupt generation on falling
edge */
EXTI_InitTypeDef EXTI_InitStructure;
EXTI_InitStructure.EXTI_Line = EXTI_Line12 | EXTI_Line14;
EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;
EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;
EXTI_InitStructure.EXTI_LineCmd = ENABLE;
EXTI_Init(&EXTI_InitStructure);
2.3 函数EXTI_StructInit
__
函数名 EXTI_StructInit
函数原形 void EXTI_StructInit(EXTI_InitTypeDef*EXTI_InitStruct)
功能描述 把 EXTI_InitStruct 中的每一个参数按缺省值填入
输入参数 EXTI_InitStruct:指向结构 EXTI_InitTypeDef 的指针,待初始化
输出参数 无
返回值 无
先决条件 无
被调用函数 无
EXTI InitStruct 缺省值
_
成员 缺省值
EXTI_Line EXTI_LineNone
EXTI_Mode EXTI_Mode_Interrupt
EXTI_Trigger EXTI_Trigger_Falling
EXTI_LineCmd DISABLE
例:
/* Initialize the EXTI Init Structure parameters */
EXTI_InitTypeDef EXTI_InitStructure;
EXTI_StructInit(&EXTI_InitStructure);
2.4 函数EXTI_GenerateSWInterrupt
函数名 EXTI_GenerateSWInterrupt
函数原形 void EXTI_GenerateSWInterrupt(u32 EXTI_Line)
功能描述 产生一个软件中断
输入参数 EXTI_Line:待使能或者失能的 EXTI 线路
参阅 Section:EXTI_Line 查阅更多该参数允许取值范围
输出参数 无
返回值 无
先决条件 无
被调用函数 无
例:
/* Generate a software interrupt request */
EXTI_GenerateSWInterrupt(EXTI_Line6);
2.5 函数EXTI_GetFlagStatus
函数名 EXTI_GetFlagStatus
函数原形 FlagStatus EXTI_GetFlagStatus(u32 EXTI_Line)
功能描述 检查指定的 EXTI 线路标志位设置与否
输入参数 EXTI_Line:待检查的 EXTI 线路标志位
参阅 Section:EXTI_Line 查阅更多该参数允许取值范围
输出参数 无
返回值 EXTI_Line 的新状态(SET 或者 RESET)
先决条件 无
被调用函数 无
例:
/* Get the status of EXTI line 8 */
FlagStatus EXTIStatus;
EXTIStatus = EXTI_GetFlagStatus(EXTI_Line8);
2.6 函数EXTI_ClearFlag
函数名 EXTI_ClearFlag
函数原形 void EXTI_ClearFlag(u32 EXTI_Line)
功能描述 清除 EXTI 线路挂起标志位
输入参数 EXTI_Line:待清除标志位的 EXTI 线路
参阅 Section:EXTI_Line 查阅更多该参数允许取值范围
输出参数 无
返回值 无
先决条件 无
被调用函数 无
例:
/* Clear the EXTI line 2 pending flag */
EXTI_ClearFlag(EXTI_Line2);
2.7 函数EXTI_GetITStatus
_
函数名 EXTI_GetITStatus
函数原形 ITStatus EXTI_GetITStatus(u32 EXTI_Line)
功能描述 检查指定的 EXTI 线路触发请求发生与否
输入参数 EXTI_Line:待检查 EXTI 线路的挂起位
参阅 Section:EXTI_Line 查阅更多该参数允许取值范围
输出参数 无
返回值 EXTI_Line 的新状态(SET 或者 RESET)
先决条件 无
被调用函数 无
例:
/* Get the status of EXTI line 8 */
ITStatus EXTIStatus;
EXTIStatus = EXTI_GetITStatus(EXTI_Line8);
2.8 函数EXTI_ClearITPendingBit
函数名 EXTI_ClearITPendingBit
函数原形 void EXTI_ClearITPendingBit(u32 EXTI_Line)
功能描述 清除 EXTI 线路挂起位
输入参数 EXTI_Line:待清除 EXTI 线路的挂起位
参阅 Section:EXTI_Line 查阅更多该参数允许取值范围
输出参数 无
返回值 无
先决条件 无
被调用函数 无
例:
/* Clears the EXTI line 2 interrupt pending bit */
EXTI_ClearITpendingBit(EXTI_Line2);
该文档修改记录:
修改时间 | 修改说明 |
---|---|
2023年8月20日 | 第一次发布,介绍了STM32外部中断/事件控制器(EXTI)所有函数的介绍及使用 |
总结
以上就是3 STM32标准库函数 之 外部中断/事件控制器(EXTI)所有函数的介绍及使用的内容,本文介绍了 外部中断/事件控制器(EXTI)所有函数的介绍及使用所有函数的简单使用。
有不明白的地方欢迎留言;有建议欢迎留言,我后面编写文档好改进。
创作不容,如果文档对您有帮助,记得给个赞。