stm32基于库3.5的Systick问题
时间:10-02
整理:3721RD
点击:
网上找了资料得知:
在标准外设库3.5中移除了SysTick的驱动,因此用户必须调用CMSIS定义的函数。
CMSIS只提供了一个SysTick设置的函数(SysTick_Config(uint32_t ticks)),替代了STM32原有SysTick驱动的全部函数。
这样我们就不能自动重载入计数器(LOAD)的值,这样不就不方便了吗,为什么越升级越死板?
还有一个问题就是,新配置的函数
void Init_SysTick(void)
{
if(SysTick_Config(SystemCoreClock / 1000))
while(1);
}为什么要加一个while(1),这样我放在main里不就会在停在Init_SysTick(),不会运行下面的程序吗,但是我实验的时候还是成功的延时了。这我很不能理解,求大神解释解释。下面的是我的main。程序不应该停在Init_SysTick();,while(1)里面的应该都不会执行啊~~
int main(void)
{
u8 time=0;
RCC_Configuration();
GPIO_Configuration();
USART_Configuration();
Init_SysTick();
while(1)
{
printf("\n\t %d",time);
delay_ms(1000);
time++;
}
}
在标准外设库3.5中移除了SysTick的驱动,因此用户必须调用CMSIS定义的函数。
CMSIS只提供了一个SysTick设置的函数(SysTick_Config(uint32_t ticks)),替代了STM32原有SysTick驱动的全部函数。
这样我们就不能自动重载入计数器(LOAD)的值,这样不就不方便了吗,为什么越升级越死板?
还有一个问题就是,新配置的函数
void Init_SysTick(void)
{
if(SysTick_Config(SystemCoreClock / 1000))
while(1);
}为什么要加一个while(1),这样我放在main里不就会在停在Init_SysTick(),不会运行下面的程序吗,但是我实验的时候还是成功的延时了。这我很不能理解,求大神解释解释。下面的是我的main。程序不应该停在Init_SysTick();,while(1)里面的应该都不会执行啊~~
int main(void)
{
u8 time=0;
RCC_Configuration();
GPIO_Configuration();
USART_Configuration();
Init_SysTick();
while(1)
{
printf("\n\t %d",time);
delay_ms(1000);
time++;
}
}
这个要看if条件中执行的函数的返回值是什么,如果为假的话,(设置成功)跳过while。 如果为为真的话,(设置失败)一直进入死循环
这个要看if条件中执行的函数的返回值是什么,如果为假的话,(设置成功)跳过while。 如果为为真的话,(设置失败)一直进入死循环
以前的Systick好理解多了,这个不太好理解了0.0
跟着小编学习一下经验