寄存器TBR是如何运用的

[复制链接]
11008|13
 楼主| lium 发表于 2012-7-10 19:24 | 显示全部楼层 |阅读模式
PORT_INT_SET:
LDI TBR,0FH;????????????
STA PPBCR,07H ;PORTB 内部上拉电阻使能
LDI PORTB,0FH ;打开PORTB 内部上拉电阻
NOP ;等待稳定
NOP
NOP
LDI TBR,00H
STA PBIF,07H ;清PORTB 中断请求标志????????????
LDI TBR,0FH
STA PBIEN,07H ;PORTB 中断使能?????????????????
LDI IRQ,00H ;清中断请求标志
LDI IE,0001B ;打开PORT 中断
STOP ;进入STOP 模式
NOP ;单片机从STOP 模式被PORT 中断唤醒, PBIF 被写入了中断请求标志
NOP
想请教一下上面程序中查表寄存器TBR是如何运用的?
guoyt 发表于 2012-7-10 19:33 | 显示全部楼层
其实书上写的很清楚,你认真看会找到答案的,在第28页.

内容如下:
RTNW
指令格式        RTNW H,L
指令描述        从子程序中返回上一层程序,H参数赋值给TBR,L参数赋值给累加器A,同时将堆栈的内容弹栈
表达式        PC   ST,TBR  H,A  L
指令编码        11010 000h hhh LLLL
影响的标志位        无
RTNW指令用于从子程序中返回上一层程序,执行此条指令时,CPU首先进行现场恢复,将保存在堆栈中最顶层的PC+1值弹出,同时将该指令的操作数H赋值给TBR寄存器,将参数L赋值给累加器A。

这一指令的主要作用有两点,一点可以实现固定数据表中数据的读取,第二点是可以实现程序的散转。
           注意:执行此条指令时,弹栈的只是PC值,不包括CY。
               
                例2-4-41:读取位于$302 处的数据表中的数据
                TBR        EQU        OEH
                TEMP        EQU        20H
                        :
                        :
                001A          LDI      TBR,00H   ;put index value (high nibble) 0 into TBR.
                001B          LDI      TEMP,02   ;put index value (low nibble) 2 into AC
                001C          CALL     300H       ;call subprogram.
                001D           :
                        :
                    :
                          ORG      300H
                0300          TJMP                ; get destination address $0302H according to (PC11~PC8),TBR,AC
                0301           RTNW     00H,01H
                0302            RTNW     00H,02H    ;return to main program, HTBR,LAC
                0303            RTNW     04H,05H
                0304           RTNW     09H,08H
                0305        :
 楼主| lium 发表于 2012-7-10 19:35 | 显示全部楼层
是啊,我也注意到这一点了,可是上面程序中
STA PPBCR,07H ;PORTB 内部上拉电阻使能
直接写成LDI  PPBCR,0FH;不就行了,为什么还要用查表寄存器TBR呢?
guoyt 发表于 2012-7-10 19:37 | 显示全部楼层
这又是另外一个问题了,呵呵.
RAM也是分区的,00H~7FH为bank0,所有指令可直接操作,80H~FFH为bank1,以此类推,非bank0的寄存器有很多指令是无法直接操作的
 楼主| lium 发表于 2012-7-10 19:38 | 显示全部楼层
谢谢啊,ROM分区和RAM分区的方式不一样吗?ROM中是000-7FFH为bank0,还有就是通过LDI TBR,0FH
STA PPBCR,07H PBCR就成了0FH,中间这个过程是怎么回事?bank7中那么多地址很多啊
guoyt 发表于 2012-7-10 19:40 | 显示全部楼层
ROM也有分区,跟RAM不一样.
你举的这个例子是RAM分区的例子,不是ROM的.
 楼主| lium 发表于 2012-7-10 19:42 | 显示全部楼层
好的,谢谢啊
LDI TBR,0FH;
STA PPBCR,07H ORTB 内部上拉电阻使能;?
LDI PORTB,0FH ;打开PORTB 内部上拉电阻
问号部分,PPBCR怎么就成了0FH呢?
hanwe 发表于 2012-7-10 19:45 | 显示全部楼层
STA指令是把累加器的值赋给寄存器PPBCR,经过LDI TBR,0FH后,累加器的值为F,再使用STA指令对PPBCR赋值,所以PPBCR的值也为F.
 楼主| lium 发表于 2012-7-10 19:47 | 显示全部楼层
那直接用STA PPBCR, 00H就可以了啊,为什么要用STA PPBCR, 07H呢?
yufe 发表于 2012-7-10 20:12 | 显示全部楼层
PPBCR寄存器在RAM的BANK7内,所以用07H,或者根据不用写07H及其前面的逗号,编译器会自动处理
llia 发表于 2012-7-10 20:15 | 显示全部楼层
lz怎么不用C,就不用考虑这么多问题了
 楼主| lium 发表于 2012-7-10 20:16 | 显示全部楼层
中颖四位机只支持汇编,呵呵
llia 发表于 2012-7-10 20:19 | 显示全部楼层
哦,对啊,呵呵
 楼主| lium 发表于 2012-7-10 20:22 | 显示全部楼层
呵呵,多谢大家讨论,先结贴了
您需要登录后才可以回帖 登录 | 注册

本版积分规则

915

主题

9578

帖子

3

粉丝
快速回复 在线客服 返回列表 返回顶部