搜索
bottom↓
回复: 10

额滴神哪,IAR的编译器也太强悍了吧,居然会做出这种优化

[复制链接]

出0入0汤圆

发表于 2008-8-3 15:53:36 | 显示全部楼层 |阅读模式
一段初始化代码:
    PUINT16 FrontSurface;
    PUINT16 BackSurface;
    UINT32  Offset;

    ...

    Offset = 160;
    do
    {
        *--FrontSurface = 0;
        *--BackSurface = 0x720;
    } while (--Offset);

编译之后看了一下list,发现看不明白它啥意思:
        MOVS     R2,#+40
        MOVS     R3,#+228
        LSLS     R3,R3,#+3        ;; #+1824
        MOVS     R5,#+0
??Initialize_1:
        SUBS     R0,R0,#+2
        STRH     R5,[R0, #+0]
        SUBS     R4,R4,#+2
        STRH     R3,[R4, #+0]
        SUBS     R0,R0,#+2
        STRH     R5,[R0, #+0]
        SUBS     R4,R4,#+2
        STRH     R3,[R4, #+0]
        SUBS     R0,R0,#+2
        STRH     R5,[R0, #+0]
        SUBS     R4,R4,#+2
        STRH     R3,[R4, #+0]
        SUBS     R0,R0,#+2
        STRH     R5,[R0, #+0]
        SUBS     R4,R4,#+2
        STRH     R3,[R4, #+0]
        SUBS     R2,R2,#+1
        BNE      ??Initialize_1

跟踪了一把,才明白过来,它的意思是:

    Offset = 40;
    do
    {
        *--FrontSurface = 0;
        *--BackSurface = 0x720;
        *--FrontSurface = 0;
        *--BackSurface = 0x720;
        *--FrontSurface = 0;
        *--BackSurface = 0x720;
        *--FrontSurface = 0;
        *--BackSurface = 0x720;
    } while (--Offset);

只好膜拜一下……

阿莫论坛20周年了!感谢大家的支持与爱护!!

曾经有一段真挚的爱情摆在我的面前,我没有珍惜,现在想起来,还好我没有珍惜……

出0入4汤圆

发表于 2008-8-3 16:03:37 | 显示全部楼层
你可以禁止对loop的优化啊

出0入0汤圆

 楼主| 发表于 2008-8-3 16:06:24 | 显示全部楼层
其实倒不是说嫌它优化loop不好,只不过是它的优化方式有点太出乎意料了

出10入120汤圆

发表于 2008-8-3 16:25:59 | 显示全部楼层
优化的不错,速度比简单的(FOR...NEXT)应该快很多。

IAR就是IAR啊

出0入0汤圆

发表于 2008-8-17 13:06:57 | 显示全部楼层
确实牛

出280入168汤圆

发表于 2008-8-17 13:35:56 | 显示全部楼层
不错!不过似乎这是 ARM 核的标准代码,在很多不同产品的源代码中都见到过。相对于老型号的 CPU 核,ARM 核有 4 个自由寄存器替代了老型号的 CPU 的一个累加器,所以代码在最大程度上利用这些寄存器,使执行效率提高了很多倍。

在 ARM7 的内核中,它的优势很明显:减少了跳转,降低了代码预取机构的刷新次数,使代码执行效率提高了很多。

出0入0汤圆

发表于 2015-5-16 21:00:55 | 显示全部楼层
循环展开啊  挺智能

出0入12汤圆

发表于 2015-5-18 14:22:25 | 显示全部楼层
Loop unrolling

出0入0汤圆

发表于 2015-5-18 14:37:28 | 显示全部楼层
循环展开
搜了一下,意思是通过展开,减少跳转次数,降低分支对流水线的打断,提高速度?

出0入0汤圆

发表于 2015-5-21 13:31:51 | 显示全部楼层
Loop unrolling
循环展开

出0入10汤圆

发表于 2015-10-12 12:01:36 | 显示全部楼层
厉害,我居然看懂了
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-8-25 16:23

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表