寄存器操作方法_对寄存器操作的通用方法总结.doc

上传人:白大夫 文档编号:3432805 上传时间:2019-08-25 格式:DOC 页数:6 大小:29.50KB
返回 下载 相关 举报
寄存器操作方法_对寄存器操作的通用方法总结.doc_第1页
第1页 / 共6页
亲,该文档总共6页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《寄存器操作方法_对寄存器操作的通用方法总结.doc》由会员分享,可在线阅读,更多相关《寄存器操作方法_对寄存器操作的通用方法总结.doc(6页珍藏版)》请在三一文库上搜索。

1、寄存器操作方法_对寄存器操作的通用方法总结寄存器,是集成电路中非常重要的一种存储单元,通常由触发器组成。在集成电路设计中,寄存器可分为电路内部使用的寄存器和充当内外部接口的寄存器这两类。内部寄存器不能被外部电路或软件访问,只是为内部电路的实现存储功能或满足电路的时序要求。而接口寄存器可以同时被内部电路和外部电路或软件访问,CPU中的寄存器就是其中一种,作为软硬件的接口,为广泛的通用编程用户所熟知。本文主要详解寄存器操作方法以及对寄存器操作的通用方法总结,具体的跟随小编来了解一下。一、寄存器操作1、#define方法1)寄存器地址的定义:#define UART_BASE_ADRS (0x100

2、00000) /* 串口的基地址 */#define UART_RHR *(volatile unsigned char *)(UART_BASE_ADRS + 0) /* 数据接受寄存器 */#define UART_THR *(volatile unsigned char *)(UART_BASE_ADRS + 0) /* 数据发送寄存器 */2)寄存器读写操作:UART_THR = ch; /* 发送数据 */ch = UART_RHR; /* 接收数据 */也可采用定义带参数宏实现#define WRITE_REG(addr, ch) *(volatile unsigned char

3、*)(addr) = ch#define READ_REG(addr, ch) ch = *(volatile unsigned char *)(addr)3)对寄存器相应位的操作方法:定义寄存器#define UART_LCR *(volatile unsigned char *)(UART_BASE_ADRS + 3) /* 线控制寄存器 */定义寄存器相应位的值#define CHAR_LEN_5 0x00#define CHAR_LEN_6 0x01#define CHAR_LEN_7 0x02#define CHAR_LEN_8 0x03 /* 8 data bit */#defin

4、e LCR_STB 0x04 /* Stop bit control */#define ONE_STOP 0x00 /* One stop bit! */#define LCR_PEN 0x08 /* Parity Enable */#define PARITY_NONE 0x00#define LCR_EPS 0x10 /* Even Parity Select */#define LCR_SP 0x20 /* Force Parity */#define LCR_SBRK 0x40 /* Start Break */#define LCR_DLAB 0x80 /* Divisor Lat

5、ch Access Bit */定义寄存器相应位的值另一种方法#define CHAR_LEN_5 00#define CHAR_LEN_6 10#define CHAR_LEN_7 11#define CHAR_LEN_8 (10)|(11) /* 8 data bit */#define LCR_STB 12 /* Stop bit control */#define ONE_STOP 02 /* One stop bit! */#define LCR_PEN 13 /* Parity Enable */#define PARITY_NONE 03#define LCR_EPS 14 /*

6、 Even Parity Select */#define LCR_SP 15 /* Force Parity */#define LCR_SBRK 16 /* Start Break */#define LCR_DLAB 17 /* Divisor Latch Access Bit */对寄存器操作只需对相应位或赋值UART_LCR = CHAR_LEN_8 | ONE_STOP | PARITY_NONE; /* 设置 8位数据位,1位停止位,无校验位 */4)对寄存器某一位置位与清零对某一寄存器第7位置位XX_CRTL |= 17;XX_CRTL UART_LCR |= LCR_DLAB

7、; /* 时钟分频器锁存使能 */UART_LCR /* 禁止时钟分频器锁存 */5 判断寄存器某一位是否置位或为0的方法#define UART_LSR *(volatile unsigned char *)(UART_BASE_ADRS + 5) /* 线状态寄存器 */#define LSR_DR 10 /* Data Ready */当UART_LSR的第0位为1时结束循环while (!(UART_LSR 2、共用体结构体位域的应用实例【例】设count 是一个16 位的无符号整型计数器,最大计数为十六进制0xffff,要求将这个计数值以十六进制半字节的形式分解出来。对于上述实例通常

8、采用移位的方法求解,而采用共用体结构体位域的方法不需要通过移位运算。以下,对CCS 在头文件中大量使用的共用体结构体位域进行注解。先定义一个共用体结构体位域:Uint16 cont,g,s,b,q; /16 位无符号整型变量定义cont=0xfedc; /对cont 赋值union /共用体类型定义 Uint16 i; /定义i 为16 位无符号整型变量struct /结构体类型定义Uint16 low:4; /最低4 位在前。从最低4 位开始,取每4 位构成半字节Uint16 mid0:4;Uint16 mid1:4;Uint16 high:4; /最高4 位在后HalfByte; /Hal

9、fByte 为具有所定义的结构体类型的变量Count; /Count为具有所定义的共用体类型的变量union 定义一个共用体类型,它包含两个成员:一个是16 位无符号整型变量i,另一个是包含4 个半字节变量(low,mid0,mid1,high)的结构体类型。它们占用同一个内存单元,通过对i(Count.i)进行赋值,可以完成对结构体4 个变量的赋值。上面的程序,在定义共用体类型和结构体类型的同时,直接完成了这两个类型变量的定义,而未定义共用体和结构体类型名。即HalfByte 是一个具有所定义的结构体类型的变量,Count 是一个具有所定义的共用体类型的变量。理解了共用体与结构体之间的关系,

10、下面的赋值指令就清楚了。Count.i = cont; /对共用体类型成员i 进行赋值g = Count.HalfByte.low; /将cont 的03 位赋值给g,g=0x000cs = Count.HalfByte.mid0; /将cont 的47 位赋值给s,s=0x000db = Count.HalfByte.mid1; /将cont 的811 位赋值给b,b=0x000eq = Count.HalfByte.high; /将cont 的1215 位赋值给q,q=0x000f通过共用体结构体定义,当对共用体类型成员i 进行赋值时,由于结构体类型变量HalfByte 与i 占用同一个内

11、存单元,因此,也就完成了对HalfByte 的各成员的赋值。C 语言的共用体结构体位域定义,可以完成对寄存器位域的访问。至于被访问的位域在内存中的具体位置则由编译器安排,编程者可以不必关注。下面是一个访问寄存器位域的例子,供读者参考。先建立一个共用体结构体位域定义,将某个寄存器的16 位,从最低位到最高位分别定义为Bit1,Bit2,Bit16。union /共用体类型定义 Uint16 all; /定义all 为16 位无符号整型变量struct /结构体类型定义Uint16 Bit1:1; /0 位Bit1 取寄存器最低位0 位,以下顺序取1 位直到最高位Uint16 Bit2:1; /1

12、Uint16 Bit3:1; /2Uint16 Bit4:1; /3Uint16 Bit5:1; /4Uint16 Bit6:1; /5Uint16 Bit7:1; /6Uint16 Bit8:1; /7Uint16 Bit9:1; /8Uint16 Bit10:1; /9Uint16 Bit11:1; /10Uint16 Bit12:1; /11Uint16 Bit13:1; /12Uint16 Bit14:1; /13Uint16 Bit15:1; /14Uint16 Bit16:1; /15bit; /bit为具有所定义的结构体类型的变量CtrlBit; /CtrlBit 为具有所定义的

13、共用体类型的变量有了上面的定义之后,要访问某一个位或某些位就很容易了。比如要置Bit4,Bit8,Bit12 及Bit16 为1,可用两种方法进行:方法一:CtrlBit.bit.Bit4 = 1;CtrlBit.bit.Bit8 = 1;CtrlBit.bit.Bit12 = 1;CtrlBit.bit.Bit16 = 1;二、对寄存器操作的通用方法总结对寄存器的操作有时候要考虑对其不同的位进行先后顺序不同的设置,但是对寄存器操作的方法是固定的。首先要明白逻辑运算符(!,(2)将寄存器REG的第5位清“0”: REG (3)将寄存器REG的第3和第5位置“1”:REG |= (1 5) | (1 3);(4)将寄存器REG的第3和第5位清“0”:REG 该段总结如下:将某位置1,移位后使用位运算“|” ;将某位清0,移位取反后,使用位运算“ (即给寄存器REG1赋值为1010 1110,这种方法多在初始化中使用)(2)分别将寄存器REG的1、3、5、7位置“1”;0、2位清“0”u8 temp;temp = REG;temp |= (1 1); /将第1位置“1”temp |= (1 3);temp |= (1 5);temp |= (1 7);temp /将第0位清“0”,等价于temp /将第2位清“0”REG = temp;

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 其他


经营许可证编号:宁ICP备18001539号-1