完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
扫一扫,分享给好友
|
本帖最后由 江南无故事 于 2016-6-22 02:21 编辑
#define MSDELAY(msec) (asm_delay(msec * cpu_clk_mhz * 1000)); asm_delay(u32 inst) { int temp = (inst) / 10; /* 10 = 2 + 8 , 8 is cortex-A9's branch penalty */ __asm__ __volatile__ ( "1: subs %0, %0, #1 n" "bhi 1b" : : "r" (tmp) : "memory" ); } /*****************************************************************************/ 实际的cpu_clk_mhz = 24 , CPU频率是24MHZ 调用MSDELAY时,MSDELAY(10000),为了延时10s,实际测得的数值为8s。 请教一下,/* 10 = 2 + 8 , 8 is cortex-A9's branch penalty */该如何理解,为什么使用这种方式来实现延时,依据再哪里,望指教。 备注:cortex-A9 is 8-stage pipeline. |
|
相关推荐
1个回答
|
|
|
IC设计中,使用Diagnostic验证IP,发现delay函数与实际不符,不太理解该函数的原理。
|
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
762 浏览 0 评论
739 浏览 0 评论
飞凌嵌入式ElfBoard-文件I/O的了解探究之复制文件描述符
668 浏览 0 评论
飞凌嵌入式ElfBoard-文件I/O的了解探究之返回错误处理与相关函数
1448 浏览 0 评论
飞凌嵌入式ElfBoard-文件I/O的了解探究之文件描述符和FILE指针转换
1058 浏览 0 评论
/9
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-12-1 23:58 , Processed in 0.503823 second(s), Total 70, Slave 53 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191

淘帖
2769