单片机双DPTR的使用方法.docVIP

  1. 1、本文档共10页,可阅读全部内容。
  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文档。上传文档
查看更多
单片机双DPTR的使用方法   DPTR是某些单片机中一个功能比较特殊的寄存器,是一个16位的特殊功能寄存器, 其高位字节寄存器用DPH表示,低位字节寄存器用DPL表示,DPTR既可以作为一个16位的寄存器来处理,也可以作为两个独立的8位寄存器来使用   主要功能是存放16位地址,作为片外RAM寻址用的地址寄存器(间接寻址),故称数据指针,也可以将外部RAM中地址的内容传送到内部RAM的地址所指向的内容中。DPH和DPL的地址分别为83H、82H。   单片机双DPTR的使用方法   1.简述   在重新设计程序升级的过程中,51系列单片机增加了另一个数据指针DPTR   软件能利用附加的数据指针加快程序的执行速度和缩减程序大小   本文的开始概述了原数据指针的操作接着简述了新数据指针如何匹配原先数据指针本文还解释了双数据指针部分在物理和软件上的识别最后还对采用双数据指针的各种软件策略包括汇编语言中断和C进行了说明   2数据指针DPTR的概述   在Intel MCS-51单片机结构中16位DPTR寄存器能对存贮区内的各个部分进行寻址使用DPTR寻址存贮器的指令如下所示   MOVX @DPTR,A 将累加器A的内容送到由DPTR寻址的数据存贮区内 MOVX A@DPTR 将由DPTR寻址的数据存贮区内的内容送到累加器A   8051结构用脚PSEN和RD分别选通程序存贮器只读和数据存贮器MOVX指令访问数据存贮器(例如RD脚数据存贮器一般是指RAM或存储映像I/O   MOVC A@DPTR 将由DPTR寻址的程序存贮区内的内容送到累加器A   MOVC指令通过访问程序存贮器例如PSEN脚,以存取只读常数(例如:数据表字符串)程序存贮器一般是指ROM或EPROM JMP @A+DPTR 转移到由DPTR和A的内容相加形成的地址处   相加形成的地址送PC寄存器DPTR和A都没有改变这条指令常用于执行查表功能在表内DPTR指向表的基址变址由A表示 操作DPTR的指令如下所示   INC DPTR DPTR加1   MOV DPTR#16 将16位立即数送到DPTR   然而DPTR也与其他CPU寄存器如ABPSW一样被操纵为特殊功能寄存器SFR所有特殊功能寄存器通过各种指令例如PUSH和MOV存取字节并采用直接寻址方式   16位DPTR可被映像成两个特殊功能寄存器 用于字节寻址这两个特殊功能寄存器即为DPH高位字节地址为83H和DPL低位字节地址为82H指令如下 MOV DPTR#1234H 用立即数1234H装载DPTR   其功能等同于执行下面两条程序但执行程序的时间和程序大小不相等 MOV DPH#12H 将立即数12H送到DPTR高字节83H MOV DPL#34H 将立即数34H送到DPTR低字节82H   3双DPTR数据指针   下面的51系列CPU通过采用双数据指针而得到升级P8xC51P8xC52P8xC54P8xC58   联系飞利蒲半导体厂商以确定这些产品和将来产品的双数据指针的转换状态参见图1这些升级的CPU仍然只有一个逻辑数据指针但可分成两个在物理上独立的数据指针索引单逻辑数据指针例如通过把DPTR作为一个操作数的指令可根据AUXR1特殊功能寄存器地址为A2H的DPS位的状态以确定使用其中物理数据指针之一类似地SFR寻址DPH83H和DPL82H的索引可访问当前选择的数据指针。      复位时DPS被设置为0为了能简单处理DPSAUXR1中的非定义位可写入任何值但读操作时只能为1CPU是采用单数据指针还是双数据指针可通过检测DPS位的当前值来决定   下面对80C51仅为80C51的AUXR1特殊功能寄存器作专门的说明具有双数据指针的新80C51 AUXR1的格式与上面AUXR1的格式有稍微的不同图2所示位3为WUPD从低功耗模式唤醒模式选择位当复位时WUPD和DPS一起设置为0利用CPU掉电方式的应用程序在复位后能把WUPD置1使能唤醒特性位2定义为0是为了容易处理DPS位正如下节所描述的。      图2 AUXR1#的定义80C51   4汇编语言   附加的数据指针能通过许多途径加速程序的执行和缩减程序大小例如通过用一个数据指针作为源指针另一个作为目的指针能很好地处理许多通用块操作比如复制比较搜索等   ------------------------------------------ 块移动使用双数据指针   破坏DPTR0DPTR1A和PSW   注释DPS退出时的状态与入口时的状态相反 除非把额外的INC AUXR1的指令增加进去   ----------------------------------------- 00A2 AUXR1 EQU 0A2H   0000 909

您可能关注的文档

文档评论(0)

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

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

1亿VIP精品文档

相关文档