打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
华大HC32F460 HC32F4A0加速程序运行速度

华大单片机HC32F4xx系类(HC32F460 HC32F4A0)可以运行200Mhz,但内部Flash CPU运行频率达到33M后,就需要加入不同的等待周期。
所以实际程序在内部FLash内运行时,是跟不上CPU速度,也就不能达到高运行速度200Mhz
如下图:可以看到在200Mhz时,读Flash中的指令需要等待5CPU时钟周期,那大概200M运行时实际CPU能够跑到不到40Mhz
 


那怎么能够使程序运行的快,跑出实际CPU的频率呢?
两种方法:
1.
理所应当想到的一种方法就是把关键程序或需要运行速度的代码搬到SRAM内运行。
   
这个方法不在本贴讨论范围内,不过原理和细节都不太复杂。
   
这里提醒以下两点,具体做法也不难,不管是谁家的MCU这种SRAM内运行的方法都是一样的。
   1
)只需要注意中断向量表要重映射到SRAM中,如果想把中断搬运到SRAM中运行的话。
   2
)还有一点是,搬运到SRAM内运行的代码如果有调用Flash内代码的,也是会影响速度。需要再把调用链上所有代码一同搬运到SRAM内。

2.
就是在华大HC32Fxx系列MCU内,有一个1K大小的FLash Cache,可以使运行FLash内的代码加速,或读取Flash内数据加速。
  
使运行在Flash内的代码执行速度和CPU速度同频。当然,既然是读的cache,那么如果CPU没有命中cache中的内容,还是会从Flash中取数据和指令的。
   
所以在整个程序运行期间 cache起到了加速作用,而不能认为每个运行时段程序运行的速度都会和CPU一致。
    

如果HCLK200Mhz,那么使能cache,可以加速程序运行速度到200Mhz
千万别认为程序每时每刻都运行在200M,所以也不要用忙等待的方式做延时函数,建议使用systick做忙等待延时函数

我做了一个试验,测试一段代码运行时在不开启cache和开启cache的运行表现:

测试的这段代码:

  


运行结果:
cacheflash_run_performance_test函数使用了72802310ns10纳秒),
cacheflash_run_performance_test函数使用了25988010ns
大家可以计算出测试函数花的时间,有cache时和无cache时速度的对比,是多少倍。

总结下:就是华大HC32F4XX系列ARM cortex-M4的这颗MCU速度还是不错的。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
我的电脑好慢,怎么办?
CPU缓存的作用
为什么CPU缓存会分为L1、L2、L3?
一秒钟的时间也要全力争取(上)
分散加载原理的简单介绍
Cache是什么文件?Cache文件可以删除吗?
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服