CH32库函数学习——CH32F207外部中断(5)

该文介绍了STM32的外部中断配置步骤,包括GPIO口初始化、NVIC设置和中断服务函数的编写。在配置中,使能AFIO时钟,设置中断线4为下降沿触发,并在中断服务函数中处理中断事件,清除中断标志位。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >



一、配置步骤

1.外部中断配置

  1. GPIO口初始化
  2. 开启IO口复用时钟
  3. 配置中断结构体成员
  4. 配置NVIC分组,并使能中断

代码如下(示例):

	EXTI_InitTypeDef EXTI_InitStructure = {0};
	NVIC_InitTypeDef NVIC_InitStructure = {0};
	
	Key_Init();
	
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE); //②使能 AFIO 时钟
	
	GPIO_EXTILineConfig(GPIO_PortSourceGPIOD,GPIO_PinSource4);    //中断线与IO口映射
	
	EXTI_InitStructure.EXTI_Line = EXTI_Line4;                    //中断线4
	EXTI_InitStructure.EXTI_LineCmd = ENABLE;                     //使能中断中断
	EXTI_InitStructure.EXTI_Mode =  EXTI_Mode_Interrupt;          
	EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;       //下降沿触发
	
	EXTI_Init(&EXTI_InitStructure);
	
	NVIC_InitStructure.NVIC_IRQChannel = EXTI4_IRQn;               //中断通道2
	NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;  
	NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 2;      //优先级
	NVIC_InitStructure.NVIC_IRQChannelSubPriority = 2;
	
	NVIC_Init(&NVIC_InitStructure);

2.编写中断服务函数

外部中断需要手动清除中断标志位。

代码如下(示例):

void EXTI4_IRQHandler( void )
{
    if( EXTI_GetITStatus( EXTI_Line4 ) != RESET )
    {
		Delay_Ms(10);
		if(KEY1==0)
		{
			LED1=!LED1;
		}
        EXTI_ClearITPendingBit( EXTI_Line4 );   /* Clear Flag */
	}
}

总结

外部中断线0~4有单独的中断线,5-9和10-15分别公用两个中断线。系统初始化要定义一次中断优先级分组.
工程源码
PE5->LED
PD4->KEY
PA6->WCH-LINK(RX)

### STM32硬件中断错误解决方案 对于STM32微控制器中的定时器中断立即触发问题,一种常见的原因是配置过程中未正确初始化或管理中断标志位。当启动定时器之后立刻进入了中断服务程序而非等待设定的时间间隔过去,这通常意味着在使能定时器之前已经存在待处理的中断事件或者是软件未能及时清除先前遗留下来的中断请求信号[^1]。 针对上述情况,可以采取如下措施: - **确认计数值设置无误**:确保TIMx->ARR寄存器被赋予了一个合理的自动重装载值,该值决定了两次相邻中断之间的时间跨度;同时也要核查预分频系数(TIMx->PSC),它影响着实际频率。 - **检查并适当调整优先级分配**:通过NVIC_SetPriority() API合理安排各外设产生的异常响应顺序,防止高优先生效而抢占低级别的ISR执行流,造成后者迟迟得不到调度的机会。 - **保证状态机逻辑严谨性**:编写稳健的状态转换机制,在每次完成特定操作(比如读取数据、更新显示等)后都应主动去查询是否有新的外部刺激到来,并据此决定下一步动作方向。 至于串口接收缓冲区非空中断(USART_IT_RXNE)清零失败进而阻碍后续消息抵达的现象,则往往是因为不当调用了`USART_ClearITPendingBit()`方法所致。此API的作用在于向对应的挂起比特位置入‘0’从而解除当前警报条件,但如果时机把握不准就容易引发副作用——即提前抹除了尚未完全消费完毕的数据帧所关联的信息标签,使得系统认为一切正常无需再做进一步通知给应用程序层了[^2]。 为此建议采用更安全可靠的替代做法: ```c void USART1_IRQHandler(void){ if (__HAL_UART_GET_FLAG(&huart1,UART_FLAG_RXNE)){ uint8_t ch; HAL_UART_Receive(&huart1,&ch,1,HAL_MAX_DELAY); // Process received character here __HAL_UART_CLEAR_FLAG(&huart1,UART_FLAG_NE|UART_FLAG_ORE|UART_FLAG_PE); } } ``` 这段代码利用了ST官方库函数来获取和释放资源锁,不仅简化了编程接口而且增强了跨版本兼容性和稳定性。另外值得注意的是只对真正发生过的错误状况进行复位(`__HAL_UART_CLEAR_FLAG`)而不是盲目地把所有可能性一股脑儿消除掉以免破坏正常的通信流程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

咕咕鸟bird

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值