我板子上焊接的是 8M 的晶体,如果小伙伴们的板子上不是 8M,根据自己的晶振频率配置即可,左侧圈 1 中,可以根据自己的晶体频率,输入相应的频率,经过分频、倍频后,系统时钟频率设置为最大,168MHZ,APB1 的时钟频率为 84MHZ,也是后面用到的 TIM2 挂载的时钟源的频率。
时钟及定时器的配置就完成了,下面是 cubemx 生成工程时的几项设置,建议大家勾选。首先是 HAL 库是否需要包含所有的文件,我们选择只需要用到的文件,这样可以缩短工程编译时间,只编译我们用到的库文件,接着是勾选为每个外设生成单独的.c .h 文件,这个建议一定要勾选,会使代码结构非常清晰,第三点就非常的重要了,用过 cubemx 的小伙伴是否遇到过每次重新生成工程后,之前添加的文件都不见了,这一项勾选之后,会保留用户文件。
然后是编译器选择,可以根据自己喜欢的 IDE 选择,我选择的是 KEIL5。
至此,配置工作就完成了,生成工程就可以了。
/*
普通定时器实现us延时
*/
void user_delaynus_tim(uint32_t nus)
{
uint16_t differ = 0xffff-nus-5;
//设置定时器2的技术初始值
__HAL_TIM_SetCounter(&htim2,differ);
//开启定时器
HAL_TIM_Base_Start(&htim2);
while( differ<0xffff-5)
{
differ = __HAL_TIM_GetCounter(&htim2);
};
//关闭定时器
HAL_TIM_Base_Stop(&htim2);
}
/*
普通定时器实现ms延时,可直接使用HAL库函数HAL_delay()
*/
void delay_ms_tim(uint16_t nms)
{
uint32_t i;
for(i=0;i<nms;i++) user_delaynus_tim(1000);
}
相应代码在core_cm4.h中
/**
\brief Structure type to access the System Timer (SysTick).
*/
typedef struct
{
__IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */
__IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */
__IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */
__IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */
} SysTick_Type;
/*
Systick功能实现us延时,参数SYSCLK为系统时钟
*/
uint32_t fac_us;
void HAL_Delay_us_init(uint8_t SYSCLK)
{
fac_us=SYSCLK;
}
void HAL_Delay_us(uint32_t nus)
{
uint32_t ticks;
uint32_t told,tnow,tcnt=0;
uint32_t reload=SysTick->LOAD;
ticks=nus*fac_us;
told=SysTick->VAL;
while(1)
{
tnow=SysTick->VAL;
if(tnow!=told)
{
if(tnow<told)tcnt+=told-tnow;
else tcnt+=reload-tnow+told;
told=tnow;
if(tcnt>=ticks)break;
}
};
}
通过延时翻转IO,逻辑分析仪测试延时时间,测试了延时 20us,下面是测量图:
/*
for循环实现延时us
*/
void for_delay_us(uint32_t nus)
{
uint32_t Delay = nus * 168/4;
do
{
__NOP();
}
while (Delay --);
}
猜你喜欢:
2020年精选原创笔记汇总
STM32延时函数的四种方法
1024G 嵌入式资源大放送!包括但不限于C/C++、单片机、Linux等。在公众号聊天界面回复1024,即可免费获取!