static __IO uint32_t delay_ms_ticks; void delay_init(void) { SysTick_Config(SystemCoreClock/1000); } void delay_ms(uint16_t ms) { delay_ms_ticks = ms; while(delay_ms_ticks); } void SysTick_Handler() { if (delay_ms_ticks > 0) { delay_ms_ticks--; } }
时间: 2023-12-06 09:40:02 浏览: 81
这是一段用于 STM32 MCU 的延时函数代码。其原理是使用 SysTick 定时器来计时,每当 SysTick 定时器中断时,就将延时计数器减一,当计数器为零时,延时结束。其中,delay_init 函数用于初始化 SysTick 定时器,设置为每毫秒中断一次;delay_ms 函数用于启动一次指定的毫秒级延时;SysTick_Handler 函数则是 SysTick 定时器中断服务函数,每次中断时将计数器减一。需要注意的是,这段代码中的 delay_ms_ticks 变量必须声明为 volatile,以避免编译器优化造成的问题。
相关问题
static __IO uint32_t delay_ms_ticks; static inline void delay_init(void) { SysTick_Config(SystemCoreClock/1000); } static inline void delay_ms(uint16_t ms) { delay_ms_ticks = ms; while(delay_ms_ticks); } __weak void SysTick_Handler() { if (delay_ms_ticks > 0) { delay_ms_ticks--; } }改为使用外部32.768KHz晶振的延时函数
首先,需要明确的是使用外部32.768KHz晶振的延时函数需要使用RTC定时器,因为RTC定时器使用的是低速外部晶振。以下是修改后的代码:
```c
static __IO uint32_t delay_ms_ticks;
static inline void delay_init(void) {
RCC->APB1ENR1 |= RCC_APB1ENR1_PWREN; // Enable power interface clock
PWR->CR1 |= PWR_CR1_DBP; // Enable access to RTC, backup and power registers
RCC->BDCR |= RCC_BDCR_RTCEN; // Enable RTC clock
RCC->BDCR |= RCC_BDCR_RTCSEL_LSE; // Select low speed external oscillator as RTC clock
RTC->WPR = 0xCA; // Unlock write protection
RTC->WPR = 0x53;
RTC->ISR |= RTC_ISR_INIT; // Enter initialization mode
while (!(RTC->ISR & RTC_ISR_INITF)); // Wait for initialization flag to be set
RTC->PRER = (127 << 16) | (255); // Set prescaler values for 32.768KHz oscillator
RTC->ISR &= ~RTC_ISR_INIT; // Exit initialization mode
RTC->WPR = 0xFF; // Lock write protection
}
static inline void delay_ms(uint16_t ms) {
delay_ms_ticks = ms;
while (delay_ms_ticks);
}
__weak void RTC_WKUP_IRQHandler() {
if (delay_ms_ticks > 0) {
delay_ms_ticks--;
}
}
```
在上述代码中,我们首先使能了PWR、RTC和BKP的时钟,并且解锁了RTC写保护。然后选择了低速外部晶振作为RTC时钟源,并且设置了对应的预分频器值。最后,我们将写保护锁定,并在RTC的WKUP中断句柄中进行延时操作。需要注意的是,在这里我们使用了RTC的WKUP中断而不是SysTick中断来进行延时,因为我们现在使用的是RTC定时器。
static __IO uint32_t delay_ms_ticks; //定义一个静态变量delay_ms_ticks,用于计数,表示还需要延时多少毫秒 void delay_init(void)//初始化SysTick,使SysTick中断发生频率为1kHz { SysTick_Config(SystemCoreClock/1000); } void delay_ms(uint16_t ms) { delay_ms_ticks = ms; while(delay_ms_ticks); } void SysTick_Handler() { if (delay_ms_ticks > 0) { delay_ms_ticks--; } }补齐它应该有的前提条件,分为c文件和h文件
假设这段代码是在一个名为delay.c的文件中实现的,那么它应该引用一个名为delay.h的头文件,其中应该包含以下内容:
在delay.h文件中:
```
#ifndef __DELAY_H
#define __DELAY_H
#include "stm32f4xx.h"
void delay_init(void);
void delay_ms(uint16_t ms);
#endif
```
在delay.c文件中:
```
#include "delay.h"
static __IO uint32_t delay_ms_ticks;
void delay_init(void)
{
SysTick_Config(SystemCoreClock/1000);
}
void delay_ms(uint16_t ms)
{
delay_ms_ticks = ms;
while(delay_ms_ticks);
}
void SysTick_Handler()
{
if (delay_ms_ticks > 0)
{
delay_ms_ticks--;
}
}
```
需要注意的是,这个代码使用了STM32F4xx的库函数,因此需要在代码中包含相应的头文件,如`stm32f4xx.h`。同时,这个代码的延时函数是基于SysTick中断实现的,因此需要先调用`delay_init()`函数初始化SysTick。
阅读全文