STM32F103的Systick无法进入SysTick_Handler中断的问题解决

13 篇文章 0 订阅
2 篇文章 0 订阅

今天做了一个小实验,使用STM32的嘀嗒定时器做一个LED闪烁(一秒亮,一秒灭),可是调试了好一阵子,没能达到目的。其实很简单,只不过我忽视了中断文件的存在;其次我的低级错误导致了调试时间过长,LED闪烁的方法写错了。

1、不加Systick中断,先保证LED灯闪烁可用。

2、保证配置Systick的代码是正确的。

3、一定要#include "stm32f10x_it.h"头文件,工程中也要引入该文件。

下面是测试的主函数代码

#ifndef __STM32F10X_H
#define __STM32F10X_H
#include "stm32f10x.h"
#endif

#ifndef __Z_HARDWARE_LED_H
#define __Z_HARDWARE_LED_H
#include "z_hardware_led.h"
#endif

#ifndef __Z_UTIL_TIME_H
#define __Z_UTIL_TIME_H
#include "z_util_time.h"
#endif

int main(void)
{
	
	init_led();
	systick_configuration();

	for(;;)
	{		
		if(systick_timestamp_ms %1000 == 0)
		{
			func_led1_toggle();
		}
		
	}
}

其次是LED灯的代码

#ifndef __Z_HARDWARE_LED_H
#define __Z_HARDWARE_LED_H
#include "z_hardware_led.h"
#endif

void init_led()
{
	GPIO_InitTypeDef GPIO_InitStructure_A;
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA , ENABLE);
	GPIO_InitStructure_A.GPIO_Pin = GPIO_Pin_8 | GPIO_Pin_9;
  GPIO_InitStructure_A.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure_A.GPIO_Mode = GPIO_Mode_Out_PP;
  GPIO_Init(GPIOA, &GPIO_InitStructure_A);
}

void func_led1_on()
{
	GPIO_SetBits(GPIOA, GPIO_Pin_8);
}

void func_led1_off()
{
	GPIO_ResetBits(GPIOA, GPIO_Pin_8);
}

void func_led1_toggle()
{
	if(GPIO_ReadOutputDataBit(GPIOA, GPIO_Pin_8) == Bit_SET)
	{
		GPIO_ResetBits(GPIOA, GPIO_Pin_8);
	}
	else
	{
		GPIO_SetBits(GPIOA, GPIO_Pin_8);
	}
}

void func_led2_on()
{
	GPIO_SetBits(GPIOA, GPIO_Pin_9);
}

void func_led2_off()
{
	GPIO_ResetBits(GPIOA, GPIO_Pin_9);
}	

LED的头文件

#ifndef __STM32F10X_H
#define __STM32F10X_H
#include "stm32f10x.h"
#endif

void init_led(void);
void func_led1_on(void);
void func_led1_off(void);
void func_led1_toggle(void);

void func_led2_on(void);
void func_led2_off(void);

重点是配置Systick的C代码

#ifndef __Z_UTIL_TIME_H
#define __Z_UTIL_TIME_H
#include "z_util_time.h"
#endif

u32 systick_timestamp_ms;

void systick_configuration(void)
{
	while (SysTick_Config(SystemCoreClock/1000)){}
	/* Configure the SysTick handler priority */
  NVIC_SetPriority(SysTick_IRQn, 0x0);
}

void SysTick_Handler(void)
{
   systick_timestamp_ms ++;
}

void delay_us(uint32_t time_us)
{
	SysTick->LOAD = AHB_INPUT * time_us;
	SysTick->VAL = 0x00;
	SysTick->CTRL = 0x00000005;
	for(;!(SysTick->CTRL & 0x00010000););
	SysTick->CTRL = 0x00000004;
}

void delay_ms(uint32_t time_ms)
{
	for(;time_ms-- > 0;)
	{
		delay_us(1000);
	}
}

配置Systick的头文件

#ifndef __STM32F10X_H
#define __STM32F10X_H
#include "stm32f10x.h"
#endif

#include "stm32f10x_it.h"

#define AHB_INPUT 72

extern u32 systick_timestamp_ms;

void systick_configuration(void);
void delay_us(uint32_t time_us);
void delay_ms(uint32_t time_ms);

注意,配置Systick的头文件中,一定要包含#include "stm32f10x_it.h",不引入中断,进不到

void SysTick_Handler(void)
{
   systick_timestamp_ms ++;
}

这个方法中。

还有,stm32f10x_it.c文件中,把SysTick_Handler注释掉。

以上,即可以实现实验要达到的目的,走过的坑,不想再走了。

  • 3
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
引用\[3\]中的代码片段展示了关于SysTick_Handler的定义和实现。在这段代码中,SysTick_Handler是一个中断处理函数,用于处理SysTick定时器中断。在函数中,systick_timestamp_ms变量会自增,用于记录毫秒级的时间戳。这个函数的目的是在每次SysTick定时器中断发生时更新时间戳。\[3\] 在stm32f103中,SysTick_Handler函数的定义和实现可以参考以下代码: ```c void SysTick_Handler(void) { systick_timestamp_ms ++; } ``` 这个函数会在SysTick定时器中断发生时被调用,每次调用时systick_timestamp_ms变量会自增,用于记录毫秒级的时间戳。通过这个函数,你可以在程序中使用systick_timestamp_ms变量来获取当前的时间戳。 #### 引用[.reference_title] - *1* [STM32F103 Systick配置](https://blog.csdn.net/Psidium/article/details/126093328)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [STM32F103Systick无法进入SysTick_Handler中断问题解决](https://blog.csdn.net/lnniyunlong99/article/details/104636389)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值