stm32f103 学习笔记 —— 05 使用SysTick实现硬件延时

  • SysTick定时时间计算(当系统时钟为72M时)

t =重载*(1 / Clk)

Clk = 72M时,t =(72)*(1 / 72M)= 1 us

Clk = 72M时,t =(72000)*(1 / 72M)= 1ms

1s = 1000ms = 1000 000 us = 100 000 000 ns

  • 当系统定时器中断与外设中断进行优先级比较时,只需要把内核外设的中断优先级的四个位按照外设的中断优先级来分组解析即可,即人为的分出抢占优先级和子优先级
  • SysTick_Config()函数
//这个固件库函数在core_com3.h中
静态__INLINE uint32_t SysTick_Config(uint32_t ticks)
{ 
	
	//重载寄存器为24位,最大值为2 ^ 24
  如果(滴答> SysTick_LOAD_RELOAD_Msk)返回(1);           
  
	//配置重装寄存器的初始值
        SysTick-> LOAD =(ticks&SysTick_LOAD_RELOAD_Msk) -  1;      
  
	//配置中断优先级为15,优先级为最低
	NVIC_SetPriority(SysTick_IRQn,(1 << __ NVIC_PRIO_BITS) -  1);
  
	//配置计数器计数器的值
	SysTick-> VAL = 0;   

  //配置系统定时器的时钟为72M
  //使能中断
  //使能系统定时器	
  SysTick-> CTRL = SysTick_CTRL_CLKSOURCE_Msk | 
                   SysTick_CTRL_TICKINT_Msk | 
                   SysTick_CTRL_ENABLE_Msk;                   
  返回(0);                                                 
}

  • 延时函数(软件检测 - 判断计数器的数值)
void SysTick_Delay_us(uint32_t us)
{
	我uint32_t我;
	SysTick_Config(72);
	对于(I = 0; I <我们;我++)
{
		while(!((SysTick-> CTRL)&(1 << 16)));
	}
	SysTick-> CTRL&=〜SysTick_CTRL_ENABLE_Msk;
}
  • 延时函数(利用中断服务函数)
    静态__IO u32 TimingDelay;
     
    / **
      * @brief启动系统滴答定时器SysTick
      * @param无
      * @retval无
      * /
    void SysTick_Init(void)
    {
    	/ * SystemFre * quency / 1000 1ms中断一次
    	 * SystemFrequency / 100000 10us中断一次
    	 * SystemFrequency / 1000000 1us中断一次
    	 * /
    //如果(SysTick_Config(SystemFrequency / 100000))// ST3.0.0库版本
    	如果(SysTick_Config(SystemCoreClock / 100000))// ST3.5.0库版本
    	{ 
    		/ *捕捉错误* / 
    		而(1);
    	}
    }
    
    / **
      * @brief us延时程序,10us为一个单位
      * @参数  
      * @arg nTime:Delay_us(1)则实现的延时为1 * 10us = 10us
      * @retval无
      * /
    void Delay_us(__ IO u32 nTime)
    { 
    	TimingDelay = nTime;	
    
    	//使能滴答定时器  
    	SysTick-> CTRL | = SysTick_CTRL_ENABLE_Msk;
    
    	while(TimingDelay!= 0);
    }
    
    / **
      * @brief获取节拍程序
      * @param无
      * @retval无
      * @注意在SysTick中断函数SysTick_Handler()调用
      * /
    void TimingDelay_Decrement(void)
    {
    	如果(TimingDelay!= 0x00)
    	{ 
    		TimingDelay--;
    	}
    }








  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值