地址轉換-51單片機C編程
比如,在頭文件reg51.h中,定義了 sfr P0 = 0x80,該地址標識的是51芯片的P0端口的8個(gè)引腳。(一個(gè)字節)。
同時(shí)reg51.h中還定義了 sfr SP = 0x81。
如果自己定義 sbit TEST1 = 0x81;實(shí)驗時(shí)會(huì )發(fā)現:TEST1實(shí)際表示的是0x80標識的8bits中的第二個(gè)bit位,表示成0x80.1。
按照一般的理解:TEST1應該是地址0x81對應的8bit的第一個(gè)bit位(0x81.0),但是事實(shí)不是這樣的;
如果定義 sbit TEST4 = 0x84,表示的是0x80.4;
sbit TEST7 = 0x87,表示的是0x80.7。
但是當末尾大于7后,比如 sbit TEST8 = 0x88,表示的是0x88.0, 而不是0x81.0;
sbit TEST9 = 0x89;表示的是0x88.1; 依次類(lèi)推到0x8f表示0x88.7。
開(kāi)始是用實(shí)驗板上的LED來(lái)檢查,后來(lái)在uVision里面軟調試,看Parallel Port0??碝emory是沒(méi)用的,特殊功能寄存器的地址和內存空間地址是兩個(gè)東西;后來(lái)看Symbols,終于把sbit定義的控制位的實(shí)際地址看清楚,但是沒(méi)想明白,為甚么是這樣,規律是怎樣的。
查了一下資料,原來(lái)特殊功能寄存器中不是所有字節都可進(jìn)行位尋址,支持位尋址字節地址的是:
0x80,0x88,0x90, 0x98, 0xA0, 0xA0, 0xA8, 0xB0, 0xB8, 0xC0, 0xC8, 0xD0, 0xD8, 0xE0, 0xE8, 0xF0, 0xF8
共16個(gè),這些地址不連是續,能被8整除, 即字節地址是以8或0為尾數的。
評論