第五节:PIC系列单片机数据存储器

发布者:JoyfulSunflower最新更新时间:2017-12-04 来源: eefocus关键字:PIC系列  单片机  数据存储器 手机看文章 扫描二维码
随时随地手机看文章

PIC16C5X把数据存储器RAM都当作寄存器来使用以使寻址简单明洁,它们功能上可分为操作寄存器、I/O寄存器、通用寄存器和特殊功用寄存器。它们的组织结构如图1.4所示:这些寄存器用代号F0~F79来表示。F0~F4是操作寄存器,F5-F7是I /O寄存器,其余为通用寄存器。特殊功用寄存器地址对用户不透明。

§1.5.1 操作寄存器

1、F0 间址寄存器

    寻址F0实际上意味着间址寻址。实际地址为寄存器选择寄存器F4的内容。

例: MOVLW 10 
MOVWF  f4    ;10→f4
MOVLW  55 
MOVWF  f0    ;55→f10

2、F1 实时时钟/计数寄存器(RTCC

    此寄存器是一个8位计数器。和其他寄存器一样可由程序进行读写操作。它用于对外加在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"时为上升沿触发。

    RTCC计数器采用递增方式计数,当计数至FFH时,在下一个计数发生后,将自动复零,重新开始计数,以此一直循环下去。RTCC对其输入脉冲信号的响应延迟时间为2个机器周期,不论输入脉冲是内部时钟、外部信号或是预分频器的输出。响应时序见图1.6。

    RTCC对外部信号的采样周期为2个振荡周期。因此当不用预分频器时,外加在RTCC引脚上的脉冲宽度不得小于2个振荡周期,即1/2指令周期。同理,当使用预分频器时,预分频器的输出脉冲周期不得小于指令周期,因此预分频器最大输入频率可达N.fosc/4,N为预分频器的分频比,但不得大于50MHz

    当RTCC使用内部时钟信号时,如果没有预分频器,则RTCC值随指令节拍增1。 当一个值写入RTCC时,接下来的二个指令节拍RTCC的值不会改变,从第三个指令节拍才开始递增,见下图。

    应注意的是尽管PIC对外部加于RTCC信号端上的信号宽度没有很严格的要求,但是如果高电平或低电平的维持时间太短,也有可能使RTCC检测不到这个信号。一般要求信号宽度要大于是10nS。

3、F2 程序计数器(PC)

    程序计数器PC可寻址最多2K的程序存储器。表1.3列出了PIC16C5X各种型号的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)

    如图1.7所示F3包含了ALU的算术状态、RESET状态、程序存储器页面地址等。F3中除PD和TO两位外,其他的位都可由指令来设置或清零。注意,当你执行一条欲改变F3 寄存器的指令后,F3中的情况可能出乎你的意料。

    例:CLRF F3 ;清F3为零

    你得到的结果是F3=000UU100(U为未变)而不是想像中的全零。UU两位是PD和TO,它们维持不变,而2位由于清零操作被置成"1"。所以如果你要想改变F3的内容,建议你使用BCF、BSF和MOVWF这三条指令,因为它们的执行不影响其他状态位。

例:MOVLW 0  ;0→W
    MOVWF F3 ;把F3除PD和TO以外的位全部清零,则你可得到F3=000UU000。

    有关各条指令对状态位的影响请看第二章介绍。
    在加法运算(ADDWF)时,C是进位位。在减法运算(SUBWF)时,C是借位的反(Borrow)。

例:CLRF F10 ;F10=0
MOVLW 1 ;1→W
SUBWF F10 ;F10-W=0-1=FFH→F10
C=0:运算结果为负
例:MOVLW 1 ;1→W
MOVWF F10 ;F10=1
CLRW ;W=0
SUBWF F10 ;F10-W=1-0=1→F10
C=1:运算结果为正

    PD和TO两位可用来判断RESET的原因。例如判断RESET是由芯片上电引起的,或是由看门狗WDT计时溢出引起的,或是复位端加低电平引起的,或是由WDT唤醒SLEEP引起的。
表1.4列出了影响TO、PD位的事件。表1.5列出了在各种RESET后的TO、PD位状态。

    判断RESET从何处引起有时是很必要的。例如在对系统初始化时,经常需判断这次复位是否是上电引起的。如果不是上电复位,则不再进行初始化。
页面选择位PA1、PA0的作用前面已描述过,RESET时清PA0-PA2位为零,所以复位后程序区页面自动选择在0页。

5、F4 寄存器选择寄存器(FSR)
a、 PIC16C52/54/55/56
    F4的0-4位在间接寻址中用来选择32个数据寄存器。5-7位为只读位,并恒为1。请参考F0寄存器描述。
b、PIC16C57/58
    FSR<6:5>位用来选择当前数据寄存器体(Bank)。PIC16C57有80个数据寄存器,如图1.4所示。80个寄存器分为4个体(Bank0~Bank3),每个体的低16个寄存器的物理位置是相同的(参考§1.5.3通用寄存器的描述)。当FSR的第4位为"1"时,则要根据FSR<6:5>位来选择某个寄存器体中的某一个高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)

OPTION可用于:
    a、定义预分频器的预分频参数。
    b、分配预分频器(Prescaler)给RTCC或WDT。注意预分频器只能分配给RTCC或WDT其中之一使用,不能同时分配。
    c、定义RTCC的信号源。
    d、定义RTCC信号源的触发沿(上升沿触发或下降沿触发)。

图1.8显示了OPTION各位的意义。
    当预分频器分配给RTCC后,所有写RTCC寄存器的指令如CLRF 1、MOVWF 1等都会清除预分频器。同理,分配给WDT时,诸如CLRWDT和SLEEP指令将清除预分频器里已有的值使其归零。
通过执行"OPTION"指令可将W值置入OPTIOW寄存器,RESET后OPTION被置成全"1"。

例:MOVLW 07H ;W=7
OPTION ;7→OPTION ;预分频器(1:256)分配给RTCC。RTCC信号源为内 部指令时钟周期。


关键字:PIC系列  单片机  数据存储器 引用地址:第五节:PIC系列单片机数据存储器

上一篇:第七节:PIC系列单片机看门狗WDT
下一篇:第四节:PIC系列单片机程序存储器及堆栈

推荐阅读最新更新时间:2024-03-16 15:48

PIC单片机之定时器(TMR0)
什么是定时器? 定时器顾名思义就是用来定时的。在单片机应用中常常用于各种各样的定时。比如让LED灯每隔 1S 亮一次。 这个1S 就是由定时器做到的。 指令周期 指令周期就是单片机执行一个指令所花费的时间。这也是定时器定时的最小时间单位。时钟频率/4=指令频率。1/指令频率=指令周期。 假设现在的时钟是4MHZ ,4MHz的时钟经过4分频后变成了 1MHz 其周期为0.0000001s也就是1us,这个1us就是指令周期,这1us也就是定时器定时的最小单位。 定时器与预分频器 假设在没有预分频器情况下。开启定时器 每隔一个指令周期定时器就加一。假设时钟是4MHz 也就是每隔 1us 定时器加一。 如果有
[单片机]
<font color='red'>PIC</font><font color='red'>单片机</font>之定时器(TMR0)
TI - MCU - MSP430使用指南3 -> SYS系统控制
MSP430 MCU的内部系统控制主要包括以下几块: 上电及复位控制 中断管理 MCU运行模式 TLV数据 对于MSP430的系统控制吧,如果仅仅是站在应用层的角度来说,可以不用太怎么了解,毕竟使用起来的话,SYS模块的的寄存器直接默认就好啦,不会有什么问题,基本都是存在比较深的解决不了的问题时才会牵扯到这一块的内容,因此我的讲解也比较有限,主要说一些关键的内容吧(主要是 我了解的也不是特别深。。。。)。下面开始进入我们今天的分享: 上电及复位管理 BOR:Brownout Reset,也就是掉电复位。 POR:Power on Reset,上电复位。 PUC:Power up Clear,通电清除 这三个有什
[单片机]
TI - <font color='red'>MCU</font> - MSP430使用指南3 -> SYS系统控制
【51单片机快速入门指南】9:省电模式(低功耗)
普中51-单核-A2 STC89C52 Keil uVision V5.29.0.0 PK51 Prof.Developers Kit Version:9.60.0.0 硬知识 摘自《STC89C52系列单片机器件手册》 仅支持掉电模式,不支持空闲模式 STC89C52系列单片机可以运行2种省电模式以降低功耗,它们分别是:空闲模式和掉电模 式。正常工作模式下,STC89C52系列单片机的典型功耗是4mA ~ 7mA,而掉电模式下的典型功耗是 0.1uA,空闲模式(建议不要使用此模式)下的典型功耗是2mA. 空闲模式和掉电模式的进入由电源控制寄存器PCON的相应位控制。PCON寄存器定义如下:
[单片机]
【51<font color='red'>单片机</font>快速入门指南】9:省电模式(低功耗)
单片机与键盘接口图及键盘消息处理程序
单片机与键盘接口图 内容来自单片机之家www.dpj100.com 采用中断方式:如图所示。各个按钮都接到一个与非上,当有任何一个按钮按下时,都会使与门输出为低电平,从而引起单片机的中断,它的好处是不用在主程序中持续地循环查询,如果有键按下,单片机再去做对应的处理 在单片机系统中键盘中按钮数量较多时,为了减少I/O口的占用,常常将按钮排列成矩阵形式,如图1所示。在矩阵式键盘中,每条水平线和垂直线在交叉处不直接连通,而是通过一个按钮加以连接。这样,一个端口(如P1口)就能组成4*4=16个按钮,比之直接将端口线用于键盘多出了一倍,而且线数越多,区别越明显,比如再多加一条线就能组成20键的键盘,而直接用端口线则只能多出一键(9键
[单片机]
<font color='red'>单片机</font>与键盘接口图及键盘消息处理程序
意法半导体开始提供基于ePCM的微控制器样片
现在开始提供创新的汽车MCU嵌入式相变存储器(ePCM)样片 在IEDM 2018展会上公布初步基准性能数据 将支持汽车系统对更快和更复杂的计算能力的需求 横跨多重电子应用领域的全球领先的半导体供应商 意法半导体 (STMicroelectronics,简称ST;纽约证券交易所代码 :STM) 在IEDM2018国际电子器件展会上,公布了内置嵌入式相变存储器(ePCM)的28nm FD-SOI汽车微控制器(MCU)技术的架构和性能基准,并从现在开始向主要客户提供基于ePCM的微控制器样片,预计2020年按照汽车应用要求完成现场试验,取得全部技术认证。这些微控制器是世界上首批使用ePCM的微控制器,将被用于汽车传动系
[汽车电子]
38-基于51单片机的简单风扇控制
具体实现功能 系统由STC89C52单片机+单体数码管+LED指示灯+LM298N芯片芯片+直流电机构成。 具体功能: (1)模拟实现风扇的转动及摇头; (2)实现按键设置1 档强风,2档中风,3档弱风,并用数码管显示; (3)实现按键控制摇头与停止摇头。 设计背景 本设计以直流电机控制为基础,基于传感器技术,以单片机控制技术为核心,实现电风扇的智能控制,同时设计采用轻触开关即可具有电风扇的调档功能。使用集成电路LM298N完成电风扇的驱动设计,通过单片机STC89C52的定时器0以及定时器1产生不同占空比的PWM波形控制电风扇电机驱动芯片从而改变电风扇电机的输入电流,最终实现电风扇电机转速调节功能,使得设计更
[单片机]
38-基于51<font color='red'>单片机</font>的简单风扇控制
单片机学习——独立按键之三
题目:按下16个矩阵键盘依次在数码管上显示1-16的平方。如按下第一个显示1,第二个显示4... 解决方案:(C语言编程) #include reg52.h #include intrins.h #define uint unsigned int #define uchar unsigned char uchar bai,shi,ge,num,temp; uint shu; sbit le=P3^6; void delay(uint a); void dis(); void display(uchar ba,uchar sh,uchar g); uchar code tabledu ={0xc0,0xf9,0xa4,0xb0,0
[单片机]
51单片机控制步进电机-让电机转起来
摘要: 本节介绍用简单的方式,让步进电机转起来。其目的之一是对电机转动有直观的感受,二是熟悉整个开发流程 本系列教程必要的51单片机基础包括IO口操作、中断、定时器三个部分,相关基础教程网上很多,可以自行学习 一、软件清单 需要用到的软件有keil5编译软件、STC程序烧录软件 二、控制原理 根据TB6600驱动器原理,向PUL口发送脉冲,每发送一个脉冲,电机就转一步。通过单片机延时的方式,切换PUL口电平产生脉冲,从而控制电机转动。 三、程序代码 //毫秒延时函数 void delay(unsigned int z) { unsigned int x,y; for(x=z;x 0;x--) for(y
[单片机]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved