运用9b96芯片,免不了用到推迟,例如:让LED闪耀。所以,呈现延时时刻的问题。
函数原型:
void SysCtlDelay (unsigned long ulCount)
参数:
ulCount 是要履行的延时循环反复的次数。
描绘:
该函数供给了一个发生稳定长度延时的办法。它是用用汇编写的,以坚持跨过东西链的
延时共同,然后避免了在应用上根据东西链来调理延时的要求。
循环占用3个周期/循环。
回来:
无。
2. 计数延时:大略延时办法。
void Delay(unsigned long nCount)
{
for(; nCount != 0; nCount–);
}
下面是一个LED闪耀的比如:
#include “inc/hw_memmap.h”
#include “inc/hw_types.h”
#include “driverlib/gpio.h”
#include “driverlib/sysctl.h”
/* 用于调试 PF1 <-> LED —————————————————–*/
#define LED_PERIPH SYSCTL_PERIPH_GPIOF
#define LED_PORT GPIO_PORTF_BASE
#define LED_PIN GPIO_PIN_1
#define LED_OFF 1 << 1
#define LED_ON ~(1 << 1) // 低电平点亮LED
void Delay(unsigned long nCount)
{
for(; nCount != 0; nCount–);
}
int main(void)
{
// Set the clocking to run directly from the crystal.
SysCtlClockSet(SYSCTL_SYSDIV_1 | SYSCTL_USE_OSC | SYSCTL_OSC_MAIN | SYSCTL_XTAL_16MHZ);
SysCtlPeripheralEnable(LED_PERIPH); // 使能LED地点的GPIO端口
GPIOPinTypeGPIOOutput(LED_PORT, LED_PIN); // 设置LED地点管脚为输出
while (1)
{
GPIOPinWrite(LED_PORT, LED_PIN, LED_ON); // 点亮LED
Delay(0xfff); // 试验测得延时2.5ms
GPIOPinWrite(LED_PORT, LED_PIN, LED_OFF); // 平息LED
Delay(0xfff); // 试验测得延时2.5ms
/*
GPIOPinWrite(LED_PORT, LED_PIN, LED_ON); // 点亮LED
SysCtlDelay(SysCtlClockGet() / 3000); // 准确延时1ms
GPIOPinWrite(LED_PORT, LED_PIN, LED_OFF); // 平息LED
SysCtlDelay(SysCtlClockGet() / 3000); // 准确延时1ms
*/
}
}
要点:1) 计数延时时刻与体系时钟频率有关,假如用PLL将体系时钟设置成50M,其延时时刻变短。
体系时钟 | 16M | 50M |
计数延时:Delay(0xfff); | 2.5ms | 819us |
体系延时:SysCtlDelay(SysCtlClockGet() / 3000); | 1ms | 1ms |
//*****************************************************************************
//
// 准确延时nms
//
//*****************************************************************************
void Delay(DWORD nms)
{
SysCtlDelay((SysCtlClockGet() / 3000) * nms);
}