EDN首页   博客首页 用户登陆  |  注册
aaa
发表于 2006/12/12 10:11:31

21

关于投票

MCS-51系列指令快速记忆法

随着微电子技术和超大规模集成电路技术的发展,单片微型计算机以其体积小、性价比高、功能强、可*性高等独有的特点,在各个领域(如工业控制、家电产品、汽车电子、通信、智能仪器仪表)得到了广泛的应用。学习、使用单片机的人越来越多,而生产单片机的厂家很多,单片机种类繁杂,不知如何选择。据统计,八位单片机占全球单片机销量的65%。在八位单片机中,Intel公司的8051单片机内核已成为8位单片机事实上的标准。因此,对初学者而言,选择8051 单片机来学习不失为明智的选择。
  学习单片机,除了搞清单片机内部功能、存储空间分配及I/O接口外,还应掌握其指令系统。MCS-51共有111条指令,现介绍我们总结出的快速记忆MCS-51指令的方法,供大家参考。
  大家都知道,汇编语言指令由操作码、操作数两部分组成。MCS-51使用汇编语言指令,它共有44个操作码助记符,33种功能,其操作数有#data、direct、Rn、@Ri等。这里先介绍指令助记符及其相关符号的记忆方法。
  一、助记符号的记忆方法
  1表格列举法
  把44个指令助记符按功能分为五类,每类列表记忆。此处从略,请读者自己总结。

  2英文还原法
  单片机的操作码助记符是该指令功能的英文缩写,将缩写还原成英语原文,再对照汉语有助于理解其助记符含义,从而加强记忆。例如:
增量 INC-Incremect  减量 DNC-Decrement
短转移 SJMP-Short jump  长转移 LJMP-Long jump
比较转移 CJNE-Compare jump not equality 
绝对转移 AJMP-Absolute jump 空操作 NOP-No operation
交换 XCH-Exchange    加法 ADD-Addition
乘法 MUL-Multiplication  除法 DIV-Division
左环移 RL-Rotate left  进位左环移 RLC-Rotate
                    left carry
右环移 RR-Rotate right  进位右环移RRC-Rotate
                    right carry
  3功能模块记忆法
  单片机的44个指令助记符,按所属指令功能可分为五大类,每类又可以按功能相似原则为2~3组。这样,化整为零,各个击破,实现快速记忆。
  1)数据传送组。      2)加减运算组
   MOV 内部数据传送     ADD 加法
   MOVC 程序存储器传送   ADDC 带进位加法
   MOVX 外部数据传送    SUBB 带进位减法
  3)逻辑运算组。      4)子程序调用组。
   ANL 逻辑与        LCALL 长调用
   ORL 逻辑或        ALALL 绝对调用
   XRL 逻辑异或       RET 子程序返回

  二、指令的记忆方法
  1指令操作数的有关符号
  MCS-51的寻址方式共有六种:立即数寻址、直接寻址、寄存器寻址、寄存器间址、变址寻址、相对寻址。我们必须掌握其表示的方法。
  1)立即数与直接地址。
  ata表示八位立即数,#data16表示是十六位立即数,data或direct表示直接地址。
  2)Rn(n=0-7)、A、B、CY、DPTR寄存器寻址变量。
  3)@R0、@R1、@DPTR、SP表示寄存器间址变量。
  4)DPTR+A、PC+A表示变址寻址的变量。
  5)PC+rel(相对量)表示相对寻址变量。
  记住指令的助记符,掌握不同寻址方式的指令操作数的表示方法,为我们记忆汇编指令打下了基础。MCS-51指令虽多,但按功能可分为五类,其中数据传送类28条,算术运算类24条,逻辑操作类25条,控制转移类17条,布尔位操作类17条。在每类指令里,根据其功能,抓住其源、目的操作数的不同组合,再辅之以下方法,是完全能记住的。我们约定,可能的目的操作数按(#data/direct/A/Rn/@Ri)顺序表示。
  对于MOV指令,其目的操作数按A、Rn、direct、@Ri的顺序书写,则可以记住MOV的15条指令。例如以累加器A为目的操作数,可写出如下4条指令。
  MOV A,#data/direct/A/Rn/@Ri
  以此类推,写出其它指令。
  MOV Rn,#data/direct/A
  MOV direct,#data/direct/A/Rn/@Ri
  MOV @Ri,#data/direct/A
  2指令图示记忆法
  图示记忆法是把操作功能相同或相似、但其操作数不同的指令,用图形和箭头将目的、源操作数的关系表示出来的一种记忆方法。例如:由助记符MOV、MOVX、MOVC组成的送数组指令,可以用图1、2帮助记忆。
  由助记符CJNE形成的四条指令,也可以用图示法表示,如图3。
CJNE A,#data,rel   CJNE A,direct,rel
CJNE @Rn,#data,rel CJNE @Ri,#data,rel
  另外,对于由(ANL、ORL、ARL)形成的18条逻辑操作指令,有关A的四条环移指令,也可以用图示法表示,请读者自行画出记忆。
  3相似功能归类法
  在MCS-51指令中,我们发现部分指令其操作码不同,但功能相似,而操作数则完全一样。相似功能归类法就是把具有这样特点的指令放在一起记忆,只要记住其中的一条,其余的也就记住了。如加、减法的十二条指令,与、或、非的十八条指令,现列举如下:
  ADD/ADDC/SUBB A,#data/direct/Rn/@Ri
  ANL/ORL/XRL A,#data/direct/Rn/@Ri
  ANL/ORL/XRL direct,#data/a
  上述每一排指令,功能相似,其操作数都相同。其它的如加1(INC)、减1(DEC)指令也可照此办理。
  4口诀记忆法
  对于有些指令,我们可以把相关的功能用精练的语言编成一句话来记忆。如PUSH direct和POP direct这两条指令。初学者常常分不清堆栈SP的变化情况,为此编成这样一句话:(SP的内容)加1(direct的内容)再入栈,(SP的内容)弹出(到direct单元)SP才减1。又如乘法指令中积的存放,除法指令中被除数和除数以及商的存放,都可以编成口诀记忆如下。
  MUL AB  高位积(存于)B,低位积(存于)A。
  DIV AB  A除以B,商(存于)A余(下)B。
  上面介绍了几种快速记忆单片机指令的方法,希望能起到抛砖引玉的作用,相信读者在学习单片机的过程中能找到适合自己的方法来记忆。但是,有了好的方法还不够,还需要实践,即多读书上的例题和别人编写的程序,自己再结合实际编写一些程序。只有这样,才能更好更快地掌握单片机指令系统

系统分类: 单片机  |  用户分类: PCB  |  标签: 无标签  |  来源: 转贴  | 

点击查看原文

发表评论 阅读全文(1832) | 回复(0)

发表于 2006/11/20 19:28:06

32

关于投票

tms320vc33的原理图.pdf

tms320vc33的原理图.pdf

pdf

系统分类: PCB  |  用户分类: PCB  |  标签: 无标签  |  来源: 无分类  | 

点击查看原文

发表评论 阅读全文(2966) | 回复(6)

发表于 2006/11/20 19:26:33

26

关于投票

串行通信接口典型应用举例

串行通信接口典型应用举例

SCI_FLAG                   .usect         ".data0",1                                     ;SCI标志寄存器

TXD_PTR                   .usect         ".data0",8                                     ;发送的数据存放区

RXD_PTR                   .usect         ".data0",8                                     ;接收到的数据存放区

                            .include           "F2407REGS.H"            ;引用头部文件

.def               _c_int0

;(1)建立中断向量表

                            .sect         ".vectors"                                        ;定义主向量段

RSVECT             B    _c_int0                                            ;PM 0        复位向量                         1

INT1                          B    GISR1                                               ;PM 2         中断优先级1                   4

INT2                          B    PHANTOM                                   ;PM 4        中断优先级2                  5

INT3                          B    PHANTOM                                   ;PM 6        中断优先级3                  6

INT4                          B    PHANTOM                                   ;PM 8        中断优先级4                  7

INT5                          B    PHANTOM                                   ;PM A        中断优先级5                  8

INT6                          B    PHANTOM                                   ;PM C        中断优先级6                  9

RESERVED      B    PHANTOM                                   ;PM E        (保留位)                      10

SW_INT8        B    PHANTOM                                   ;PM 10    用户定义软件中断            —

                                             …

SW_INT31       B    PHANTOM                                   ;PM 3E    用户定义软件中断         —

;中断子向量入口定义pvecs

                            .sect         ".pvecs"                                          ;定义子向量段

PVECTORS        B         PHANTOM                                     ;保留向量地址偏移量0000h

                            B         PHANTOM                                     ;保留向量地址偏移量0001h

                                             …

                            B         PHANTOM                                     ;保留向量地址偏移量0005h

                            B         SCI_RX_ISR                                     ;保留向量地址偏移量0006h SCI接收中断

                            B         PHANTOM                                     ;保留向量地址偏移量0007h

                                             …

                            B         PHANTOM                                     ;保留向量地址偏移量0041h

 

;(2)主程序:

        .text

_c_int0    

SETC          INTM

               CLRC          SXM

               CLRC          OVM

CLRC          CNF

LDP                   #0E0H

SPLK                  #81FEH,SCSR1                                     ;CLKIN=6 M,CLKOUT=24 M

SPLK                  #0E8h,WDCR                                   ;关看门狗

                   CALL         SCI_INIT                                       ;调串口初始化程序

                   LDP           #5H

                   SPLK                   #00H,SCI_FLAG                            ;清发送软件标志位

TXD_LOOP:  

                   LDP           #5H

                   BIT            SCI_FLAG,BIT0

                   BCND           TXD_DATA,TC                            ;SCI_FLAG.0=1则发送数据

                   B                WAIT

TXD_DATA:                                                                   ;发送N个数据程序

                   MAR                   *,AR0

                   LAR          AR0,#TXD_PTR

                   ADRK         #N+1                                                        ;发送N个数据

                   MAR                   *,AR4

                   LACC         *+                                                   ;读数据

                   CMPR         00

                   BCND         TXD_DATA_END,TC                 ;判数据发送完?

                   MAR                   *,AR2

                   SACL         *,AR4                                          ;数据送SCITXBUF寄存器

XMIT_RDY:  

                   LDP           #DP_PF1

                   BIT            SCICTL2,BIT7

                   BCND         XMIT_RDY,NTC                         ;判发送器是否空?

                   B                TXD_DATA

TXD_DATA_END:

                   MAR                   *, AR4

                   LAR          AR4,#TXD_PTR                           ;恢复发送的数据指针

                   LDP             #5H

                   SPLK                   #00H,SCI_FLAG                            ;清发送软件标志位

WAIT:    NOP

                   B                TXD_LOOP

(3)串行通信初始化程序:

SCI_INIT:

                   LDP                    #0E1H

                   LACL         MCRA

                   OR             #03H

                   SACL         MCRA                                           ;配置串行口引脚为特殊功能:TXD、RXD

                   LDP                   #DP_PF1  

                   SPLK          #000FH,SCICCR                     ;地址位唤醒模式,8位数据,

;1位停止位,无奇偶校验

SPLK          #0007H,SCICTL1                             ;接收、发送、内部时钟使能 ,SLEEP=1

               SPLK          #0002H,SCICTL2                    ;接收中断使能

               SPLK          #0001H,SCIHBAUD

               SPLK          #0038H,SCILBAUD                          ;波特率为9600

               SPLK          #0027H,SCICTL1                    ;串口初始化完成

               LAR          AR1,#SCIRXBUF                         ;接收缓冲寄存器地址

               LAR          AR2,#SCITXBUF                         ;发送缓冲寄存器地址

               LAR          AR3,#RXD_PTR                           ;接收的数据指针

LAR          AR4,#TXD_PTR                            ;发送的数据指针

LDP          #0

                   SPLK                  #0001h,IMR                                     ;允许INT1中断

                   SPLK                  #0FFFFh,IFR                               ;清所有中断标志

                   CLRC         INTM                                             ;开总中断

                   RET

(4)中断程序

GISR1:                                                                              ;优先级INT1中断人口

                   ;保护现场

                   LDP           #0E0H

                   LACC         PIVR,1                                         ;读取外设中断向量寄存器(PIVR),并左移一位

                   ADD                  #PVECTORS                                     ;加上外设中断人口地址

                   BACC                                                                 ;跳到相应的中断服务子程序

SCI_RX_ISR:                                                                   ;接收中断服务程序

                   LDP           #DP_PF1

                   MAR                   *,AR1        

                   BIT            SCICTL1,BIT2

                   BCND         RXD_DATA,NTC                         ;SLEEP=0,接收数据

                   LACC         *                                                      ;读入地址

                   SUB           #0AAH

                   BCND         TXD_FLAG,EQ                            ;接收到的地址为AAH,则发送数据

                   SUB           #0001H

                   BCND         SCI_RX_END,NEQ                      ;地址错误,退出中断

                   SPLK                  #0033H,SCICTL1                     ;地址为ABH,则清SLEEP=0

;表示准备接收数据

                   B                SCI_RX_END

TXD_FLAG:                                                                    ;置发送标志

                   LDP           #5H

SPLK                  #01H,SCI_FLAG

                   B                SCI_RX_END

RXD_DATA:                                                                   ;接收N个数据

                   LACC         *,AR3                                          ;读入数据

                   SACL         *+,AR0                                        ;保存数据

                   LAR          AR0,#RXD_PTR

                   ADRK         #N

                   MAR                   *,AR3

                   CMPR         00

                   BCND         SCI_RX_END,NTC                      ;判是否接收完

                   LAR          AR3,#RX_PTR                              ;恢复接收的数据指针

                   SPLK                  #0037H,SCICTL1                     ;置SLEEP=1表示准备接收地址

SCI_RX_END:                                                                           ;中断返回

                   ;恢复现场

                   CLRC         INTM                                             ;开总中断,因为一进中断就

;自动关闭总中断

                   RET

(5)假中断程序

PHANTOM      

KICK_DOG                                                         ;复位看门狗

                   RET

                   END

系统分类: PCB  |  用户分类: PCB  |  标签: 无标签  |  来源: 无分类  | 

点击查看原文

发表评论 阅读全文(1064) | 回复(0)

发表于 2006/11/19 18:58:53

22

关于投票

谈在powerpcb中如何将多层板层数减少

在powerpcb中将多层板的层数的减小的方法如下,现举个例子:4层板删除layer2、layer3层,变成2层板,其他的做法一样:
第一步:删除layer2层的电特性数据,包括走在该层的traces、copper、via。
第二步:删除layer3层的电特性数据,包括走在该层的traces、copper、via。
第三步:进入菜单setup/Layer Definition面板。在Electrical layers栏中点击modify按钮。在弹出的对话框中输入2。如果layer2、layer3已经没有电特性数据,那么4层就变成2层板了。如果 layer2、layer3已经还有电特性数据,会出现一个警告说layer2、layer3已经还有电特性数据。按第一、第二步骤删除它,再进入第三步。
第四步:将原先布在layer2、layer3的相关部分布到top、bottom层即可。

系统分类: PCB  |  用户分类: PCB  |  标签: 无标签  |  来源: 无分类  | 

点击查看原文

发表评论 阅读全文(1395) | 回复(0)

发表于 2006/11/18 19:07:55

23

关于投票

射频电路板设计技巧

射频电路板设计技巧

rar

系统分类: PCB  |  用户分类: PCB  |  标签: 无标签  |  来源: 无分类  | 

点击查看原文

发表评论 阅读全文(1499) | 回复(2)

Total , Page /