完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
HAL库和LL库都没有自带的微秒级延时,但是修改SysTick的配置会影响其他部分。经过几天的实验,浏览了不少资料,分享以下三种延时方法。
一、利用定时器实现微秒延时 1. MX配置 2. /* USER CODE BEGIN 1 */ void delayXus(uint32_t us) { (&htim3)->Instance->CNT = (0x0000efff -us*8);// __HAL_TIM_SET_COUNTER(&htim3,differ); // HAL_TIM_Base_Start(&htim3); SET_BIT(TIM3->CR1, TIM_CR1_CEN); //__HAL_TIM_GET_COUNTER(&htim3); while(((&htim3)->Instance->CNT) < 0x0000effe) // READ_REG(TIM3->CNT) { } // HAL_TIM_Base_Stop(&htim3); CLEAR_BIT(TIM3->CR1, TIM_CR1_CEN); } /* USER CODE END 1 */ 二、利用已有的SysTick配置,读取计数判断延迟,精确且不浪费资源 void delay_us(uint32_t udelay) { uint32_t startval,tickn,delays,wait; startval = SysTick->VAL; tickn = HAL_GetTick(); //sysc = 72000; //SystemCoreClock / (1000U / uwTickFreq); delays =udelay * 72; //sysc / 1000 * udelay; if(delays > startval) { while(HAL_GetTick() == tickn) { } wait = 72000 + startval - delays; while(wait < SysTick->VAL) { } } else { wait = startval - delays; while(wait < SysTick->VAL && HAL_GetTick() == tickn) { } } } 三、利用指令耗时计算延迟 void RCCdelay_us(uint32_t udelay) { __IO uint32_t Delay = udelay * 72 / 8;//(SystemCoreClock / 8U / 1000000U) //见stm32f1xx_hal_rcc.c -- static void RCC_Delay(uint32_t mdelay) do { __NOP(); } while (Delay --); } |
|
|
|
只有小组成员才能发言,加入小组>>
调试STM32H750的FMC总线读写PSRAM遇到的问题求解?
1760 浏览 1 评论
X-NUCLEO-IHM08M1板文档中输出电流为15Arms,15Arms是怎么得出来的呢?
1613 浏览 1 评论
1058 浏览 2 评论
STM32F030F4 HSI时钟温度测试过不去是怎么回事?
721 浏览 2 评论
ST25R3916能否对ISO15693的标签芯片进行分区域写密码?
1670 浏览 2 评论
1932浏览 9评论
STM32仿真器是选择ST-LINK还是选择J-LINK?各有什么优势啊?
724浏览 4评论
STM32F0_TIM2输出pwm2后OLED变暗或者系统重启是怎么回事?
564浏览 3评论
590浏览 3评论
stm32cubemx生成mdk-arm v4项目文件无法打开是什么原因导致的?
548浏览 3评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-20 13:41 , Processed in 0.749489 second(s), Total 79, Slave 62 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号