⑴ C语言中,如何定义单片机的寄存器
1.
位地址在汇编语言中,只能直接寻址,不支持间接寻址。那么,在
C
语言中,也就不能用指针来操作。所以不能定义单片机的寄存器。
2.
访问寄存器可以通过直接地址引用来完成。
例如52单片机的寄存器有4组,分别为00H-07H,08H-0FH,10H-17H,18H-1FH,各组均8字节,要结合程序状态字寄存器PSW(D0H)中的RS0,RS1的组合来确定是哪一组。
可以定义一个访问Rn的函数
typedef unsigned char uchar;
uchar dacRn(uchar n) //n=[0..7]
{
uchar data *p;
n += (PSW & 0x18); //PSW 7:CY 6:AC 5:F0 4:RS1 3:RS0 2:OV 1:F1 0:P
//本来要右移三位变为0-3,但由于是8个一组要乘以8(左移3位),所以直接加上寄存器编号就可以了
return *(uchar data *)n;
}
⑵ 单片机C语言中SBUF可以直接传递数吗
1. SBUF在单片机C语言中是一个特殊功能寄存器(SFR),它实际上代表两个物理寄存器,它们共用同一个地址。
2. 当向SBUF写入数据时,实际上是向串行输出寄存器写入数据;而从SBUF读取数据时,则是从串行输入寄存器读取数据。
3. 在写入SBUF时,需要理解这会导致串口开始发送数据,这是由输出寄存器的控制逻辑决定的。
4. 因此,在C语言中直接读写SBUF是可以的,写入的任何数据都会被串口发送。
5. 串口的具体行为还取决于串口的配置设置。
⑶ 51单片机可以通过指针访问寄存器吗
data:固定指前面0x00-0x7f的128个RAM,可以用acc直接读写的,速度最快,生成的代码也最小。
idata:固定指前面0x00-0xff的256个RAM,其中前128和data的128完全相同,只是因为访问的方式不同。idata是用类似C中的指针方式 访问的。汇编中的语句为:mox ACC,@Rx。
xdata:外部扩展RAM,一般指外部0x0000-0xffff空间,用DPTR访问。
pdata:外部扩展RAM的低256个字节,地址出现在A0-A7的上时读写,用movx ACC,@Rx读写。这个比较特殊,对于C51来说好象有BUG, 建议少用。
code:访问程序存储器(默认仅限于标准51能够寻址的64kB空间内),生成的代码主要通过 MOVC@A+DPTR实现。
far:far是Keil 编译器为了支持新出现的8051家族增强型MCU,这些增强型MCU可能拥有大于64KB的存储器。使用far可访问扩展的RAM,使用**const far可访问扩展的ROM**。NXP 51MX架构51单片机提供通过通用指针访问多达8MB的code和xdata存储空间。Dallas 390架构的51单片机通过24位的DPTR寄存器结合传统MOVX 、MOVC指令来访问扩展的RAM和ROM。