6884|7

1170

帖子

0

TA的资源

至上芯片

楼主
 

51单片机特殊单元隐含的秘密 [复制链接]

一个原始的计算机指令本来是应该这样来编码的: 指令码头\目标存储位置\第一操作数\第二操作数\下一条指令的地址 但由于计算机默认下一条指令就在此指令后(分支和循环,操作数就是下一条指令地址)所以下一条指令这一节就删除了,而目标存储位置,可以用累加的方式来表达 例如A=A+XX 于是有再省去了一节,于是基本指令编码就是三字节长,由前面的引子我们发现隐含可以简短代码长度,而对51来说,它有三字节也有两字节指令\甚至还有单字节指令,它是怎么继续隐含的呢? 下面我们看51中那些是隐含的: A R0~R7 @R0 @R1 C (位累加器) AB (只用于乘除法) DPTR(必须16位一起用) SP(只限于PUSH 和POP 指令,PC(只限于查表), 这些隐含的是怎么"隐藏掉"的呢单元,其实你分析一下编址,她们就显原形了,编码有高低各4个位,其低4位就是它们的编码,下面看X3H这3对应DPTR, X4H 一定和累加器打交道 X6H和X7是间接寻址@R0和@R1 X8H到XFH 是R0到R7 X5H不隐含,但它"隐约"告诉我们它后面是个直接地址,那X2H呢,它是中断返回和LJMP,那X1H呢,它是AJMP 和ACALL 那XO呢,它是空跳NOP JBC JZ JNZ JC JNC JB JNB SJMP 相对跳转的组合 知道了这些规律对指令寻址译码运行可以理解得更透,而且一眼就能看出它是几个字节 例如CLR A CLR C INC A INC RN INC @R0 INC DPTR MOVC A,@A+PC MOVX A,@DPTR,DIV AB MUL AB MOV A,RN MOV @R0,A等都是单字节,INC 地址 PUSH 地址 MOV A,#数.....都是两字节 三字节则是一个都隐含不了,有点意思吧做个有心人,你也可以发现的.
此帖出自51单片机论坛

最新回复

学习了,多谢  详情 回复 发表于 2013-4-6 01:17
点赞 关注(1)
 

回复
举报

367

帖子

0

TA的资源

裸片初长成(高级)

沙发
 

回复:51单片机特殊单元隐含的秘密

MCS-51单片微型计算机指令手册 0-:INC Rn ;n=0~7,-=8~F 1-:DEC Rn 2-: ADD A,Rn 3-: ADDC A,Rn 4-: ORL A,Rn . . . . F-: MOV Rn,A n1: ACALL addr m1: AJMP addr . . . .
此帖出自51单片机论坛
 
 
 

回复

446

帖子

0

TA的资源

裸片初长成(高级)

板凳
 

回复:51单片机特殊单元隐含的秘密

哈哈~~~编码组合就是个阵列,搞过反汇编什么都明白了
此帖出自51单片机论坛
 
 
 

回复

11

帖子

0

TA的资源

一粒金砂(中级)

4
 

回复:51单片机特殊单元隐含的秘密

51单片机特殊单元隐含的秘密 一个原始的计算机指令本来是应该这样来编码的:   指令码头\目标存储位置\第一操作数\第二操作数\下一条指令的地址   但由于计算机默认下一条指令就在此指令后(分支和循环,操作数就是下一条指令地址)所以下一条指令这一节就删除了,   而目标存储位置,可以用累加的方式来表达 例如A=A+XX   于是有再省去了一节,于是基本指令编码就是三字节长,由前面的引子我们发现隐含可以简短代码长度,而对51来说,它有三字节也有两字节指令\甚至还有单字节指令,它是怎么继续隐含的呢?   下面我们看51中那些是隐含的: A R0~R7 @R0 @R1 C (位累加器) AB (只用于乘除法) DPTR(必须16位一起用) SP(只限于PUSH 和POP 指令,PC(只限于查表), 这些隐含的是怎么"隐藏掉"的呢单元, 其实你分析一下编址,她们就显原形了,编码有高低各4个位,其低4位就是它们的编码,下面看X3H这3对应DPTR, X4H 一定和累加器打交道 X6H和X7是间接寻址@R0和@R1 X8H到XFH 是R0到R7 X5H不隐含,但它"隐约"告诉我们它后面是个直接地址, 那X2H呢,它是中断返回和LJMP, 那X1H呢,它是AJMP 和ACALL 那XO呢,它是空跳NOP JBC JZ JNZ JC JNC JB JNB SJMP 相对跳转的组合 知道了这些规律对指令寻址译码运行可以理解得更透,而且一眼就能看出它是几个字节 例如 CLR A CLR C INC A INC RN INC @R0 INC DPTR MOVC A,@A+PC MOVX A,@DPTR, DIV AB MUL AB MOV A,RN MOV @R0,A等都是单字节, INC 地址 PUSH 地址 MOV A,#数.....都是两字节 三字节则是一个都隐含不了,有点意思吧做个有心人,你也可以发现的. 懵懵懂懂,看不懂哪!!
此帖出自51单片机论坛
 
 
 

回复

2

帖子

0

TA的资源

一粒金砂(中级)

5
 

回复:51单片机特殊单元隐含的秘密

使用价值不大,但作者对51指令有深入理解
此帖出自51单片机论坛
 
 
 

回复

399

帖子

0

TA的资源

裸片初长成(初级)

6
 

回复:51单片机特殊单元隐含的秘密

d在那里找的啊。是自己写的吗。 这个用处不是很大啊。来点有用的吧。
此帖出自51单片机论坛
 
 
 

回复

9

帖子

0

TA的资源

一粒金砂(中级)

7
 
学习了,多谢啊
此帖出自51单片机论坛
 
个人签名为了理想而奋斗
http://keweimcutaobao.com
 
 

回复

19

帖子

0

TA的资源

一粒金砂(初级)

8
 
学习了,多谢
此帖出自51单片机论坛
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表