ARM寄存器地址定義
1.首先這是定義的一個(gè)變量,這一點(diǎn)要非常明白,因?yàn)閞GPBCON就是一個(gè)寄存器變量,我們可以給他賦值對(duì)他讀寫操作,這是一個(gè)變量,而不是一個(gè)指針或者地址。
2.這是一個(gè)地址固定的變量,以前分配的變量地址是隨機(jī)的,但這里的地址是固定的,就是0x56000010。
3.#define rGPBCON (*(volatile unsigned *)0x56000010)宏定義的過(guò)程,首先把0x56000010這個(gè)物理地址強(qiáng)制轉(zhuǎn)換為指針變量
(volatile unsigned *)0x56000010 這就是一個(gè)指針變量。然后再用*符號(hào)對(duì)指針變量操作相當(dāng)于*p是一個(gè)變量。其中因?yàn)檫@里是寄存器映射到內(nèi)存是虛地址,所以需要用關(guān)鍵字volatile寫回,而不是讀緩沖器中的值。
4. 關(guān)于rGPBCON這個(gè)特殊寄存器到底有沒(méi)有這樣一個(gè)寄存器?
這個(gè)我一直很迷惑,直到今天,我才明白,其實(shí)沒(méi)有這樣一個(gè)寄存器,這個(gè)寄存器是0x56000010開始的四個(gè)字節(jié)的內(nèi)存地址的別名,rGPBCON是占用內(nèi)存的,而不存在IO空間或者說(shuō)IO寄存器。因?yàn)?strong>ARM根本久沒(méi)有IO空間,直接映射到內(nèi)存空間。
標(biāo)簽: ARM寄存器地址定