| PIC16C5X硬件结构 | ||||
|
第五节 数据存储器 | ||||
|
PIC16C5X把数据存储器RAM都当作寄存器来使用以使寻址简单明洁,它们功能上可分为操作寄存器、I/O寄存器、通用寄存器和特殊功用寄存器。它们的组织结构如图1.4所示:这些寄存器用代号F0~F79来表示。F0~F4是操作寄存器,F5-F7是I /O寄存器,其余为通用寄存器。特殊功用寄存器地址对用户不透明。 ![]() §1.5.1 操作寄存器
2、F1 实时时钟/计数寄存器(RTCC) ![]() 图1.5 RTCC 方块图 上图中可看出RTCC工作状态由OPTION寄存器控制(参见§1.5.4),其中OPTION寄存器的RTS位用来选择RTCC的计数信号源,当RTS为"1"时,信号源为内部时钟,RTS为"0"时,信号源为来自RTCC引脚的外部信号。OPTION寄存器的PSA位控制预分频器(Prescaler)分配对象,当PSA位为"1",8位可编程预分配给RTCC,即外部或内部信号经过预分频器分频后再输出给RTCC。预分频器的分频比率由OPTION内的PS0~PS2决定。这时涉及写f1(RTCC)寄存器的指令均同时将预分频器清零。但要注意OPTION寄存器内容仍保持不变,即分配对象、分频比率等均不变。OPTION的RTE位用于选择外部计数脉冲触发沿。当RTE为"1"时为下降沿触发,为"0"时为上升沿触发。 ![]() 图1.6A RTCC时序图:内部时钟/无预分频器 ![]() 图1.6B RTCC时序图:内部时钟/预分频比1:2
表1.3 PC及堆栈的宽度 单片机一复位(RESET),F2的值全置为"1"。除非执行地址跳转指令,否则当执行一条指令后,F2(PC)值会动加1指向下一条指令。下面这些指令可能改变PC的值: a、"GOTO"指令。它可以直接写(改变)PC的低9位。对于PIC16C56/57/58,状态寄存器F3的PA1、PAO两位将置入PC的最高二位。所示"GOTO"指令可以跳转到程序存储器的任何地方。 b、"CALL"指令。它可以直接写PC 低8位,同时将PC的第9位清零。对于PIC16C56/57/58,状态寄存器F3的PA1、PAO两位将置入PC的最高二位(第10、11位)。 c、"RETLW"指令。它把栈项(堆栈1)的值写入PC。 d、"MOVWF F2"指令。它把W寄存器的内容置入PC。 e、"ADDWF F2"指令。它把PC值加1后再和W寄存器的值相加,结果写入PC。 在以上b、d和e中,PC的第9位总是被清为零。所以用这三条指令来产生程序跳转时,要把子程序或分支程序放在每页的上部地址(分别为000-0FF、200-2FF、400-4FF、600-6FF)。 4、F3 状态寄存器(STATUS)
在加法运算(ADDWF)时,C是进位位。在减法运算(SUBWF)时,C是借位的反(Borrow)。
![]() 表1.4列出了影响TO、PD位的事件。表1.5列出了在各种RESET后的TO、PD位状态。
判断RESET从何处引起有时是很必要的。例如在对系统初始化时,经常需判断这次复位是否是上电引起的。如果不是上电复位,则不再进行初始化。 页面选择位PA1、PA0的作用前面已描述过,RESET时清PA0-PA2位为零,所以复位后程序区页面自动选择在0页。
表1.6 寄存器体高16寄存器地址 注意:当芯片上电复位时,FSR<6:5>是不定的,所以它可能指向任何一个Bank。而其他复位则保持原来的值不变。具体程序技巧请参阅§2.7.2程序设计基础的描述。 §1.5.2 I/O 寄存器 PIC16C52/54/56/58有二个I/O口RA、RB(F5、F6),PIC16C55/57有三个I/O口RA、RB、RC(F5、F6、F7)。与其它寄存器一样,它们皆可由指令来读写。它们是可编程双向I/O口,可由程序来编程确定每一根I/O端的输入/输出状态。控制方法见§1.8节。 RESET后所有的I/O口都置成输入态(等于高阻态),即I/O控制寄存器(TRISA、TRISB、TRISC)都被置成"1"。 1、F5(A口) 4位I/O口寄存器。只能使用其低4位。高4位永远定义为"0"。 2、F6(B口) 8位I/O口寄存器。 3、F7(C口) 对于PIC16C55/PIC16C57,它是一个8位I/O口寄存器。 对于PIC16C54/56/58,它是一个通用寄存器。 §1.5.3 通用寄存器 PIC16C54/56: 07H~1FH PIC16C55: 08H~1FH PIC16C57/58: 08H-0FH:共有通用寄存器(无须体选择即可寻址)。 10H-1FH:Bank0的通用寄存器 20H-2FH:物理上等同于00H-0FH。 30H-3FH:Bank1的通用寄存器 40H-4FH:物理上等同于00H-0FH。 50H-5FH:Bank2的通用寄存器 60H-6FH:物理上等同于00H-0FH。 70H-7FH:Bank3的通用寄存器。 请参考图1.4。对寄存器体Bank的寻址请参阅F4寄存器描述和第四章的实例。 §1.5.4 特殊功能寄存器 1、工作寄存器(W) W用来存放两操作数指令中的第二个操作数,或用以进行内部数据传送。算术逻辑单元ALU把W和寄存器连接起来,ALU的运算结果通过总据总线可以送到W保存。 2、I/O控制寄存器(TRISA、TRISB、TRISC) TRISA、TRISB、TRISC分别对应I/O口A、B、C。其中TRISA只有4位,和A口对应。执行"TRIS f"指令可把W的值置入I/O控制寄存器,以此来定义各I/O端的输入/输出态。当写入"1"时,将相应的I/O端置成输入态(高阻态),当写入"0",则将相应的I/O端置成输出态。I/O控制寄存器都是只写寄存器,在RESET后自动置为全"1",即所有I/O口都为输入态。 3、预设倍数/RTCC选择寄存器(OPTION) ![]() |









