第3章_C6指令系统2.ppt

  1. 1、本文档共33页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第3章_C6指令系统2

第3章 C6000指令系统;3.1 C6000开发工具CCS 3.2 C6000指令结构 3.3 C6000存储器访问指令 3.4 C6000算术逻辑运算指令 3.5 C6000分支、调用指令 3.6 C6000软件流水线循环指令 3.7 伽罗瓦乘法指令;第4节 C6000算术逻辑运算指令;1、加减运算指令分类 有符号数加减运算指令: ①操作数为整型(32位)或长型(40位)的ADD、SUB指令 ②操作数为半字(16位) 的ADD2、SUB2指令:同时进行2个16位补码数的加减运算,高半字与低半字之间没有进/借位,各自独立进行。 无符号数加减运算指令ADDU、SUBU:操作数为32位或40位无符号数。 带饱和的有符号数加减运算指令SADD、SSUB:操作数为32位或40位有符号数。 与16位常数进行加法操作的指令ADDK。;2、加减运算指令的溢出问题 溢出:运算结果超出目的操作数字长所能表示数的范围,造成运算结果的高位丢失,使保存的运算结果不正确,称为溢出。 定点数以全字长表示一个整数,其能覆盖的数据动态范围较小,易产生溢出。 ①定点无符号加减运算类指令:高位丢失,运算结果不正确 ②定点有符号加减运算类指令:产生溢出时会改变运算结果的符号 在C6000的指令里,普通加减运算指令产生溢出时在CPU内不会留下任何标志。 解决溢出问题通常有3种办法:;①用较长的字长来存放运算结果,使目的操作数字长超出源操作数的字长。超出源操作数字长的部分称为保护位(guard bit) #:N位保护位可以保证2N-1次累加运算不溢出 #:增加保护位要占用系统资源,还可能降低运算速度 ②用带饱和的加减运算指令SADD、SSUB做补码加减运算:当产生溢出时,这类指令将使目的操作数置为同符号的最大值(绝对值),即保持运算结果的符号不变,同时使CPU的状态寄存器CSR内的SAT位置1,提示用户注意。 ③对整个系统乘一个小于1的比例因子,亦即将所有输入的数值减小,以保持运算过程不溢出,但这种方法会降低计算结果。;例3.5: ① SSUB .L2 B1, B2, B3;② SUB .L2 B1, B2, B3 产生溢出:此时存入B3寄存器的内容为DA04 1201h,它是一个负数(-637267455),得数的正负号及数值全错了。 ③ SUB .L2 B1, B2, B5:B4 得数为B5:B4=00DA041201h,它是一个40位有符号数(+3657699841),结果正确。其中???存放在B5的内容为00h,存放在B4的内容为DA041201h。;例3.6: 累加和运算举例 计算累加和的程序,用长型数存放和数,有 8 位保护位。下述程序在进入loop循环前,已使寄存器A4指向存放数组的基地址,寄存器B2存放欲累加的个数,寄存器组A7:A6 用来存放累加和,进入循环前已清零。 loop: LDW .D1 *A4++, A5 NOP 4 ADD .L1 A7:A6, A5, A7:A6 SUB .L2 B2, 1, B2 [B2] B .S1 loop NOP 5; C6000的乘法运算指令以16?16位硬件乘法器为基础。在.M功能单元中进行运算。 整数乘法指令:以MPY为首字母的13条指令 MPY 、MPYU 、MPYUS、MPYSU、MPYHL、MPYHLU、MPYHULS、MPYHSLU、MPYLH、MPYLHU 、MPYLUHS、MPYLSHU ①其2个源操作数都是16位字长,目的操作数是32位的寄存器 ②根据源操作数为有/无符号数以及源操作数是寄存器的低/高半字,可以组合成16种不同的乘法指令。 ③除了2个无符号源操作数相乘外,只要有一个源操作数是有符号数,其结果就认定是有符号数。 ④由于目的操作数是32位,乘法指令不存在溢出问题;适宜Q格式数相乘的3条指令: SMPY、SMPYLH、SMPYHL ①通常用Q格式数表示小数 ②16位定点数的Q15格式:最高位为符号位,符号位后即是小数点位置;实际小数范围是-1?x ?0.9999695 ③Q14:符号位有1位整数,而后才是小数点位置,表示的小数范围是-2?x ?1.9999390 ④定点数Xq和实际小数x之间的转换关系: Xq =int(x?2q);x= Xq ? 2-q ⑤定标:选定Q格式值后,应将系统的全部数值转换成同一格式的定点数,称为定标,即确定同一标尺。;3.4.2 乘法运算指令;3.4.2 乘法运算指令;ABS:取绝对值

文档评论(0)

cbf96793 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档