全球最实用的IT互联网信息网站!

AI人工智能P2P分享&下载搜索网页发布信息网站地图

当前位置:诺佳网 > 电子/半导体 > 处理器/DSP >

CW32L083实现SysTick精准微秒延时驱动

时间:2023-06-11 14:44

人气:

作者:admin

标签: 定时器  CW32L083  RCC  Systick 

导读:在做18B20时需要用到精准的微秒定时器。...

在做18B20时需要用到精准的微秒定时器

  1. 时钟初始化,这里采用CW的例程,驱动HSI主频为64M
void RCC_Configuration(void)
{
    /* 0. HSI使能并校准 */
    RCC_HSI_Enable(RCC_HSIOSC_DIV6);

    /* 1. 设置HCLK和PCLK的分频系数*/
    RCC_HCLKPRS_Config(RCC_HCLK_DIV1);
    RCC_PCLKPRS_Config(RCC_PCLK_DIV1);

    /* 2. 使能PLL,通过HSI倍频到64MHz */
    RCC_PLL_Enable(RCC_PLLSOURCE_HSI, 8000000, RCC_PLL_MUL_8); // HSI 默认输出频率8MHz

    ///< 当使用的时钟源HCLK大于24M,小于等于48MHz:设置FLASH 读等待周期为2 cycle
    ///< 当使用的时钟源HCLK大于48M,小于等于72MHz:设置FLASH 读等待周期为3 cycle
    __RCC_FLASH_CLK_ENABLE();
    FLASH_SetLatency(FLASH_Latency_3);

    /* 3. 时钟切换到PLL */
    RCC_SysClk_Switch(RCC_SYSCLKSRC_PLL);
    RCC_SystemCoreClockUpdate(64000000);

}
  1. 在cw32l083_systick.c中增加三个函数:
    初始化ms、us的装载初值,以实现毫秒、微秒的装装:
static uint32_t fac_ms ;
static uint32_t fac_us;
#define HclkFreq 64000000
void init_SysTick(void)
{
fac_ms = HclkFreq/1000U;
fac_us = fac_ms/1000U;
}

3、微秒延时函数,实现的思路是用微少的时装载初值*延时需要的时间,加载到计数器中(SysTick->Load),然后开始计时,查询到计数器已经在计时,且溢出标志位为1时中止计时,以实现微秒延时,代码如下:

void delayTick_us(uint32_t nus)
{
		uint32_t temp;
	  SysTick- >CTRL=0;
		SysTick- >LOAD = fac_us*nus - 1;
	  SysTick- >CTRL  = SysTick_CTRL_CLKSOURCE_Msk |SysTick_CTRL_ENABLE_Msk;    //使能时钟、开始计时
		do {
		temp = SysTick- >CTRL; //读寄存器,判断是否溢出位
		}while(!(temp&(SysTick_CTRL_COUNTFLAG_Msk)) && (temp & 0x01));
		SysTick- >CTRL=0; 	//停止计时
	
}

4、毫秒延时函数的实现,由于毫秒的计数初值比较大,所以不能象微秒一样直接把相乘的计数值装载进LOAD寄存器中,需要以1毫秒为单位,在中断中每一毫秒相加进行计数,当计数值达到所需要的计数的值时,中止计时,来实现精准的延时。

代码如下:

void delayTick_ms(uint32_t nms)
{
	  SysTick- >CTRL=0;
	  uwTick = 0;
    SysTick_Config(fac_ms);
		while(uwTick< nms);
		SysTick- >CTRL=0;
		uwTick = 0;
		
}

毫秒延时.png微秒延时.png

微秒延时2.png

温馨提示:以上内容整理于网络,仅供参考,如果对您有帮助,留下您的阅读感言吧!
相关阅读
本类排行
相关标签
本类推荐

CPU | 内存 | 硬盘 | 显卡 | 显示器 | 主板 | 电源 | 键鼠 | 网站地图

Copyright © 2025-2035 诺佳网 版权所有 备案号:赣ICP备2025066733号
本站资料均来源互联网收集整理,作品版权归作者所有,如果侵犯了您的版权,请跟我们联系。

关注微信