第三章Blackfin的寻址方式及指令系统V选编.pptVIP

第三章Blackfin的寻址方式及指令系统V选编.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第三章Blackfin的寻址方式及指令系统V选编

Blackfin DSP的寻址方式及指令系统;内核结构及存储器结构回顾;内核结构(知识回顾);存储器结构(知识回顾);内部存储器:每个Blackfin处理器包含3个块的片内存储器,内核对这些存储器可以进行高速访问 L1指令存储器,由SRAM和cache组成。该存储器可以被处理器全速访问。 L1数据存储器,由SRAM和(或)cache组成。该存储器可以被处理器全速访问。 L1高速暂存RAM,该存储器可与L1存储器以相同的速度访问,但它只能用作数据SRAM,而不能配置成cache。 L2存储器,容量比L1大,访问性能比L1稍低,作为多核之间的共享内存,可以存放数据和指令,但不能用作cache;外部存储器:通过外部总线扩展器 External Bus Interface Unit(EBIU)进行访问。 它是一个16位总线接口,可以与多种类型的存储器进行无缝连接,如SDRAM、flash memory、 EPROM、ROM、SRAM、memory-mapped I/O设备。 I/O内存空间:Blackfin没有定义独立的I/O空间,所有I/O设备的控制寄存器都通过32位地址映射到统一的4GB地址空间。;Register Files(知识回顾);地址算术单元寄存器组;数据运算单元寄存器组:R0~R7 操作举例 32位访问: R2 = R1 + R2; 16位访问: R2.L = R1.H * R0.L 在寄存器组与L1数据存储器之间连接有3组32位的独立数据总线,包括2个Load,和1个Store;累加器寄存器:A0~A1 结构 16位:An.L, An.H 8位扩展位:An.X 32位:An.W 40位:An ;操作举例 A0 = A1; /* 40-bit move */ A1.W = R7; /* 32-bit move */ A0.H = R5.H; /* 16-bit move */ R6.H = A0.X; /* read 8-bit value and sign extend to 16 bits */;算术逻辑单元ALU;乘累加单元(MAC);桶形移位寄存器Barrel Shifter;程序控制器PROGRAM SEQUENCER;地址算术单元ADDRESS ARITHMETIC UNIT;;AAU实现多种功能以减小数据访问的开销 产生地址:在数据访问期间提供数据地址 产生地址后自动修改:提供数据搬移时的地址,并为下一次搬移自动增减地址 产生偏移地址:提供相对于某个基地址的偏移量,不改变原始地址指针 修改地址:增减地址,不进行数据搬移 位逆序地址:在数据搬移时提供位逆序地址;;BLANKFIN指令集简介;;;DAG的寻址;DAG寻址方式汇总;不同位宽的寻址;帧和堆栈指针;;;索引和指针寄存器的索引寻址;;;自动增减寻址;;预修改堆栈指针寻址;后修改寻址;;循环寻址;循环寻址说明;循环寻址注意事项 预调整地址方式不支持循环寻址方式。 在向Bx寄存器写入起始地址的同时,对应的Ix寄存器也会自动赋予相同的值。 Bx、Lx、Ix三个寄存器的序号必须一致,而Mx寄存器可以在同一个DAG组中任意选取。 两个DAG中都可以设置循环缓存区 Mx寄存器可以正也可以负 对Lx和Bx寄存器清零,对应的Ix寄存器自动恢复线性寻址方式。;;位逆序寻址;;;;指令集;;Example jump get_new_sample ;跳转至用户定义标记的绝对地址 jump (p5) ;跳转至寄存器Preg所指向的一个绝对地址 jump (pc + p2) ;跳转至PC(程序计数器)的一个相对地址,偏移量为Preg寄存器的内容 jump 0x224 ;跳转至PC+offset jump.s 0x224 ;短跳转至PC=PC+offset jump.l 0xFFFACE86 ;长跳转至PC=PC+offset;;;调用和返回指令(1);;调用和返回指令(2);循环指令;;;加载指令;加载字节 D-register = B [ indirect_address ] (Z);零扩展 D-register = B [ indirect_address ] (X);符号扩展 Example r0 = -344 (x) ; p3 = [ p2 ] ; p5 = [ p0 ++ ] ; r6 = [ p2 + 12 ] ; r3 = [ p0 ] ; r2 = w [ sp -- ] (z) ; r0 = b [ p4 + 0xFFFF800F ](x) ;;存储指令;寄存器数据转移指令;堆栈操作指令;;堆栈操作指令;Example link 8 ; 建立8个字的帧空间 [ -- sp ] = (r7:0, p5:0) ; 压栈 (r7:0, p5:0) = [ sp +

文档评论(0)

jiayou10 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8133070117000003

1亿VIP精品文档

相关文档