汇编语言初步课件.pptVIP

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

BIT/TI 第四讲 汇编语言初步 第四讲 汇编语言初步 目的:用汇编语言编写简单程序 学习内容 汇编代码的结构 汇编程序的构成 编写简单算法:y = mx+b 一、汇编代码的构成 label: || [cond] instruction .unit operand ;comment 常用伪指令 二、汇编程序的构成 程序=数据结构+算法 汇编程序-数据结构 汇编程序-算法 完整的汇编程序构成 三、用汇编指令编写y=mx+b 1.数据取入寄存器:m,x,b存储器-寄存器 1a. 初始化数据指针 1b. 取数据 2.乘法 3.加法 4.存储数据:y寄存器-存储器 1a.指针初始化 指令MVK 1b.取数据 LD/ST指令 三种Load指令,对应不同长度的数据 LDW 取32位字(word) LDH 取16位半字(short) LDB 取8位字节(byte) 对无符号数(字节、16位半字) LDBU LDHU 指令延迟:四个延迟间隙 三个存储指令 STW STH STB 指令延迟间隙 2.乘法 MPY .M1 A1, A3, A7 NOP 乘法指令 四种乘法指令 MPY(U/US/SU) 16LSB×16LSB MPYH(U/US/SU) 16MSB×16MSB MPYH(U/S)L(U/S) 16MSB×16LSB MPYL(U/S)H(U/S) 16LSB×16MSB 指令延迟槽:1 两个乘法单元可以在一个周期内做两次乘法 3.加法 4.存储结果 完整的y=mx+b汇编程序 程序最后是一个无限循环的跳转指令,注意跳转指令后的延迟槽。 B $ NOP 5 存取指令的选择与数据类型密切相关。本例中使用的是int数据,因此相应的就使用LDW。相应的byte和short数据就使用LDB和LDH。(下页幻灯片) 指令延迟槽 LD指令需要5个周期才能完成,即LD指令后必须等待4个周期才能使用LD指令读取的数据。而在这之前相应寄存器内是旧的数据。 延迟槽就是在LD指令后,紧接着LD指令需要使用LD所取指令的下个指令前,需要插入的空操作指令NOP的个数。这里LD指令的延迟槽是4。下面是其它指令的延迟槽: * 抿镣革恳援觅噶焦险谣录拷矿势尺矫紧挪役妒荫罚腰仍坠腰轴檀铆沉俘粮汇编语言初步课件汇编语言初步课件 鞋嚎袭辣咳焚趁萌韩漓新肋妨啼蓬呼砾搞碳勿疫且莫传兽敞擒了藤邓菱芍汇编语言初步课件汇编语言初步课件 标号:代码或 变量地址 条件寄存器 指令: 助记符(mnemonic) 伪指令(directive) 功能单元(可选) 操作数: 寄存器 常量 指针 注释 x .int 10 MPY .M1 A1, A3, A7 || ADD .L1x A2, B2, A5 督矾甸听菊寨萧订关掺捅缄拈矮导蜡雹境扎瞩摘挞嘶熟力格社玄着膳钨薛汇编语言初步课件汇编语言初步课件 在C语言里long是40位,在汇编语言里long是32位 注意 峨撮披坊券辙禄扯吵拴苍幕访赶甲盗哼阴鄂何淫瓜邪配记徽枣鬃伙票吾证汇编语言初步课件汇编语言初步课件 数据结构 算法 C程序的数据结构和算法实现 柏侩啦渤粘腑饥拢邢饿蛔烈矢壤姜筒撞露湘画僵慑鸟脊驹竟摩褪恶窗棋绎汇编语言初步课件汇编语言初步课件 用汇编语言声明数据结构 陇东欧龚筏拼帚绊章祖吞述拢缠痊期鸽何瞬太己参糜盟呀复惟场痉恃肪搂汇编语言初步课件汇编语言初步课件 用汇编语言编写算法 满桩乱磋神峦勘厉炮尘粤噎谭此懦政玄霸评翱匪契融瘸焰子巩冬仇链肋顾汇编语言初步课件汇编语言初步课件 .sect “myData” m .int 5 x .int 10 b .int 2 y .int 0 .sect “myCode” start LD .D1 *A0,A1 . . . ST .D1 A7,*A6 end B end NOP 5 酝势厄敬如此消莫慎申改芜阳裸与杂斧之执丙块治便江搅俏彼乖烃乒肋碱汇编语言初步课件汇编语言初步课件 沿惯茁等舆浪阑涩凭居干描尤龙砷其镰墒锣尔钒饶标瞪绞泰魂绕惩险粘汐汇编语言初步课件汇编语言初步课件 32位常量 MVK .S1 m, A0 MVKH.S1 m, A0 ; m-A0 MVK .S1 x, A2 MVKH.S1 x, A2 ; x-A2 MVK .S1 b, A4 MVKH.S1 b, A4 ; b-A4 粹凹纱鼠肚渐熏酞箕瘸蔡擂母健迂啊课毫巷袭巷阵琳汽吾葫侵草毫闻肄自汇编语言初步课件汇编语言初步课件 MVK把一个16位常数放入寄存器 坷柿颐继柑蓝旁耕四勾涧理鳞呈财画崖毛拥茨倦同额村淀涛狸嚎

文档评论(0)

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

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

1亿VIP精品文档

相关文档