stm32快速学习6——SysTick 定时1s控制LED
设置引脚功能
本文引用地址:https://www.eepw.com.cn/article/201611/315447.htm设置systick为1s中断
利用systick中断就可以得到1s时间
//////////////////////////////////////////////////////////////////////////前言/////////////////////////////////////////////////////////////////////////////////////////
stm32的systick通过少数的程序设置,当使用systick_config()函数之后,其载入值就是你的参数,并且自动打开中断,并将中断设为最低的优先级,将其时钟设为HCLK即系统时钟72mhz,并重置计数寄存器开始计数。也可以将时钟设置为HCKL的八分频,通过使用SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK_Div8) 紧跟在systick_config()之后,而改变优先级则使用NVIC_SetPriority(SysTick_IRQn,...) 函数,而时基单元的设置使用如下公式,Reload Value = SysTick Counter Clock (Hz) x Desired Time base (s) Reload Value 就是传递进去的参数。但参数不能超过0xFFFFFF。
使用systick延时的时候也可以不开启中断,而直接对其寄存器进行读写
SysTick_Config(uint32_t
(SysTick_CTRL_CLKSOURCE_Msk),所以定时时间=ticks
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
这里使用3.4的库,注意是SystemCoreClock,3.0那些版本是用SystemFrequency这个单词,其他2.x版本的方法是不同的。

注: 全局变量 TimingDelay , 必须定义为 volatile 类型 , 延迟时间将不随系统时钟频率改变。

Main文件
#include"stm32f10x.h"
voidRCC_Configuration(void);
voidGPIO_Configuration(void);
voidSysTick_Configuration(void);
voidDelay(volatileuint32_tnTime);
staticvolatileuint32_tTimingDelay;
intmain(void)
{
RCC_Configuration();
GPIO_Configuration();
SysTick_Configuration();
while(1)
{
GPIO_SetBits(GPIOA,GPIO_Pin_0);
Delay(1000);
GPIO_SetBits(GPIOA,GPIO_Pin_1);
Delay(1000);
GPIO_ResetBits(GPIOA,GPIO_Pin_0);
Delay(1000);
GPIO_ResetBits(GPIOA,GPIO_Pin_1);
Delay(1000);
}
}
voidRCC_Configuration(void) /*使用外部8M*/
{
ErrorStatusHSEStartUpStatus;
/*RCCsystemreset(fordebugpurpose)*/
RCC_DeInit();
/*EnableHSE*/
RCC_HSEConfig(RCC_HSE_ON);
/*WaittillHSEisready*/
HSEStartUpStatus=RCC_WaitForHSEStartUp();
if(HSEStartUpStatus==SUCCESS)
{
/*EnablePrefetchBuffer预取指缓存使能*/
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);
/*Flash2waitstate,FLASH存储器延时时钟周期数*/
FLASH_SetLatency(FLASH_Latency_2);
/*HCLK=SYSCLK*/
RCC_HCLKConfig(RCC_SYSCLK_Div1);
/*PCLK2=HCLK*/
RCC_PCLK2Config(RCC_HCLK_Div1);
/*PCLK1=HCLK/2*/
RCC_PCLK1Config(RCC_HCLK_Div2);
/*PLLCLK=8MHz*9=72MHz*/
RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_9);
/*EnablePLL*/
RCC_PLLCmd(ENABLE);
/*WaittillPLLisready*/
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)==RESET)
{
}
/*SelectPLLassystemclocksource*/
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
/*WaittillPLLisusedassystemclocksource*/
while(RCC_GetSYSCLKSource()!=0x08)
{
}
}
/*EnableGPIOCclock*/
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
}
voidGPIO_Configuration(void)
{
GPIO_InitTypeDefGPIO_InitStructure;
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_0|GPIO_Pin_1;
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_Out_PP;
GPIO_Init(GPIOA,&GPIO_InitStructure);
}
voidSysTick_Configuration()
{
if(SysTick_Config(SystemCoreClock/1000))
{
/*Captureerror*/
while(1);
}
}
voidDelay(volatileuint32_tnTime)
{
TimingDelay=nTime;
while(TimingDelay!=0);
}
voidTimingDelay_Decrement(void)
{
if(TimingDelay!=0x00)
{
TimingDelay--;
}
}
Stm32f10x_it.c加入
voidTimingDelay_Decrement(void);
voidSysTick_Handler(void)
{
TimingDelay_Decrement();
}
评论