OEMAddressTable只存在于X86和ARM架構(gòu)的平臺下,用來定義從4GB的虛擬地址到物理512MB存儲空間的靜態(tài)映射關(guān)系,它實(shí)質(zhì)是一個結(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為一個結(jié)構(gòu)數(shù)組,每項(xiàng)的第一個成員為虛擬地址,第二個成員為對應(yīng)的物理地址,最后一個成員為該段空間的大小。這個數(shù)組的最后一項(xiàng)必須全部為0,以示整個數(shù)組的結(jié)束。內(nèi)核啟動時會讀取這個數(shù)組的內(nèi)容以初始化MMU頁表。啟用MMU以后OS內(nèi)核段程序(如ISR)可以用這里的虛擬地址來訪問設(shè)備。當(dāng)然,OEMAddressTable中所用到的每個物理地址及虛擬地址都需要在頭文件中定義。
比如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)會自動添加uncached段的映射,從0xA000000-0xBFFFFFFF.
CONFIG.BIB文件分兩個部分,我們且稱之為段,MEMORY段和CONFIG段。MEMORY段定義虛擬內(nèi)存的分片方法,CONFIG段定義它的一些屬性。以下是一個CONFIG.BIB文件MEMORY段的例子:
來自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