957|0

6815

帖子

0

资源

五彩晶圆(中级)

ST1寄存器中CPL位的影响 [复制链接]

CPL位是编译模式控制位,它表示在相对直接寻址时采用哪种指针。当CPL=0时,使用页指针DP;当CPL=1时,使用堆栈指针SP。实际使用中二者没什么差别,但使用SP寻址的程序更易读。在程序中经常使用CPL=1。


         指令的歧义
        比较下面指令
         STLM B,AR4 把bl内容送入寄存器AR4 (×)
         STLM B,*AR4 把bl内容送入寄存器AR4(√)??
         前者实际执行的是把bl内容送入一个系统用的缓冲区,后者也可用:
         MVDM BL,AR4 把bl内容送入寄存器AR4 (√)?
         其他易导致歧义的语句还有:
         LD AR5,A 把AR5的内容送入寄存器A (×)
         LDM AR5,A 把AR5的内容送入寄存器A(√)??
         ANDM #0x107e,AR4;把#107e加到寄存器 AR4 (×)
         ANDM #0x107e,*AR4; 把#107e加到寄存器 AR4 (√)???
         仅对某些寄存器有效的指令:
         MVDD * AR2+,*AR3+ 把以AR2为地址的内容拷入AR3的地址中
         此类指令用作数据块搬移特别有效,但仅对AR2、AR3、AR4、AR5有效。
         易错语句中对程序运行危害最大的是:
ST #0 (bsp0_out_sign);
bsp0_out_sign 是一个变量名?(√)?
STM #0,bsp0_out_sign;
此语句被编译为STM #0,PMST或STM #0,IMR (×)
复制代码


         这种语句会导致程序运行中的随机故障,且极难发现。
          流水冲突
         分析以下程序:
STM to-dce-buff, AR4
LDM AR4,B
ADD A,B ;B=AR4+AL
MVDM BL,AR4 ;AR4=to-dce-buff+AL
复制代码


         实际上,上段程序得不到AR4=to-dce-buff+AL 的结果。这是因为DSP一般采用深度为3~6级的流水结构,产生了无法解决的冲突,所以它不能被正确执行。解决的办法是在赋值和引用之间插入一条或几条其他的指令,或NOP语句即可。


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

查找数据手册?

EEWorld Datasheet 技术支持

最新文章 更多>>
    关闭
    站长推荐上一条 1/7 下一条

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

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

    北京市海淀区知春路23号集成电路设计园量子银座1305 电话:(010)82350740 邮编:100191

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