STM32 在RVMDK下简单延时计算

本文详细介绍了如何使用STM32主控板移植ARF2496K无线2.4G驱动,通过对比while和for循环在MDK模拟器中的效率,探讨了STM32系列ARM芯片在实际应用中的延时处理方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

为了改写ARF2496K无线2.4G驱动,需要移植到STM32主控上来,所以就想先简单的控制 I/O 时序,去完成这个实验。

第一步先完成寄存器的读写,第二步便完成正常收发,而且暂时不用考虑移植到UCOSII。

查看了ARF2496K datasheet后发现需要进行延时25us  125ms,之前的配套驱动是使用STM8为主控的,16M晶振。 我自己的开发板是神舟IV,高速外部晶振为25MHz,想着简单解决的办事原则,没有采用STM32的库进行编程,而且计时也使用的最简单的51方式,使用循环。 调试时发现了一个问题,while和for 循环的效率差别很大。便记录下来供以后参考。


RVMDK版本为 RVMDK 4.12

芯片采用STMF103VB  (暂时不知什么原因,STMF107VCT6无法进行纯软件仿真 simulator,提示 load ...axf access violation 0x0000000C,no 'read' permission,据说是不支持),反正不影响延时代码的效果,所以也就无所谓了。

晶振使用 25MHz(默认是8MHz)     如下图:




以下代码纯为测试使用:

void delay(__IO uint32_t n)
{
	while(n--);
}

void delay_u()
{
	__IO u8 n = 25;
	for (;n > 0;n--)
		;
}

void delay_20us()
{
	__IO u8 n = 25; //n = 25时,定时为20.125us; n = 26时,定时为20.625us
	while(n--);
}


初始执行到main主函数,耗费的时间为74.62500us,也就是执行STM32F10X.s中的代码时间。为了区别while和for的效率,分别使用两个不同的函数进行封装。


一、调用delay_20us()函数,内部是使用while循环,经过调试发现在n = 25时,比较接近20us。

执行前如下图:

 

执行后: 时间值为94.75000us ,总共耗费时间为94.75000 - 74.62500 = 20.125 (us)。


二、 对于delay_u()函数,内部是使用for循环。

执行前 如下图:


执行完成后,时间为90.87500 us,中间共耗时16.25us,平均执行时间为: 0.8125us (812.5ns)


为了查看区别,看了看MDK相应的汇编代码,如下:

for 语句代码为10个字节,而while生成的代码将近14个字节,由此可见在MDK中, while 效率明显低于 for语句。至于优化后的效果暂时没有测试。


总结:

STM32系列的ARM芯片,可能真正应用上的时候,因为其芯片的速度很快,而且频率可调,像C51之类的简单延时方法将不再好用,取而代之的是使用SysTick,可以从STM32库中找到对应的封装函数。

MDK 的simulator功能非常强大,能够模拟很多中外设,如GPIO、串口等,具体支持的类型因主控而定。 这里对于时间值的测量是最简单的。

MDK 中的不同循环方式对代码效率会产生比较大的影响。

因MDK的BUG问题,可以使用变通的方式搞定,就像STM32F107VC不同simulator一样,如果只是调试简单的I/O口,延时之类的可以使用其他型号的ARM主控芯片(内核必须一致)。

另外MDK 4.22a 使用旧版的注册机仍然能够破解,已经使用上了,感觉很HIGH!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值