OEMAddressTable只存在于X86和ARM架構(gòu)的平臺(tái)下,用來(lái)定義從4GB的虛擬地址到物理512MB存儲(chǔ)空間的靜態(tài)映射關(guān)系,它實(shí)質(zhì)是一個(gè)結(jié)構(gòu)變量。
typedef struct
{
ULONG ulVirtualAddress;
ULONG ulPhysicalAddress;
ULONG ulSizeInMegs;
} AddressTableStruct;
#define MEG(A) (((A - 1)>>20) + 1)
const AddressTableStruct OEMAddressTable[] =
{
{ SDRAM_VIRTUAL_MEMORY, //虛擬地址
PHYSICAL_ADDR_SDRAM_MAIN, //物理地址
MEG(SDRAM_MAIN_BLOCK_SIZE) //這段空間的大小,以M計(jì)
},
………………………
{
0,
0,
0
}
};
如例子所示,OEMAddressTable為一個(gè)結(jié)構(gòu)數(shù)組,每項(xiàng)的第一個(gè)成員為虛擬地址,第二個(gè)成員為對(duì)應(yīng)的物理地址,最后一個(gè)成員為該段空間的大小。這個(gè)數(shù)組的最后一項(xiàng)必須全部為0,以示整個(gè)數(shù)組的結(jié)束。內(nèi)核啟動(dòng)時(shí)會(huì)讀取這個(gè)數(shù)組的內(nèi)容以初始化MMU頁(yè)表。啟用MMU以后OS內(nèi)核段程序(如ISR)可以用這里的虛擬地址來(lái)訪問(wèn)設(shè)備。當(dāng)然,OEMAddressTable中所用到的每個(gè)物理地址及虛擬地址都需要在頭文件中定義。
比如X86的OEMAddressTable (platform\common\src\x86\common\startup\startup.asm):
_OEMAddressTable:
dd 80000000h, 0, 04000000h //格式為:虛擬地址,物理地址,大小
注意(1)這里的大小,X86下為4MB的倍數(shù),ARM下為1MB的倍數(shù)。
(2)這里的映射是靜態(tài)的cached,虛擬地址范圍是0x8000000-0x9FFFFFFF,系統(tǒng)會(huì)自動(dòng)添加uncached段的映射,從0xA000000-0xBFFFFFFF.
CONFIG.BIB文件分兩個(gè)部分,我們且稱之為段,MEMORY段和CONFIG段。MEMORY段定義虛擬內(nèi)存的分片方法,CONFIG段定義它的一些屬性。以下是一個(gè)CONFIG.BIB文件MEMORY段的例子:
來(lái)自platform\CEPC\files\config.bib:
MEMORY
; Name Start Size Type
; ------- -------- -------- ----
; 64 MB of RAM (note: AUTOSIZE will adjust boundary)
NK 80220000 009E0000 RAMIMAGE //系統(tǒng)鏡像
RAM 80C00000 03400000 RAM // 應(yīng)用程序與文件系統(tǒng)區(qū)域
DMA 80100000 00030000 RESERVED ; Native DMA reserved.
BOOTARGS 801FFF00 00000100 RESERVED ; Boot arguments
EDBG_DMA 80200000 00020000 RESERVED ; EDBG DMA buffer