SysTick守时器被捆绑在NVIC中,用于发生SysTick反常(反常号:15)。在曾经,操作体系还有一切运用了时基的体系,都必须一个硬件守时器来发生需求的“滴答”中止,作为整个体系的时基。滴答中止对操作体系特别重要。例如,操作体系可认为多个使命许以不同数意图时刻片,保证没有一个使命能强占体系;或许把每个守时器周期的某个时刻规模赐予特定的使命等,还有操作体系供给的各种守时功用,都与这个滴答守时器有关。因而,需求一个守时器来发生周期性的中止,并且最好还让用户程序不能随意拜访它的寄存器,以保持操作体系“心跳”的节律。
有4个寄存器操控SysTick守时器,如表8.9至表8.12所示。


static __INLINE uint32_t SysTick_Config(uint32_t ticks)
{
if (ticks > SysTick_LOAD_RELOAD_Msk) return (1);
SysTick->LOAD = (ticks & SysTick_LOAD_RELOAD_Msk) – 1;
NVIC_SetPriority (SysTick_IRQn, (1<<__NVIC_PRIO_BITS) – 1);
SysTick->VAL = 0;
SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk |
SysTick_CTRL_T%&&&&&%KINT_Msk |
SysTick_CTRL_ENABLE_Msk;
return (0);
}
在3.5库中,要运用SysTick变得十分简略,只需在初始化时调用SysTick_Config()函数写入重装节拍数即可。如,设置SysTick守时器1ms发生一个中止:
{
}
SysTick_Config(72000);//1ms
在此基础上做一个Delay延时函数:
void Delay_ms(u16 time)
{
nTime = time;
while(nTime);
}
其间,nTime为全局变量,在SysTick中止服务程序里做自减操作:
void SysTick_Handler(void)
{
nTime–;
}