使用SysTick的普通計數模式對延遲進行管理.
static u8 fac_us=0;//us延時倍乘數
static u16 fac_ms=0;//ms延時倍乘數
//初始化延遲函數
void delay_init(u8 SYSCLK)
{
SysTick->CTRL&=0xfffffffb; //bit2清空,選擇外部時鐘*/
fac_us = SYSCLK/8;
fac_ms = (u16)fac_us*1000;
}
//延時nms
//SysTick->LOAD為24位寄存器,所以,最大延時為:
//nms<=0xffffff*8*1000/SYSCLK
//對72M條件下,nms<=1864
void delay_ms(u16 nms)
{
u32 temp;
SysTick->LOAD=(u32)nms*fac_ms; // 當倒數至零時,將被重裝載的值 */
SysTick->VAL =0x00; // VAL寄存器中存放著當前倒計數的值 */
SysTick->CTRL=0x01 ; // Systick定時器的使能位 開始計時 */
do
{
temp=SysTick->CTRL;
}
while(temp&0x01&&!(temp&(1<<16))); //首先檢查定時器使能位是否為1
//Systick定時器倒數至零後 位16被置1 被讀取後該位置0
// 等待時間到達或定時器關閉 */
SysTick->CTRL=0x00; //關閉計數器
SysTick->VAL =0X00; //清空計數器
}
//延時nus
//nus為要延時的us數.
void delay_us(u32 nus)
{
u32 temp;
SysTick->LOAD=nus*fac_us; //時間加載
SysTick->VAL=0x00; //清空計數器
SysTick->CTRL=0x01 ; //開始倒數
do
{
temp=SysTick->CTRL;
}
while(temp&0x01&&!(temp&(1<<16)));//等待時間到達
SysTick->CTRL=0x00; //關閉計數器
SysTick->VAL =0X00; //清空計數器
}