打印

TBR是如何运用的

[复制链接]
2322|13
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
langgq|  楼主 | 2011-3-25 22:23 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
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是如何运用的?
沙发
wangzsa| | 2011-3-25 22:28 | 只看该作者
其实书上写的很清楚,你认真看会找到答案的,在第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        :

使用特权

评论回复
板凳
langgq|  楼主 | 2011-3-25 22:37 | 只看该作者
是啊,我也注意到这一点了,可是上面程序中
STA PPBCR,07H ;PORTB 内部上拉电阻使能
直接写成LDI  PPBCR,0FH;不就行了,为什么还要用查表寄存器TBR呢?

使用特权

评论回复
地板
wangzsa| | 2011-3-25 22:51 | 只看该作者
这又是另外一个问题了,呵呵.
RAM也是分区的,00H~7FH为bank0,所有指令可直接操作,80H~FFH为bank1,以此类推,非bank0的寄存器有很多指令是无法直接操作的

使用特权

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

使用特权

评论回复
6
kui606| | 2011-3-25 23:16 | 只看该作者
比较复杂啊

使用特权

评论回复
7
wangzsa| | 2011-3-25 23:16 | 只看该作者
ROM也有分区,跟RAM不一样.
你举的这个例子是RAM分区的例子,不是ROM的.

使用特权

评论回复
8
langgq|  楼主 | 2011-3-26 15:23 | 只看该作者
好的,谢谢啊
LDI TBR,0FH;
STA PPBCR,07H ORTB 内部上拉电阻使能;?
LDI PORTB,0FH ;打开PORTB 内部上拉电阻
问号部分,PPBCR怎么就成了0FH呢?

使用特权

评论回复
9
yufe| | 2011-3-26 15:27 | 只看该作者
STA指令是把累加器的值赋给寄存器PPBCR,经过LDI TBR,0FH后,累加器的值为F,再使用STA指令对PPBCR赋值,所以PPBCR的值也为F.

使用特权

评论回复
10
langgq|  楼主 | 2011-3-26 15:38 | 只看该作者
那直接用STA PPBCR, 00H就可以了啊,为什么要用STA PPBCR, 07H呢?

使用特权

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

使用特权

评论回复
12
langgq|  楼主 | 2011-3-26 16:06 | 只看该作者
我还是感觉疑惑如果不写连07H都不写的话他怎么就知道把0FH给PPBCR呢,
难道系统早就定义好了吗?!

使用特权

评论回复
13
yufe| | 2011-3-26 16:17 | 只看该作者
定义寄存器的时候会定义它的地址,编译的时候编译器会自动处理。

使用特权

评论回复
14
langgq|  楼主 | 2011-3-26 16:30 | 只看该作者
OK,解决了

使用特权

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

本版积分规则

932

主题

8762

帖子

1

粉丝