STM32F030, 使用嘀嗒定时器Systick实现LED闪烁

本文主要解决两个问题

1 STM32的IO口要反转,怎么实现?

2 嘀嗒定时器systick的配置

解答1:

单片机的口,反转非常easy。sbit led = P1 ^6;  led = ~led;而STM32的口要让它反转。如何实现呢?

非常easy,对想要反转的IO口取异或: GPIOx->ODR ^= GPIO_Pin;

解答2:

SysTick是1个24bit递减计数器

SysTick_Config(SystemFrequency / 10)   函数的形參就是systick重装定时器的值。

systck计数频率为每秒48000000次,所以4800000次就是1/10秒。也就是100ms。

SysTick的重装寄存器决定了定时器频率。

以下介绍STM32中的systick。Systick 部分内容属于NVIC控制部分。一共同拥有4个寄存器,名称和地址各自是:

STK_CSR,        0xE000E010  --  控制寄存器

STK_LOAD,     0xE000E014  --  重载寄存器

STK_VAL,        0xE000E018  --  当前值寄存器

STK_CALRB,   0xE000E01C  --   校准值寄存器

首先看STK_CSR控制寄存器:寄存器内有4个位t具有意义

第0位:ENABLE。Systick 使能位  (0:关闭Systick功能;1:开启Systick功能)

第1位:TICKINT。Systick 中断使能位    (0:关闭Systick中断;1:开启Systick中断)

第2位:CLKSOURCE,Systick时钟源选择  (0:使用HCLK/8 作为Systick时钟;1:使用HCLK作为Systick时钟)

第3位:COUNTFLAG。Systick计数比較标志,假设在上次读取本寄存器后,SysTick 已经数到了0。则该位为1。假设读取该位,该位将自己主动清零

STK_LOAD  重载寄存器:

Systick是一个递减的定时器。当定时器递减至0时,重载寄存器中的值就会被重装载,继续開始递减。STK_LOAD  重载寄存器是个24位的寄存器最大计数0xFFFFFF。

STK_VAL当前值寄存器:

也是个24位的寄存器。读取时返回当前倒计数的值,写它则使之清零,同一时候还会清除在SysTick 控制及状态寄存器中的COUNTFLAG 标志。

STK_CALRB  校准值寄存器:

这个寄存器好像眼下的水平我还用不到,大体意思明确点,把英文说明放这吧:

位31 NOREF :1=没有外部參考时钟(STCLK 不可用)0=外部參考时钟可用

位30 SKEW:1=校准值不是准确的1ms 0=校准值是准确的1ms

位[23:0] :Calibration value

Indicates the calibration value when the SysTick counter runs on HCLK max/8 as external clock. The value is product dependent, please refer to the Product Reference Manual, SysTick Calibration Value section. When HCLK is programmed at the maximum frequency, the SysTick period is 1ms. If calibration information is not known, calculate the calibration value required from the frequency of the processor clock or external clock.

cortex_m0.c文件里定义

<span style="font-size:14px;">/** \brief  System Tick Configuration

    The function initializes the System Timer and its interrupt, and starts the System Tick Timer.
    Counter is in free running mode to generate periodic interrupts.

    \param [in]  ticks  Number of ticks between two interrupts.

    \return          0  Function succeeded.
    \return          1  Function failed.

    \note     When the variable <b>__Vendor_SysTickConfig</b> is set to 1, then the
    function <b>SysTick_Config</b> is not included. In this case, the file <b><i>device</i>.h</b>
    must contain a vendor-specific implementation of this function.

 */
__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks)
{
  if ((ticks - 1) > SysTick_LOAD_RELOAD_Msk)  return (1);      /* Reload value impossible */

  SysTick->LOAD  = ticks - 1;                                  /* set reload register */
  NVIC_SetPriority (SysTick_IRQn, (1<<__NVIC_PRIO_BITS) - 1);  /* set Priority for Systick Interrupt */
  SysTick->VAL   = 0;                                          /* Load the SysTick Counter Value */
  SysTick->CTRL  = SysTick_CTRL_CLKSOURCE_Msk |
                   SysTick_CTRL_TICKINT_Msk   |
                   SysTick_CTRL_ENABLE_Msk;                    /* Enable SysTick IRQ and SysTick Timer */
  return (0);                                                  /* Function successful */
}</span>

<span style="font-size:14px;">#include "SysTick.h"

__IO uint32_t TimingDelay;
uint32_t time_count = 0;
uint16_t idx_led = 0;
//SystemCoreClock/100000) 10 us 进入一次中断
void SysTick_Config_Init(void)
{
	/* SystemFrequency / 1000    1ms中断一次
	* SystemFrequency / 100000	 10us中断一次
	* SystemFrequency / 1000000 1us中断一次
	*/
    if(SysTick_Config(SystemCoreClock/1000))
	{
	    while(1);
	}
		// 关闭滴答定时器
	//SysTick->CTRL &= ~ SysTick_CTRL_ENABLE_Msk;
}

/**
  * @brief  Inserts a delay time.
  * @param  nTime: specifies the delay time length, in milliseconds.
  * @retval None
  */
void Delay_ms(__IO uint32_t nTime)
{
	TimingDelay = nTime;
	// 使能滴答定时器
//	SysTick->CTRL |=  SysTick_CTRL_ENABLE_Msk;

	while(TimingDelay != 0);
}

/**
  * @brief  Decrements the TimingDelay variable.
  * @param  None
  * @retval None
  */
void TimingDelay_Decrement(void)
{
  if (TimingDelay != 0x00)
  {
    TimingDelay--;
  }
}

void SysTick_Handler(void)
{    

	TimingDelay_Decrement();

	idx_led++;
        if(idx_led >= 1000){
		idx_led = 0;
	    GPIOA->ODR^=GPIO_Pin_4;
	}
}</span>
时间: 2024-08-24 02:42:42

STM32F030, 使用嘀嗒定时器Systick实现LED闪烁的相关文章

STM32F103ZET6系统定时器SysTick

1.系统定时器SysTick的简介 系统定时器SysTick属于内核外设,内嵌在NVIC中.SysTick是一个24位的向下递减的计数器,计数器根据SysTick的时钟源计数,当SysTick的计数器计数到0的时候,SysTick就产生一次中断,并且SysTick的重装载寄存器会给计数器重新赋值,以此循环往复. SysTick一般用于带操作系统的应用,用来产生时基,维持操作系统的心跳. 2.SysTick的寄存器 SysTick有4个寄存器: 控制及状态寄存器CTRL: 重装载数值寄存器LOAD

[ZigBee] 16、Zigbee协议栈应用(二)——基于OSAL的无线控制LED闪烁分析(下)

说在前面:上一篇介绍了无线LED闪烁实现的OSAL部分,本篇介绍如何实现无线数据收发及数据处理: 上一篇是用SI跟着流程查看源码,我个人认为以架构的思维去了解代码能让人更清晰 ::ZMain.c程序入口文件 这里chipcon_cstartup.s51是汇编的启动文件,ZMain.c相当于main文件,里面有main函数: 1 int main( void ) 2 { 3 osal_int_disable( INTS_ALL );// Turn off interrupts 关中断 4 HAL_

uC/OS-III学习2::uC/OS-III LED闪烁实验

1 前言: 看完了uC/OS-III的基本介绍之后,大致对这个操作系统有了点了解,但真正的理解还是要通过不断的去使用,在使用中体验uC/OS-III的乐趣和更深的理解其工作原理是非常重要的.因此,我在STM32上面移植好uC/OS-III后,就開始了自己的简单实验学习,至于怎么移植,书上还有网上有非常多參考资料,当然你也能够下载别人移植好的干净的项目project直接用也能够.本文主要介绍一下怎么利用uC/OS-III来控制STM32开发板上面的LED闪烁任务. 2 硬件部分: 这里并不为某个开

[stm32][ucos] 1、基于ucos操作系统的LED闪烁、串口通信简单例程

* 内容简述: 本例程操作系统采用ucos2.86a版本, 建立了5个任务            任务名                                             优先级            APP_TASK_START_PRIO                               2            主任务                          Task_Com1_PRIO                                

由一个LED闪烁问题发现的MTK的LED driver中存在的问题

今天根据最新的需求要对LED灯的提示闪烁频率进行修改,将之前默认的2000ms改为10000ms,但是修改之后没有产生预料中的效果,而是变成了常量,百思不得其解,最后还是read the fucking code,从上层到底层,一路追下来,最终发现了问题所在,下面直接上MTK的LED driver代码: #define PMIC_PERIOD_NUM 9 // 100 * period, ex: 0.01 Hz -> 0.01 * 100 = 1 int pmic_period_array[]

WLGK-51单片机接口技术基础实验 ——LED闪烁灯

WLGK-51单片机接口技术基础实验-LED闪烁灯 当我们开始接触单片机,首先接触的第一个实验就是LED灯的使用,类似于我们学习软件开始接触的第一个程序"HelloWorld",这个实验是带领我们走入"软硬件综合使用"的一个很好入门示例,51单片机是他的一个载体.下面小伙伴们,让我们一起来揭开LED的神秘面纱吧! 万立高科官网:www.wanligaoke.com 万立高科官方商城:http://www.wlgkbj.com 万立高科淘宝直销店铺:https://r

[stm32][ucos][ucgui] 2、LED闪烁、串口、滑块、文本编辑框简单例程

上一篇:[stm32][ucos] 1.基于ucos操作系统的LED闪烁.串口通信简单例程 * 内容简述: 本例程操作系统采用ucos2.86a版本, 建立了7个任务            任务名                                             优先级            APP_TASK_START_PRIO                               2            主任务            APP_TASK_USER_

STM32 的系统滴答定时器( Systick) 彻底研究解读

作者:王健 前言 SysTick 比起那些 TIM 定时器可以说简单多啦~~~~~哥的心情也好了不少, 嘎嘎!! ARM Cortex-M3 内核的处理器内部包含了一个 SysTick 定时器,它是一个24 位的倒计数定时器,注意,是倒计数! 当计到 0 时它就会从 LOAD 寄存器中自动重装载定时初值.只要不把 CTRL 寄存器中的 ENABLE 为清 0,它就永不停息! 遗憾的是,SysTick 定时器在<STM32 参考手册>里一个屁都没放,只有在<ARM Cortex-M3 技术

Cortex系统定时器--SysTick

1.SysTick寄存器结构 SYSTICK 寄存器结构,SysTick_TypeDeff,在文件"stm32f10x_map.h"中定义如下: typedef struct  {     vu32 CTRL;      vu32 LOAD;      vu32 VAL;      vuc32 CALIB;  } SysTick_TypeDef; SysTick 外设声明于文件"stm32f10x_map.h": #define SCS_BASE ((u32)0xE