STM32F103系列_使用系统时钟SysTick的延时函数

STM32F103系列_使用系统时钟SysTick的延时函数

设计起因

使用TIM时钟做延时,很浪费TIM,为了充分利用STM32时钟的使用,我们使用很精确的系统时钟来做延时。

代码

Delay.c

//延时函数初始化
#include "stm32f10x.h"
#include "Delay.h"

void Delay_Init(void)
{
	SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK_Div8); //选择外部时钟
}

//微秒延时
void Delay_us(u16 n)
{
	u32 temp;
	SysTick->LOAD = n * 9;					  //时间加载
	SysTick->VAL = 0x00;					  //清空计数器
	SysTick->CTRL |= SysTick_CTRL_ENABLE_Msk; //开始倒数
	do
	{
		temp = SysTick->CTRL;
	} while ((temp & 0x01) && !(temp & (1 << 16))); //等待时间到达
	SysTick->CTRL &= ~SysTick_CTRL_ENABLE_Msk;		//关闭计数器
	SysTick->VAL = 0X00;							//清空计数器
}

//毫秒延时
void Delay_ms(u16 n)
{
	u32 temp;
	SysTick->LOAD = (u32)n * 9000;			  //时间加载
	SysTick->VAL = 0x00;					  //清空计数器
	SysTick->CTRL |= SysTick_CTRL_ENABLE_Msk; //开始倒数
	do
	{
		temp = SysTick->CTRL;
	} while ((temp & 0x01) && !(temp & (1 << 16))); //等待时间到达
	SysTick->CTRL &= ~SysTick_CTRL_ENABLE_Msk;		//关闭计数器
	SysTick->VAL = 0X00;							//清空计数器
}

//秒延时
void Delay_s(u16 n)
{
	for (u16 x = 0; x < n; x++)
	{
		u32 temp;
		SysTick->LOAD = 9000000;				  //时间加载
		SysTick->VAL = 0x00;					  //清空计数器
		SysTick->CTRL |= SysTick_CTRL_ENABLE_Msk; //开始倒数
		do
		{
			temp = SysTick->CTRL;
		} while ((temp & 0x01) && !(temp & (1 << 16))); //等待时间到达
		SysTick->CTRL &= ~SysTick_CTRL_ENABLE_Msk;		//关闭计数器
		SysTick->VAL = 0X00;							//清空计数器
	}
}

Delay.h

#ifndef __DELAY_H
#define __DELAY_H 			   

extern void Delay_Init(void);

extern void Delay_ms(u16 n);
extern void Delay_us(u16 n);
extern void Delay_s(u16 n);

#endif

使用方法

1、在mian函数里调用Delay.h头文件,并调用Delay_Init()初始化延时函数;
2、使用Delay_us()来进行微秒级别延时,延时几微秒,括号内就填上几;
3、使用Delay_ms()来进行毫秒级别延时,延时几毫秒,括号内就填上几;
4、使用Delay_s()来进行秒级别延时,延时几秒,括号内就填上几;

  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
首先,在STM32F103的固件库中,SysTick_Handler函数已经在startup_stm32f10x_hd.s文件中定义,我们不需要手动编写该函数。而是需要在main函数中使用SysTick_Config函数对SysTick定时器进行配置。 以下是一个简单的例子: ```c #include "stm32f10x.h" #include "stm32f10x_conf.h" void Delay(__IO uint32_t nTime); int main(void) { /* 初始化SysTick定时器 */ if (SysTick_Config(SystemCoreClock / 1000)) { /* 定时器初始化失败 */ while (1); } /* 系统时钟为72MHz,每个时钟周期为1/72MHz秒 */ /* SysTick_Config(SystemCoreClock / 1000) 的参数为72MHz时钟下,每1ms触发一次中断 */ while (1) { /* 延时一段时间 */ Delay(1000); } } /* 延时函数使用SysTick定时器 */ void Delay(__IO uint32_t nTime) { TimingDelay = nTime; while(TimingDelay != 0); } /* SysTick中断处理函数 */ void SysTick_Handler(void) { if (TimingDelay != 0x00) { TimingDelay--; } } ``` 在该代码中,我们使用SysTick_Config函数对SysTick定时器进行配置。SysTick_Config函数的参数为时钟周期数,即一次中断触发的时间间隔。在本例中,我们将时钟周期数设置为SystemCoreClock / 1000,即每1ms触发一次中断。 在main函数中,我们使用了一个简单的延时函数Delay来演示SysTick定时器的使用。Delay函数中,我们将一个计数器TimingDelay设置为需要延时的时间,然后在SysTick中断处理函数中递减该计数器,直到计数器为0时,延时结束。 最后,在代码中需要实现SysTick_Handler函数,该函数在SysTick定时器中断发生时被调用,我们在该函数中递减计数器TimingDelay。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

星宸-Darla

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

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

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

打赏作者

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

抵扣说明:

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

余额充值