让LCD闪烁起来:STM32F4SysTick的设置与使用

发布者:Tianyun2021最新更新时间:2017-02-06 来源: eefocus关键字:LCD闪烁  STM32F4  SysTick 手机看文章 扫描二维码
随时随地手机看文章

在这节中, 我打算利用SysTick定时器做延时, 让STM32F429 Discovery板子上的两个灯闪烁起来.

SysTick包含于Cortex核心中, 在不同厂家的Cortex产品中都存在. 它本质上是一个24位的倒计数器, 在STM32F429中, 它对SYSCLK经过AHB预分频器分频后的时钟或分频后的时钟的8分频计数(不同的CPU时钟来源可能不会相同, 请参考数据手册中的时钟树), 当倒计数至0时将会产生一个中断(如果使能中断的话), 中断异常号为15. 它的存在是为RTOS提供一个系统节拍, 或者为任务调度产生一个周期性的中断, 可以使得程序在不同厂商的器件之间移植工作得到简化.

SysTick的配置.
SysTick的配置函数位于Core_CM4.h中, 只有一个简单的配置函数:


uint32_t SysTick_config(uint32_t ticks);

它属于CMSIS的一部分, 参数ticks为两次中断之间的时钟脉冲数, 即每经过ticks个脉冲, 中断就会发生一次.
当SysTick被成功配置时, 函数返回0, 出错时返回1.

SysTick初始化函数:

void SysTick_Init(void)

{

    if (SysTick_Config(SystmeCoreClock / 1000))

    {

        while (1);

    }

 

    SysTick->CTRL &= ~SysTick_CTRL_ENABLE_Msk;

 

    return;

}

 


以上初始化函数调用SysTick_config()将SysTick定时器初始化为每1ms中断一次.

SystemCoreClock是定义在system_stm32f4xx.c中的一全局变量, 它的值为当前系统时钟频率. 需要说明的是它的默认值为芯片所支持的最大频率, 在使用它之前要调用函数SystemCoreClockUpdate()更新它的值为正确的系统频率, 要不会出现不正确的结果.


关于参数的计算可以这样想, 当参数为SystemCoreClock的时候, 定时是间间隔正好为1秒, 如果我们需要1ms的定时时间,  那么SystemCoreClock / 1000就是了. 因为SysTick计数寄存器为24位, 所以参数值不能大于2的24次方减一, 即16777215, 否则的话初始化失败, 进入死循环.


当SysTick_Config()配置SysTick成功后会立刻启动定时器, 但在这里我希望在用到它的时候启动, 所以在配置完成后使用SysTick->CTRL &= ~SysTick_CTRL_ENABLE_Msk这一句清掉它的使能位, 暂停定时器.


上面说过SysTick时钟有AHB时钟和AHB时钟的8分频两种时钟源可选, 默认为AHB时钟.如果想要使用AHB时钟的8分频可以直接修改SysTick_Config()或者调用函数SysTick_CLKSourceConfig()(位于MISC.h中)进行配置.

在SysTick_Config()中对SysTick的中断优先级也做了修改, 这个暂不深究, 等研究NVIC的时候再说.


中断服务函数:


void SysTick_Handler(void)

{

    if (Delay_Time != 0)

    {

        Delay_Time--;

    }

 

    return;

}

不同于51, MSP430等单片机中断函数的写法, STM32的中断函数并不需要使用特殊关键字来声明, 但是函数名是已经被定义好了的. 打开启动文件(这里是startup_stm32f429_439xx.s)就可以看到各中断服务函数的名称, 所以只要按正常函数的写法完成它就可以了.


官方库中有提供两个中断函数模板stm32f4xx_it.h和stm32f4xx_it.c, 将它加入到工程, 然后在对应的地方写中断函数的实现就可以了. 不过由于STM32的中断函数实际上可以写在任何地方, 所以这里我偷了一下懒, 直接将它定义在了main()函数中.


Delay_Time是一个全局变量, SysTick每产生一次中断, 就对它进行一次减一操作.


延时函数:


void Delay_ms(uint16_t ms)

{

    Delay_Time = ms;

 

    // 使能SysTick

    SysTick->CTRL |= SysTick_CTRL_ENABLE_Msk;

 

    while (Delay_Time != 0);

 

    return;

}

延时函数对Delay_Time赋初值后阻塞CPU, 直到Delay_Time减到0, 完成延时操作.


主函数:


int main(void)

{

    RCC_Config();

    LED_GPIO_Config();

    SysTick_Init();

    GPIO_SetBits(GPIOG, GPIO_Pin_13 | GPIO_Pin_14);

 

    while(1)

    {

        GPIO_ResetBits(GPIOG, GPIO_Pin_13);

        GPIO_SetBits(GPIOG, GPIO_Pin_14);

        Delay_ms(500);

        GPIO_ResetBits(GPIOG, GPIO_Pin_14);

        GPIO_SetBits(GPIOG, GPIO_Pin_13);  

        Delay_ms(500);

    }

 

}

编译下载程序, 板子上红色和绿色的LED就会交替闪烁.


关键字:LCD闪烁  STM32F4  SysTick 引用地址:让LCD闪烁起来:STM32F4SysTick的设置与使用

上一篇:STM32F4 USART配置
下一篇:STM32F4时钟系统初探(二)

推荐阅读最新更新时间:2024-03-16 15:32

stm32f407之窗口看门狗使用流程
1.初始化 1.声明中断变量 NVIC_InitTypeDef NVIC_InitStructure; 2.打开WWDG时钟 RCC_APB1PeriphClockCmd(RCC_APB1Periph_WWDG, ENABLE); 3.设置预分频器分频 WWDG_SetPrescaler(fprer); 4.设置窗口值 WWDG_SetWindowValue(wr); 5.喂狗 WWDG_SetCounter(WWDG_CNT); 6.中断配置 NVIC_InitStructure.NVIC_IRQChannel = WWDG_IRQn; NVIC_InitStructure.NVIC_
[单片机]
<font color='red'>stm32f4</font>07之窗口看门狗使用流程
【STM32】HAL库-系统滴答定时器SysTick
SysTick定时器被捆绑在NVIC中,是一个简单的定时器,对于CM3、CM4内核芯片,都有Systick定时器。Systick定时器常用来做延时,或者实时系统的心跳时钟。这样可以节省MCU资源,不用浪费一个定时器。 Systick定时器就是系统滴答定时器,一个24 位的倒计数定时器,计到0 时,将从RELOAD 寄存器中自动重装载定时初值。 系统滴答定时器有4个寄存器 时钟源 该定时器的时钟源可以是 内部时钟(FCLK,CM3上的自由运行时钟) 外部时钟( CM3处理器上的STCLK信号) 通过SysTick控制及状态寄存器的第2位来确定 STM32的时钟树 RCC通过AHB时钟(HCLK)8分频或者不分
[单片机]
【STM32】HAL库-系统滴答定时器<font color='red'>SysTick</font>
STM32之SysTick时钟
今天学完STM32的SysTick时钟,(24位递减计数器)现在总结如下: 首先SysTick时钟包含一下四个寄存器 (1),STK_CSR 地址为0xE000E010 ----控制寄存器 STK_CSR中有以下四位具有意义,使用的时候需要配置 (1),第0位:SysTick使能位(0-关闭功能,1-开启功能) (2),第1位:SysTick中断使能位(0-关闭中断,1-开启中断) (3),第2位:SysTick时钟源选择(0-使用HCLK/8作为时钟(8分频),1-使用HCLK作为时钟) (4),第16位:SysTick技术比较标志(如果计数到达0,则该位为1,否则为零)
[单片机]
STM32F4系列HAL库配置定时器实验——输入捕获
输入捕获简单讲解 输入捕获模式可以用来测量脉冲宽度或者测量频率。我们以测量周期和频率为例,用一个简图来说明输入捕获的原理 假定定时器工作在向上计数模式, 图中 t1~t2 时间,就是我们需要测量的高电平时间。测量方法如下:首先设置定时器通道 x 为上升沿捕获,这样,t1 时刻,就会捕获到当前的 CNT 值,然后立即清零 CNT,并设置通道 x为下降沿捕获,这样到 t2 时刻,又会发生捕获事件,得到此时的 CNT 值,记为 CCRx2。这样,根据定时器的计数频率,我们就可以算出 t1~t2 的时间,从而得到高电平脉宽。 在 t1~t2 之间,可能产生 N 次定时器溢出,这就要求我们对定时器溢出,做处理,防止高电平太长,导致数
[单片机]
<font color='red'>STM32F4</font>系列HAL库配置定时器实验——输入捕获
STM32F407-获取GPIO电平状态
判断STM32 GPIO输入口的输入状态(高电平或低电平) 以PE2和PE4为例: ① 判断单个端口是否为高电平: if(GPIOE- IDR& GPIO_IDR_IDR2) { 函数体; } 当PE2端口为高电平时,if条件为真;当PE2口为低电平时,if条件为假; ② 判断单个端口是否为低电平: if((~GPIOE- IDR)& GPIO_IDR_IDR2) { 函数体; } 分析:首先通过 &GPIO_IDR_IDR屏蔽掉PE2之外的其他PE口。当PE2为高电平时,GPIO-〉IDR的bit2为‘1’,取反后为‘0’,因此条件为假;当PE2为低电平时,GPIO-〉IDR的
[单片机]
STM32F407的RTC时间
RTC_InitTypeDef RTC_InitStructure; RTC_TimeTypeDef RTC_TimeStructure; RTC_DateTypeDef RTC_DataStructure; /**************************************************************************************** *函 数 名:bsp_InitRtc *函数功能:初始化rtc *形 参:无 *返 回 值:无 **************************************************************************
[单片机]
<font color='red'>STM32F4</font>07的RTC时间
STM32F429 Discovery FMC驱动原子4.3寸LCD
上一篇写了GPIO简单的流水灯测试,看着有点单调,习惯了串口调试,板子上没有串口 那就另想办法吧,看着LCD突然有了个想法,为什么不把调试信息输出到LCD上,以前在做2416 WINCE开发的时候就经常这样干非常直观,那说干就干。 STM32F429I-DISO SDK里已经把开发包做好,那就直接拿过来用吧。 #define MESSAGE1 STM32F429I-Discoverry //提示信息 #define MESSAGE1_1 GPIO TEST #define MESSAGE2 LED3 LED4 #define MESSAGE2_1 ^-^ #define
[单片机]
STM32F407 ADC时钟设置及采样频率设置
/************************************************* 在system_stm32f4xx.c中有如下定义: /* PLL_VCO = (HSE_VALUE or HSI_VALUE / PLL_M) * PLL_N / / / #define PLL_M 8 #define PLL_N 336 /* SYSCLK = PLL_VCO / PLL_P // #define PLL_P 2 /* USB OTG FS, SDIO and RNG Clock = PLL_VCO / PLLQ /// #define PLL_Q
[单片机]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved