打印

寄存器TBR是如何运用的

[复制链接]
10149|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的寄存器有很多指令是无法直接操作的

使用特权

评论回复
5
lium|  楼主 | 2012-7-10 19:38 | 只看该作者
谢谢啊,ROM分区和RAM分区的方式不一样吗?ROM中是000-7FFH为bank0,还有就是通过LDI TBR,0FH
STA PPBCR,07H PBCR就成了0FH,中间这个过程是怎么回事?bank7中那么多地址很多啊

使用特权

评论回复
6
guoyt| | 2012-7-10 19:40 | 只看该作者
ROM也有分区,跟RAM不一样.
你举的这个例子是RAM分区的例子,不是ROM的.

使用特权

评论回复
7
lium|  楼主 | 2012-7-10 19:42 | 只看该作者
好的,谢谢啊
LDI TBR,0FH;
STA PPBCR,07H ORTB 内部上拉电阻使能;?
LDI PORTB,0FH ;打开PORTB 内部上拉电阻
问号部分,PPBCR怎么就成了0FH呢?

使用特权

评论回复
8
hanwe| | 2012-7-10 19:45 | 只看该作者
STA指令是把累加器的值赋给寄存器PPBCR,经过LDI TBR,0FH后,累加器的值为F,再使用STA指令对PPBCR赋值,所以PPBCR的值也为F.

使用特权

评论回复
9
lium|  楼主 | 2012-7-10 19:47 | 只看该作者
那直接用STA PPBCR, 00H就可以了啊,为什么要用STA PPBCR, 07H呢?

使用特权

评论回复
10
yufe| | 2012-7-10 20:12 | 只看该作者
PPBCR寄存器在RAM的BANK7内,所以用07H,或者根据不用写07H及其前面的逗号,编译器会自动处理

使用特权

评论回复
11
llia| | 2012-7-10 20:15 | 只看该作者
lz怎么不用C,就不用考虑这么多问题了

使用特权

评论回复
12
lium|  楼主 | 2012-7-10 20:16 | 只看该作者
中颖四位机只支持汇编,呵呵

使用特权

评论回复
13
llia| | 2012-7-10 20:19 | 只看该作者
哦,对啊,呵呵

使用特权

评论回复
14
lium|  楼主 | 2012-7-10 20:22 | 只看该作者
呵呵,多谢大家讨论,先结贴了

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

915

主题

9579

帖子

3

粉丝