[stm32] Systick

本文介绍了一种利用STM32的SysTick定时器实现精确延时的方法。通过配置SysTick定时器,可以实现稳定的1毫秒中断,进而通过循环检测实现任意毫秒级的延时。


 

(一) 背景介绍
在传统的嵌入式系统软件按中通常实现 Delay(N) 函数的方法为:
for(i=0;i<=x;i++); 
x--;            对应于N毫秒的循环值
对于STM32系列微处理器来说,执行一条指令只有几十个ns,进行for循环时,要实
现N毫秒的x值非常大,而且由于系统频率的宽广,很难计算出延时 N 毫秒的精确值。
针对STM32微处理器,需要重新设计一个新的方法去实现该功能,以实现在程序中使用
Delay(N)。

(二) STM32 SysTick 介绍
Cortex-M3 的内核中包含一个 SysTick 时钟。SysTick 为一个 24 位递减计数器
SysTick 设定初值并使能后,每经过 1 个系统时钟周期,计数值就减 1。计数到 0 时,
SysTick 计数器自动重装初值并继续计数,同时内部的 COUNTFLAG 标志会置位,触发
中断 (如果中断使能情况下)。
在 STM32 的应用中,使用 Cortex-M3 内核的 SysTick 作为定时时钟,设定每一毫秒
产生一次中断,在中断处理函数里对 N 减一,在Delay(N) 函数中循环检测 N 是否为 0,
不为 0 则进行循环等待;若为 0 则关闭 SysTick 时钟,退出函数。
注: 全局变量 TimingDelay , 必须定义为 volatile 类型 , 延迟时间将不随系统时钟频
率改变。

(三) SysTick 库文件
使用ST的函数库使用systick的方法
1、调用SysTick_CounterCmd() -- 失能SysTick计数器
2、调用SysTick_ITConfig () -- 失能SysTick中断
3、调用SysTick_CLKSourceConfig() -- 设置SysTick时钟源。
4、调用SysTick_SetReload() -- 设置SysTick重装载值。
5、调用SysTick_ITConfig () -- 使能SysTick中断
6、调用SysTick_CounterCmd() -- 开启SysTick计数器

(四) SysTick 工程实战

外部晶振为 8 MHz,9倍频,系统时钟为72MHz,SysTick的最高频率为9MHz(最大
为HCLK/8),在这个条件下,把 SysTick 效验值设置成9000,将 SysTick 时钟设
置为9MHz,就能够产生1ms的时间基值,即SysTick产生1ms的中断。

第一步:配置RCC寄存器和SysTick寄存器

复制代码
 1 /****************************************************************************
 2 * 名    称:void RCC_Configuration(void)
 3 * 功    能:系统时钟配置为72MHZ, 外设时钟配置
 4 * 入口参数:无
 5 * 出口参数:无
 6 * 说    明:
 7 * 调用方法:无 
 8 ****************************************************************************/ 
 9 void RCC_Configuration(void){
10   SystemInit();   
11   RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB |RCC_APB2Periph_GPIOC |RCC_APB2Periph_GPIOD |RCC_APB2Periph_GPIOA |RCC_APB2Periph_GPIOE,ENABLE);
12 }
复制代码

写个RCC函数配置系统时钟和外设时钟使能

1 if (SysTick_Config(72000))            //时钟节拍中断时1ms一次  用于定时 
2 { 
3      /* Capture error */ 
4      while (1);
5 }

在主函数中调用库函数SysTick(72000)初始化系统时钟

第二步:配置SysTick中断函数
这里我们定义了一个static __IO uint32_t TimingDelay;全局变量, 用于我们使用 Keil 软件自带的逻辑分析仪来分析.

1 void SysTick_Handler(void)
2 {
3   TimingDelay_Decrement();
4 }

这是一个SysTick中断触发函数,里面调用一个TimingDelay_Decrement()函数,如下:

复制代码
 1 /****************************************************************************
 2 * 名    称:void TimingDelay_Decrement(void)
 3 * 功    能:获取节拍程序
 4 * 入口参数:无
 5 * 出口参数:无
 6 * 说    明:
 7 * 调用方法:无 
 8 ****************************************************************************/  
 9 void TimingDelay_Decrement(void)
10 {
11   if (TimingDelay != 0x00)
12   { 
13     TimingDelay--;
14   }
15 }
复制代码

TimingDelay_Decrement()负责全局变量 TimingDelay每次减1

第三步:编写Delay延时函数

复制代码
 1 /****************************************************************************
 2 * 名    称:void Delay(__IO uint32_t nTime)
 3 * 功    能:定时延时程序 1ms为单位
 4 * 入口参数:无
 5 * 出口参数:无
 6 * 说    明:
 7 * 调用方法:无 
 8 ****************************************************************************/  
 9 void Delay(__IO uint32_t nTime)
10 { 
11   TimingDelay = nTime;
12   while(TimingDelay != 0);
13 }
复制代码

第四步:主函数中调用Delay

复制代码
1 while (1)
2 {
3   GPIO_SetBits(GPIOB, GPIO_Pin_8);     //LED1 亮 
4   Delay(500);                         //延时500ms
5   GPIO_ResetBits(GPIOB, GPIO_Pin_8); //LED1 灭 
6   Delay(500);                         //延时500ms
7 }
复制代码

第五步:仿真

设置一:采用软件仿真(右边是硬件仿真)

设置二:打开波形仿真界面

 

设置三:引入端口

设置四:执行与波形调整

设置五:硬件仿真

设置六:跟踪调试

 

 

资源链接:http://pan.baidu.com/s/1hqmTYhI




本文转自beautifulzzzz博客园博客,原文链接:http://www.cnblogs.com/zjutlitao/p/3839676.html,如需转载请自行联系原作者

### STM32 SysTick 定时器使用教程 #### 一、SysTick定时器概述 SysTick定时器是一个简单易用的倒计数定时器,集成于ARM Cortex-M系列处理器内核之中。该定时器能够提供系统级的时间管理功能,在操作系统调度、任务延迟等方面有着广泛应用[^1]。 #### 二、主要特性 - **高精度**:基于核心频率工作,可以实现微秒级别的精准延时; - **低资源消耗**:仅需少量CPU干预即可完成配置与启动; - **硬件支持**:自动重装载机制使得无需软件介入就能持续触发中断事件; #### 三、寄存器结构说明 SysTick拥有四个关键寄存器来控制其行为模式: | 寄存器名称 | 功能描述 | | --- | --- | | `CTRL` (Control and Status Register) | 控制及状态设置,决定是否开启/关闭定时器及其运行方式等属性| | `LOAD` (Reload Value Register)| 设置每次溢出前的最大计数值| | `VAL`(Current Value Register) | 当前剩余未计满次数值显示| | `CALIB`(Calibration Value Register)| 提供校准参数| 其中最重要的是`CTRL`寄存器,它决定了整个定时过程的核心逻辑[^2]。 #### 四、初始化流程 为了使能并正确配置SysTick定时器,通常按照以下步骤执行: - 配置加载值(load value),即设定一次完整的计数周期长度; - 清零当前计数值(current value register),确保从头开始计算; - 启动定时器,允许产生相应的中断信号; 下面给出一段简单的C语言代码作为实例演示如何利用STM32 HAL库来进行基本的SysTick定时器编程: ```c #include "stm32f1xx_hal.h" void SystemClock_Config(void); static void MX_GPIO_Init(void); int main(void){ // 初始化HAL库 HAL_Init(); // 系统时钟配置 SystemClock_Config(); // GPIO端口初始化 MX_GPIO_Init(); /* 开启systick */ if(HAL_OK != HAL_SYSTICK_Config(SystemCoreClock / 1000)){ Error_Handler(); } while (1){ // 主程序循环体... } } ``` 上述代码片段实现了每毫秒触发一次SysTick中断的效果,这有助于构建稳定可靠的任务调度框架[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值