0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

你的MCU不只这么强大

5RJg_mcuworld 来源:电子发烧友网 作者:工程师谭军 2018-07-04 14:14 次阅读

当前的生活节奏越来越快,对计算处理器的要求也越来越高。即使是有摩尔定律的限制,人们仍然希望在单个芯片中塞入尽可能多的晶体管。尽管现在的MCU动不动就可以跑到几十上百兆,比如NXP高能效的LPC54100系列已破100MHz大关,通用型的LPC54600系列飚到210MHz,i.MX RT1050跨界处理器甚至飞到了怪兽级的600MHz,可是在当下应付图像处理和机器学习等计算大户时,仍然免不了出现“卡”的窘境。这个时候,如果能清楚地知道最消耗性能的具体函数,就有机会制定优化性能的策略。这也是圈子里常说的“profiling”(性能分析)。

有些价格相当昂贵的专业软硬件开发工具,都会提到它们有多么超强的profiling能力,这仿佛让人觉得profiling是有钱人才能玩得起,难道作为广大工程师我们就只能缩手缩脚吗?其实不然,在软件上想一点变通的办法,使用最便宜的仿真器,就完全可以在极小的开销下,做到好用够用的强大profiling利器,丑小鸭秒变金凤凰。

下面要介绍的方法的基本思想,就是密集地定期采集PC寄存器的值,从它的概率分布上估计最占CPU的函数。采集得越久,就越接近真实情况(大数定率)。其原理是,在Cortex-M系MCU进入中断/异常时,会自动把被打断的位置(PC)存储在堆栈中。这样我们可以用汇编写一小段入口程序,读取出入栈的PC数值,作为参数传递给处理程序的C程序主体,在主体中统计PC样本的规律。只要采集了足够久的样本,在概率论的大数定理支持下,咱们就有信心估计程序中PC最常出现的位置,也就是最占CPU时间的函数。

为了贯彻这个思想,需要准备的只有:

1.工具链产生的 .map文件。无论是KEIL, IAR, GCC,在成功构建程序后,都会产生一个map文件来记录各函数和变量的位置。从采集的PC位置,查map文件判定是什么函数。

2.系统中有一个定期产生中断的时基。常见的就是SysTick定时器的周期中断,别的timer也可以。这个中断需要优先级比较高。

3.扩写定时器中断服务程序,按照前面的思路,加入这个屌丝神器。

这样,我们就可以把占CPU最多的计算型函数请到VIP区,它们与CPU有绿色快速通道,加速它们的执行。其实这个VIP区也是分等级的,从小V到大V,特权待遇相差还是明显的,小编今后再专开一文介绍不同VIP的特权。

要想让这个思路能可靠工作,还有几个关键的小坑不要踩:

1.PC最常在的位置并非一定就是最计算密集的位置。比如,程序中经常会出现等候外设寄存器的情况,CPU几万几亿遍地查看一个外设标志。这类IO忙等的代码即使放在大V区,也无济于事。

2.定时器中断的优先级不够高。如果有高优先级的中断服务程序占用了大量CPU时间,定时器中断就没有机会采集到它们,反而是在这些中断返回时定时器中断才得到服务,结果反而冤枉了被高优先级中断给打断的位置。

3.某个函数的工作频率与相位恰好和定时器中断产生“共振”,经常有机会在进入定时器中断的前夕在这个函数中,也会误以为这个函数是最占CPU时间的。这个情况一般是罕见的。

4.CPU负载比较轻,结果大量PC都采集到idle函数中。可能有小伙伴要问了,CPU都这么咸(闲)了,还淡操什么心?这个其实要以发展的眼光来看。比如,有可能随着功能集成的增加CPU终将有不堪重负的时候,或者系统负载不均匀而表现出明显的峰谷性,又可能希望让CPU尽管做完事好进低功耗模式。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 芯片
    +关注

    关注

    446

    文章

    47756

    浏览量

    409050
  • mcu
    mcu
    +关注

    关注

    146

    文章

    16010

    浏览量

    343532

原文标题:证明你的MCU够强,有时不需要昂贵开发工具!

文章出处:【微信号:mcuworld,微信公众号:嵌入式资讯精选】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    芯科科技推出新的8位MCU系列产品,扩展其强大MCU平台

    “芯科科技”,NASDAQ:SLAB),今日宣布推出新的8位微控制器(MCU)系列产品,该系列MCU针对价格和性能进行了优化,进一步扩展了芯科科技强大MCU开发平台。 这些新的8位
    发表于 11-21 15:20 572次阅读
    芯科科技推出新的8位<b class='flag-5'>MCU</b>系列产品,扩展其<b class='flag-5'>强大</b>的<b class='flag-5'>MCU</b>平台

    请问用算力强大的SOC来控制汽车是不是能够大幅减少MCU的使用数量?

    来自一位用户的咨询,麻烦帮忙解答,越详细越好,有图有真相,可以适当提供一些英飞凌解决方案和产品推荐。 用算力强大的SOC来控制汽车是不是能够大幅减少MCU的使用数量? 未来电动汽车会使用SOC来代替大量MCU?
    发表于 02-02 07:16

    莫名被戳中的“不只是”体

    机会获得惊喜,不知道下面这些网友的够不够资格呢?一起来欣赏下吧。 不只是因为长的丑,这个居然也有版本 年薪20万谁不眼馋 国安的球迷也不示弱 居然也出了一个星爸的版本 这个看来是力宏的粉丝写的了 好基友,一辈子 上一次头条就这么
    发表于 05-26 17:24

    莫名被戳中的“不只是”体

    机会获得惊喜,不知道下面这些网友的够不够资格呢?一起来欣赏下吧。 不只是因为长的丑,这个居然也有版本 年薪20万谁不眼馋 国安的球迷也不示弱
    发表于 05-26 17:26

    超级强大的心理定律~~!可以变成你想要的样子!~

    是情绪化的动物,而且任何时候的决定都是情绪化的决定。 4、因果定律 任何事情的发生,都有其必然的原因。有因才有果。换句话说,当你看到任何现象的时候,不用觉得不可理解或者奇怪,因为任何事情的发生都必有其
    发表于 12-11 17:19

    复旦微MCU强大的串口功能

    最近试了下复旦微的串口,功能确实非常强大;1、首先串口路上非常多,高达6路之多 ,随着物联网的趋势,现在产品通信,升级,无线,wifi,蓝牙,以太网等功能用到的越来越多,外扩基本都需要串口,现在
    发表于 09-09 22:14

    关于现实标准和32位MCU的知识点,看完就懂了

    关于现实标准和32位MCU的知识点,看完就懂了
    发表于 04-26 06:32

    为什么不只使用低阻抗扬声器?

    为什么不只使用低阻抗扬声器?
    发表于 05-28 06:03

    MCU、MPU、DSP、FPGA的概念看完就懂了

    MCU、MPU、DSP、FPGA的概念看完就懂了
    发表于 09-24 07:12

    什么是MCU,看完就懂了

    目录3. 什么是MCU?3.1 定义3.2 分类3.2.1 按用途分类3.2.2 按基本操作处理的数据位数分类3.3 厂商介绍3.3.1 国外3.3.2 国内***3.3.3 国内大陆3.
    发表于 11-04 08:05

    为什么MCU不支持SDRAM呢

    在使用MCU的嵌入式系统设计中,当程序或者数据内存占用太大而无法放入片上闪存或SRAM时,开发者通常考虑使用SDRAM。别问我为什么MCU不支持SDRAMSDRAM是...
    发表于 12-16 06:28

    i.MX RT1052这种级别MCU通常都跑什么系统?

    性能这么强大MCU应该很少会裸机开发吧,用什么系统更合适呢。
    发表于 11-09 07:41

    8条腿的MCU原来有这么强大和广泛的功用

    8条腿(pin)、8位、8k flash...不少人听到这些参数可能会嗤之以鼻,当MCU的CoreMark跑分已经动辄2000多分,像这种“简陋”的单片机已经处在了鄙视链的底端。
    的头像 发表于 02-22 15:17 3w次阅读

    用了这么多年的MCU,你知道哪些MCU原厂最牛?

    单片机诞生于1971年,经历了SCM、MCU、SoC三大阶段。单片机由以前的1位、4位、8位、16位,发展到现在的32位甚至64位。90年代后随着消费电子产品大发展,单片机技术得到了巨大提高,相继
    发表于 10-25 09:51 9次下载
    用了<b class='flag-5'>这么</b>多年的<b class='flag-5'>MCU</b>,你知道哪些<b class='flag-5'>MCU</b>原厂最牛?

    低成本 MCU 助力电池组系统实现强大功能

    低成本 MCU 助力电池组系统实现强大功能
    发表于 10-28 12:00 0次下载
    低成本 <b class='flag-5'>MCU</b> 助力电池组系统实现<b class='flag-5'>强大</b>功能