STM32F030C6外部中断问题

使用STM32F030C6外部中断的时候碰到一个很奇怪的问题:

1、中断线13一直响应(没有外部触发的这个中断);

2、在debug的时候,按下按键触发中断可以进入中断;

3、但下载到单片机中运行,发现中断没有被触发。

4、debug过程中看到中断触发请求寄存器PR13一直是1;

5、如果把延时函数去掉,debug界面看到中断触发请求寄存器PR13一直是0,其实中断还是一直响应,设置一个断点便知道;



根源问题:打开中断复位时钟函数用错了。这个函数RCC_AHBPeriphResetCmd(RCC_APB2Periph_SYSCFG,ENABLE);改为           RCC_APB2PeriphClockCmd(RCC_APB2Periph_SYSCFG,ENABLE);

### STM32F030C6T6 SysTick 定时器使用教程 #### 初始化系统时钟 为了使SysTick定时器正常工作,首先需要初始化STM32F030C6T6的系统时钟。通常情况下,会通过调用一个自定义函数来完成这一过程,在该函数内部设定PLL参数以达到期望的工作频率。 ```c void SystemClock_Config(void){ RCC_OscInitTypeDef RCC_OscInitStruct = {0}; RCC_ClkInitTypeDef RCC_ClkInitStruct = {0}; /* 配置HSE */ RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI; RCC_OscInitStruct.HSIState = RCC_HSI_ON; RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON; RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI_DIV2; RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL16; // 倍频到48MHz if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) { Error_Handler(); } /* 设置AHB分频因子 */ RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2; RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK; RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1; RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2; RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1; if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_1) != HAL_OK) { Error_Handler(); } } ``` 上述代码片段展示了如何配置HSI作为外部高速振荡源并启用PLL以实现更高的CPU运行速度[^3]。 #### 启动SysTick定时器 一旦完成了系统时钟的初始化之后,则可以继续设置SysTick计数器及其重装载值以便于创建周期性的中断事件: ```c #include "stm32f0xx_hal.h" /* SysTick configuration function */ static void MX_SysTick_Init(uint32_t ticks_num) { if (ticks_num < osKernelGetTickCount()) { return ; } /* Set the reload value to generate an interrupt each millisecond */ if (SysTick_Config(ticks_num)) { /* Capture error */ while (1); } } int main(void) { /* Reset of all peripherals, Initializes the Flash interface and the Systick. */ HAL_Init(); /* Configure the system clock */ SystemClock_Config(); /* Initialize all configured peripherals */ ... /* Start scheduler */ osKernelInitialize (); ... /* Initiate systick timer with a tick frequency corresponding to 1ms intervals */ MX_SysTick_Init((SystemCoreClock / 1000U)); /* Infinite loop */ for (;; ) { osDelay(500); } } ``` 这段程序说明了怎样利用`SysTick_Config()` API 来启动SysTick定时器,并将其配置成每毫秒触发一次中断请求IRQ[^2]。 #### 中断服务例程ISR处理 当发生SysTick中断时,处理器将会跳转至对应的向量表地址执行预先编写的ISR(Interrupt Service Routine)。对于RTOS环境而言,这通常是调度器用来管理任务切换的地方;而在裸机编程环境下,则可以根据实际需求编写相应的逻辑响应机制。 ```c void SysTick_Handler(void) { static uint32_t count = 0; count++; if(count >= 1000){ // 模拟一秒间隔 Toggle_LED(); // 切换LED状态或其他操作 count = 0; } } ``` 此部分实现了简单的基于SysTick中断的服务程序,它每隔一秒钟就会改变一次LED的状态。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值