2621|1

1万

帖子

25

TA的资源

裸片初长成(高级)

楼主
 

【C2000的使用经验】使用重复指令,使用你的代码更简 [复制链接]

过去也曾讨论过CCS编译器的编译效率问题,作为TI CPU的专用编译器 ---- CCS,不能用到有特点的、效率高的指令,确实让人感到遗憾。



看一下常用的一个函数的编译结果:



void MemCopy(Uint16 *SourceAddr, Uint16* SourceEndAddr, Uint16* DestAddr)
{
    while(SourceAddr < SourceEndAddr)
    {
       *DestAddr++ = *SourceAddr++;
    }
    return;
}
不优化时:
        ADDB     SP,#4               
        MOVL     *-SP[4],XAR5         
        MOVL     *-SP[2],XAR4         
        MOVL     XAR6,*-SP[2]
        MOVL     ACC,*-SP[4]
        CMPL     ACC,XAR6
        B        $C$L2,LOS
$C$L1:   
        MOVL     XAR4,*-SP[2]
        MOV       AL,*XAR4++   
        MOVL     *-SP[2],XAR4
        MOVL     XAR4,*-SP[8]
        MOVL     XAR6,XAR4
        ADDB     XAR6,#1  
        MOVL     *-SP[8],XAR6
        MOV      *+XAR4[0],AL
        MOVL     XAR6,*-SP[2]
        MOVL     ACC,*-SP[4]
        CMPL     ACC,XAR6
        B        $C$L1,HI
$C$L2:   
        SUBB     SP,#4   
        LRETR     ; [CPU_]
最高优化级:
        MOVL     XAR7,XAR4     
        MOVL     ACC,XAR5     
        MOVL     XAR5,*-SP[4]   
        CMPL     ACC,XAR7  
        BF       $C$L2,LOS  
        SUBL     ACC,XAR7
        SUBB     ACC,#1  
        MOVL     XAR4,ACC
$C$L1:   
        MOV       AL,*XAR7  
        MOV      *XAR5++,AL  
        SUBB     XAR4,#1  
        MOVB     ACC,#0  
        ADDB     XAR7,#1  
        SUBB     ACC,#1   
        CMPL     ACC,XAR4  
        BF       $C$L1,NEQ   
$C$L2:   
        LRETR   
实际上,对于这个问题,都有相应的指令可用:
XPREAD loc16, *(pma)
XPWRITE *A,loc16
上两条指令是将程序区的内容拷贝至目标地址。指令的应用示例如下:
; Copy the contentsof Array1 to Array2:
; int16 Array1[N];// Located in high 64K of program space
; int16 Array2[N];// Located in data space
; for(i=0; i < N;i++)
; Array2 =Array1;
MOVL XAR2,#Array2 ;XAR2 = pointer to Array2
RPT #(N−1) ; Repeatnext instruction N times
||XPREAD*XAR2++,*(Array1) ; Array2 = Array1,
; i++
然而,使用CCS编译器时,并没有用到此指令------ 不管优化与否。
所以,在应用编程时,与此相当的过程,可以用嵌入汇编的方法,使程序达到最简、运行效率更高。
再看一个例子。将某一数组的值累加。
C程序为:
    for ( i = 0; i < N; i++)
    {
       sum +=Array;
    }
// 注:N为某一定值,为需要累加的长度。
CCS编译后,生成如下汇编代码:
        MOV      *-SP[3],#0   ;使用SP作数据运算 ---CCS惯用的办法。
        MOV       AL,*-SP[3]
        CMPB      AL,#N
        BF        $C$L2,HIS ;判断累加N次否?
        MOVL     XAR4,#_Array 放首地址
$C$L1:   
        MOVZ     AR0,*-SP[3]
        MOV       AL,*+XAR4[AR0]
        ADD      *-SP[4],AL
        INC      *-SP[3]
        MOV       AL,*-SP[3]
        CMPB      AL,#N   
        BF       $C$L1,LO  
可见,CCS编译器并没有用到REP这条指令。

实际上,这个问题使用REP指令很容易解决:
       MOVL   XAR1, #Array      ;数据存储地址
       RPT    #N-1   ||ADDU ACC,*XAR1++;累加32个数据

最新回复

程序优化,收藏留着用  详情 回复 发表于 2017-7-19 10:15
 
点赞 关注(1)

回复
举报

63

帖子

0

TA的资源

一粒金砂(中级)

沙发
 
程序优化,收藏留着用
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/6 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表