- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
swi SWI 的一系列的详细事件: ①在SWI 代码操作后,PC 指向下一个地址(这是个返回地址) ②PCL 压栈——存储PC(低位)特定位置指向通过SP,然后减少SP 的值。 ③PCH 压栈。 ④同样顺序下将X、A 和CCR入栈——在这个顺序的结尾,SP 指向CCR 进 栈地址的下一个位置。 ⑤在CCR 中置位I 位,以使在执行中断服务子程序期间,禁止中断嵌套。 ⑥从$FFFC 中加载PCH——为中断服务子程序取来高地址的字节。 ⑦从$FFFD 中加载PCL。 ⑧转移到从$FFFC:FFFD 取来的地址。 为了与早期的M68HC05 兼容,高位寄存器H 不能够自动进栈。在中断服务子程序开始时手动将H 寄存器压栈和在返回中断子程序时手动将H 出栈是个很好的习惯。 通常,在中断服务程序中执行的最后指令是中断返回(RTI),RTI 恢复了CCR、A、X、PCH 和PCL 的值,之前它们按相反的顺序被保存在堆栈中。每个字节从堆栈中取出时,SP 加1 并指向下一个将被取出的数据,相应的寄存器从SP 指向的地址加载数据。在执行RTI 后,程序重新返回刚才被压进堆栈的地址。 其它指令 无操作指令(NOP)一般用于在软件中产生程序延时。它消耗执行时间,但是不引起任何状态码和CPU 寄存器的改变。下面的例子是用NOP 来产生1ms 延时的软件循环。 627 ********************* 628 *dly1ms – 总线频率延时1ms 总线频率= 20MHz 629 ********************* 630 ;1个总线周期 = 50个十亿分之一秒,因此20,000个周期= 1ms 631 ;JSR (EXT)指令占了[5或者6]周期,总的花费的时间是24-25周期 632 ;总的延时20000= 8n+24;因此n = 19976/8 = 2497 633 C232 8B dly1ms: pshh ;[2] 保存H 634 C233 89 pshx ;[2] 保存X 635 C234 9D nop ;[1] 使得n正好 636 C235 45 09C0 ldhx #2496 ;[3] 转移记数 637 C238 AF FF loop1ms: aix #-1 ;[2] H:X = H:X - 1 638 C23A 65 0000 cphx #$0000 ;[3] 零检查 639 C23D 26 F9 bne loop1ms ;[3] 直到H:X = $0000转移 640 C23F 88 pulx ;[3] 恢复X 641 C240 8A pulh ;[3] 恢复H 642 C241 81 rts ;[6] 返回 * * * * * * * 比较和测试 CMP 指令影响CCR 的位,就像相应的SUB 指令。但其结果不会存储回累加器中,因此A 寄存器和存储器操作数是不发生变化的。比较指令是比较寄存器A、X 或H:X内容与存储器中的操作数。在CPHX 指令执行时,M 指向存储位置的首地址,H 与存储器位置M 相对应,X 和存储器位置M+1 相对应。CPHX 执行一个16 位减法指令(存储结果不返回H:X 中)。 测试指令是将寄存器A、X 或者存储器中的操作数与0 相减。这个操作清零了V,然后依据测试的结果置位或者清零N 和Z,依据在测试指令的结果而定。测试指令不改变测试数的值。 BCD的计算 在BCD 码数值中,16 进制数表示一个有符号的十进制数值0 到9。当两个8 位的BCD 数值相加,CPU 实际上执行普通的二进制加法。对于BCD 码,这个计算的结果可能不再是一个有效的BCD 码。根据ADD 或ADC 指令对2 个标准的BCD 数计算所改变的H 和C 标志位,DAA 指令可以对结果进行修正使其成为有效的BCD 数并且修正C 标志位的内容使其正确的表示使用BCD 加法后的结果。在过去完成这些操作是非常复杂的,需要测试每一个BCD 数值的结果和H、C 标志位。而DAA 指令则能很简单的完成这个操作。 下面例子展示了2 种可能的情况:当2 个8 位BCD 数据相加,并且使用DAA 指令对其进行修正,以修正BCD 和设置进位标志位。第一个例子展示了一种情况,BCD码加法后结果不需要调整。第二个例子展示了另一种情况,BCD 码加法后需要对结果调整。在第二个例子中DAA 指令对数值加上了一个修正的因数并且调整了进位标志使其正确表示BCD 加法的结果。 LDA #$11 ;BCD 11 ADD #$22 ;11 + 22 = 33 DAA ;在这个情况中没有调整 LDA #$59 ;BCD 59 ADD #$57 ;59+57=$B0 ;C=0,H=1,A=$B0
您可能关注的文档
最近下载
- 《广告策划与创意》课件(全).pptx VIP
- 企业财务管理制度十二篇.docx VIP
- 工业行业市场前景及投资研究报告:解析Palantir.pdf VIP
- 检验科标本接收拒收制度标本验收标准.pdf VIP
- 卫生部手术分级目录(2025年版).doc VIP
- 电子束曝光技术.ppt VIP
- 第二单元《燕赵大地连津门》第2课时《津冀之声》课件 人教版二年级音乐上册.pptx VIP
- (2025)全国保密教育线上培训知识考试题库及参考答案.pdf
- 房地产制度与标准 - 绿城项目运营手册之交付后工作操作指引 .docx VIP
- 2024年9月28日福建省事业单位统考《行政职业能力测试》笔试试题.docx VIP
文档评论(0)