青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

創(chuàng)新無極限

Sun Guoqing的Blog

C++博客 首頁 新隨筆 聯(lián)系 聚合 管理
  3 Posts :: 1 Stories :: 11 Comments :: 0 Trackbacks
WINCE的內(nèi)存(包括SDRAM及FLASH)的配置包含兩個方面:源代碼(包括C和匯編)中的定義,及系統(tǒng)配置文件CONFIG.BIB中的定義。源 代碼中需要定義內(nèi)存的物理及虛擬地址,大小,并初始化名為OEMAddressTable的結(jié)構(gòu)數(shù)組,以告知系統(tǒng)物理地址與虛擬地址的對應(yīng)關(guān)系,系統(tǒng)根據(jù) 其設(shè)置生成MMU頁表。而CONFIG.BIB中一般會將內(nèi)存定義成不同的段,各段用作不同的用途。

CONFIG.BIB文件
CONFIG.BIB文件分兩個部分,我們且稱之為段,MEMORY段和CONFIG段。MEMORY段定義內(nèi)存的分片方法,CONFIG段定義系統(tǒng)其它的一些屬性。以下是一個CONFIG。BIB文件MEMORY段的例子:
MEMORY
; 名稱 起始地址 大小 屬性
RESERVED 80000000 00008000 RESERVED
DRV_GLB 80008000 00001000 RESERVED
CS8900 80010000 00030000 RESERVED
EDBG 80040000 00080000 RESERVED
NK 800C0000 00740000 RAMIMAGE
RAM 81000000 00800000 RAM

名 稱原則上可以取任意字符串,ROMIMAGE通過一個內(nèi)存片的屬性來判斷它的用途。RESERVE屬性表明該片內(nèi)存是BSP自己使用的,系統(tǒng)不必關(guān)心其用 途;RAMIMAGE說明它是一片存放OS IMAGE的內(nèi)存;而RAM則表示些片內(nèi)存為RAM,系統(tǒng)可以在其中分配空間,運行程序。
但存放 ROM的這片內(nèi)存的名稱,即NK一般不要改動。因為BIB文件中定義將一個文件加入到哪個ROM片(WINCE支持將ROM IMAGE存放在不連續(xù)的幾 個內(nèi)存片中)中時會用到這個名稱,如下現(xiàn)這行BIB文件項就定義將touch.dll放在名稱為NK這片ROM中,
touch.dll $(_FLATRELEASEDIR)\touch.dll NK SH
因而,如果將NK改為其它名稱,則系統(tǒng)中所有的BIB文件中的這個NK串都需要改動。
注 意:保證各片內(nèi)存不要重疊;而且中間不要留空洞,以節(jié)約內(nèi)存;兩種設(shè)備如果不能同時被加載,就應(yīng)該只為其保留一片從而節(jié)約內(nèi)存,例如,本例中的 CS8950是為網(wǎng)卡驅(qū)動程序保留的,EDBG是為網(wǎng)卡作調(diào)試(KITL)用時保留的,而系統(tǒng)設(shè)計成這兩個程序不會同時加載(CS8950在啟動時判斷如 果EDBG在運行就會自動退出),這樣為這兩個驅(qū)動程序各保留一片內(nèi)存實在浪費而且也沒有必要。
RAM片必須在物理上是連續(xù)的,如果系統(tǒng)的物理內(nèi) 存被分成了幾片,則在RAM片只能聲明一片,其它的內(nèi)存在啟動階段由OEMGetExtensionDRAM報告給系統(tǒng),如果有多于一個的內(nèi)存片,應(yīng)該用 OEMEnumExtensionDRAM報告。NK片則沒有此限制,只是NK跨越兩個以上物理內(nèi)存片時,系統(tǒng)啟動時會顯示這個OS包跨越了多個物理內(nèi)存 片,認(rèn)為是個錯誤,但并不影響系統(tǒng)的執(zhí)行與穩(wěn)定性,因為系統(tǒng)啟動之時便會打開MMU而使用虛擬地址,從而看到連續(xù)的內(nèi)存空間。當(dāng)然,如果內(nèi)核自己都被放在 了兩個內(nèi)存片上,那系統(tǒng)應(yīng)該就無法啟動了。而其它保留起來的內(nèi)存片是一般是給驅(qū)動程序DMA用,應(yīng)該保證它們在物理上的連續(xù)性,因為DMA是直接用物理地 址的。
CONFIG段中以下幾個需要格外注意:
ROMSTART,它定義ROM的起始位置,應(yīng)該和NK片的起始位置相同。
ROMSIZE,定義ROM的大小,應(yīng)該和NK片的大小相同。
如果不需要NK。BIN文件,則可以不設(shè)這兩個值。
ROMWIDTH,它只是定義ROMIMAG生成ROM包時如何組織文件,而非其字面含義:ROM的寬度,所以一般都應(yīng)該為32
COMPRESSION,一般定義為ON,以打開壓縮功能,從而減小BIN文件的尺寸。
AUTOSIZE,一般應(yīng)該設(shè)為ON,以使系統(tǒng)將定義給ROM但沒有用掉的內(nèi)存當(dāng)做RAM使用,而提高RAM的使用率。注意,如果ROM是FLASH,則不能設(shè)為ON,因為FLASH不能當(dāng)作RAM使用。
ROMOFFSET,它定義OS起始位置(即ROMSTART)的物理地址和虛擬地址的差值,有些BSP中并沒有使用這個定義。
OEMAddressTable及其它
OEMAddressTable用來初始化系統(tǒng)中各種設(shè)備的虛擬地址與物理地址的對映關(guān)系。在我使用的BSP中,它是這樣定義并初始化的:
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計
},
………………………
{
0,
0,
0
}
};
如 例子所示,OEMAddressTable為一個結(jié)構(gòu)數(shù)組,每項的第一個成員為虛擬地址,第二個成員為對應(yīng)的物理地址,最后一個成員為該段空間的大小。這 個數(shù)組的最后一項必須全部為0,以示整個數(shù)組的結(jié)束。內(nèi)核啟動時會讀取這個數(shù)組的內(nèi)容以初始化MMU頁表,啟用MMU,從爾使程序可以用虛擬地址來訪問設(shè) 備。當(dāng)然,OEMAddressTable中所用到的每個物理地址及虛擬地址都需要在頭文件中定義,每個BSP中定義這些值的文件不盡相同,所以,在此不 能說明具體在哪個文件,讀者朋友可以參考具體BSP的文檔及代碼。

不連續(xù)內(nèi)存的處理
如果內(nèi)存在物理上是連續(xù)的,則 OEMAddressTable中只需要一項就可以完成對內(nèi)存的地址映射。但如果BSP運行在SDRAM物理上不連續(xù)的系統(tǒng)上時, OEMAddressTable中需要更多的項來將SDRAM映射到連續(xù)的虛擬地址上,當(dāng)然也可以將它們映射到不連續(xù)的虛擬地址上,但似乎沒有理由那么 做。而且,當(dāng)其物理地址不連續(xù)時系統(tǒng)需要做更多的工作。例如,我有這樣一個系統(tǒng):32M SDRAM,16M FLASH,SDRAM在物理上不連續(xù),被分成了4個8M的內(nèi)存塊,我的SDRAM的使用情況如下圖所示:



CONFIG。BIB文件的MEMORY段如下所示:
MEMORY
RESERVED 80000000 00008000 RESERVED
DRV_GLB 80008000 00001000 RESERVED
CS8900 80010000 00030000 RESERVED
EDBG 80040000 00080000 RESERVED
NK 800C0000 00940000 RAMIMAGE
RAM 81800000 00800000 RAM

在 這32M的空間中,BSP保留了前0x80000字節(jié),接下來是NK,它占用了0x940000字節(jié),而且它跨越了兩個內(nèi)存片,這些和其它BSP的設(shè)置都 沒有多大差別,接下來看RAM片,它只占用了最后的8M空間,前面說過,在這種物理內(nèi)存不連續(xù)的系統(tǒng)中,RAM片不能跨越兩個物理內(nèi)存塊,所以它被設(shè)計成 只占用該系統(tǒng)中的最后一個物理內(nèi)存片,而其它兩片則由OEMEnumExtensionDRAM在運行時刻報告給系統(tǒng),該函數(shù)的內(nèi)容如下:

pMemSections[0].dwFlags=0;
pMemSections[0].dwStart=(SDRAM_VIRTUAL_MEMORY + 0x1000000);
pMemSections[0].dwLen=0x800000;

pMemSections[1].dwFlags=0;
pMemSections[1].dwStart=(SDRAM_VIRTUAL_MEMORY + 0x0A00000);
pMemSections[1].dwLen=0x600000;
return 2;
這 樣,系統(tǒng)所有的內(nèi)存都被激活,系統(tǒng)可用內(nèi)存就變成了8+8+6=24M,可以將RAM定義為這三片中的任意一片,而在 OEMEnumExtensionDRAM中報告其它兩片。但把RAM放在最后一片物理內(nèi)存上有一個很大的好處,即如果NK變大,例如編譯一個DEBUG 版的系統(tǒng)時,這時,只需要將OEMEnumExtensionDRAM中的內(nèi)容注釋掉,CONFIG.BIB文件不用做任何改動,系統(tǒng)就可運行,只是在 MAKEIMG時會有一個警告說系統(tǒng)包太大,可能無法運行,但實際不會影響系統(tǒng)的執(zhí)行與穩(wěn)定性,因為NK之后的那段內(nèi)存并沒有被使用,正好被漲大的系統(tǒng)占 用,這在調(diào)試時極其方便。
而如果系統(tǒng)物理內(nèi)存是連續(xù)的,那將變得簡單的多,還以上面的設(shè)置為例,如果這32M的SDRAM是物理上連續(xù)的,內(nèi)存的使用情況就可以表示如下圖:


所有者系統(tǒng)可用內(nèi)存都可以定義在RAM片中。
對硬件知識了解不多的朋友請注意:SDRAM是否在物理上連續(xù),與我們的板上有幾片SDRAM沒有關(guān)系,應(yīng)該向硬件工程師了解SDRAM的地址分布情況。
posted on 2007-11-14 12:39 sunGuoqin 閱讀(4576) 評論(0)  編輯 收藏 引用 所屬分類: Embeded

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲一区二区三区四区五区午夜| 亚洲自拍都市欧美小说| 欧美成人精品一区二区| 久久精品欧美日韩精品| 久久久高清一区二区三区| 久久久免费观看视频| 美女视频黄 久久| 欧美另类变人与禽xxxxx| 欧美性色综合| 国精品一区二区| 91久久中文字幕| 一区二区三区视频在线观看| 欧美一级日韩一级| 久久在线视频在线| 亚洲乱码国产乱码精品精天堂| 亚洲网站在线播放| 久久嫩草精品久久久精品一| 欧美日韩精品伦理作品在线免费观看 | 欧美永久精品| 欧美大片在线看免费观看| 欧美视频日韩| 永久域名在线精品| 亚洲午夜久久久| 鲁大师成人一区二区三区| 亚洲欧洲中文日韩久久av乱码| 亚洲人精品午夜| 小黄鸭精品aⅴ导航网站入口| 麻豆av一区二区三区| 国产精品久久久久久久久果冻传媒| 国语自产精品视频在线看抢先版结局 | 欧美一级黄色网| 欧美高清hd18日本| 国产婷婷色一区二区三区在线 | 亚洲精品久久7777| 欧美主播一区二区三区美女 久久精品人| 欧美1区3d| 亚洲欧美日韩成人高清在线一区| 免费日韩av| 国内成人精品视频| 午夜欧美不卡精品aaaaa| 亚洲国产中文字幕在线观看| 久久国内精品视频| 国产欧美精品久久| 亚洲欧美久久久久一区二区三区| 亚洲午夜激情| 亚洲午夜精品视频| 欧美激情一区二区三区全黄| 伊人成人在线视频| 欧美一区二区视频在线观看2020| 亚洲欧洲日夜超级视频| 久久一区二区精品| 国产亚洲成av人片在线观看桃 | 亚洲精品久久久久久久久| 久久国产乱子精品免费女| 一本久久a久久精品亚洲| 欧美国产免费| 亚洲欧洲一区| 欧美激情无毛| 女仆av观看一区| 91久久精品国产91性色 | 亚洲一区二区三区视频| 欧美午夜不卡| 亚洲欧美www| 亚洲一区二区三区在线观看视频| 欧美三级在线视频| 亚洲欧美制服另类日韩| 亚洲午夜一区二区三区| 国产精品日韩欧美大师| 欧美在线观看视频一区二区三区| 亚洲免费在线视频| 国产真实久久| 亚洲国产精品黑人久久久| 欧美华人在线视频| 亚洲网站在线| 欧美一区二区视频97| 今天的高清视频免费播放成人| 久久亚洲精品视频| 蜜臀va亚洲va欧美va天堂| 亚洲人成毛片在线播放| 日韩视频在线观看免费| 国产精品女主播| 久久综合一区二区| 欧美黄免费看| 欧美一区二区三区久久精品茉莉花 | 一区二区三区四区精品| 一区二区三区欧美在线观看| 国产精品无码专区在线观看| 噜噜噜久久亚洲精品国产品小说| 免费成人美女女| 亚洲直播在线一区| 久久久久国产一区二区三区| 亚洲精品少妇30p| 亚洲欧美成人一区二区在线电影| 狠狠色2019综合网| 99精品国产高清一区二区| 国产午夜精品久久久久久久| 亚洲国产成人av| 国产欧美日本| 亚洲综合成人婷婷小说| 亚洲免费影视| 久久免费视频网站| 亚洲欧美国内爽妇网| 久久久亚洲国产天美传媒修理工| 亚洲精品一二| 久久精品国产91精品亚洲| 宅男噜噜噜66一区二区| 久久久噜噜噜久久中文字免| 国产精品99久久久久久宅男 | 亚洲精品精选| 午夜在线播放视频欧美| 一区二区高清视频在线观看| 欧美一级电影久久| 这里只有精品在线播放| 久久免费高清视频| 久久精品在线视频| 国产精品海角社区在线观看| 亚洲成人资源网| 国内成+人亚洲| 亚洲午夜日本在线观看| avtt综合网| 欧美91大片| 欧美成人精品h版在线观看| 国产拍揄自揄精品视频麻豆| 亚洲另类自拍| 在线亚洲自拍| 欧美日韩一区二区三区在线视频| 亚洲高清av在线| 亚洲国产你懂的| 久久亚洲国产精品日日av夜夜| 久久精品九九| 国产午夜精品一区二区三区欧美| 亚洲先锋成人| 翔田千里一区二区| 国产精品视屏| 午夜精品久久久久| 欧美在线一二三区| 国产欧美日韩三级| 欧美一区二视频| 久久人体大胆视频| 在线成人欧美| 麻豆九一精品爱看视频在线观看免费| 久久久久在线| 亚洲国产精品一区二区www| 久久亚洲综合色一区二区三区| 麻豆国产va免费精品高清在线| 精品成人久久| 欧美高清日韩| 中国成人黄色视屏| 久久riav二区三区| 黄色成人av| 美女尤物久久精品| 亚洲精品日韩综合观看成人91| 亚洲天堂av在线免费观看| 国产精品美女午夜av| 亚洲欧美亚洲| 欧美fxxxxxx另类| 99热免费精品在线观看| 国产精品jizz在线观看美国 | 欧美有码在线观看视频| 黄色成人在线观看| 欧美a级片网站| 美女主播一区| 久久精品99国产精品| 在线不卡a资源高清| 欧美国产日韩精品免费观看| 一本色道久久精品| 久久久视频精品| 亚洲作爱视频| 国产在线成人| 欧美日韩国产色综合一二三四| 亚洲私人影院| 欧美电影免费观看高清| 亚洲一区二区在| 在线不卡欧美| 国产精品乱人伦一区二区| 久久香蕉国产线看观看网| 一片黄亚洲嫩模| 欧美成人精品在线播放| 亚洲一区三区在线观看| 永久免费精品影视网站| 国产精品九九| 欧美激情第10页| 久久精品国产免费| 亚洲色图在线视频| 欧美国产第二页| 久久精品国产亚洲精品| 一本色道久久综合亚洲精品婷婷 | 国产欧美日韩精品在线| 欧美暴力喷水在线| 欧美在线视频二区| 宅男噜噜噜66国产日韩在线观看| 牛夜精品久久久久久久99黑人| 午夜精品久久一牛影视| 亚洲精品午夜| 亚洲第一页自拍| 国产在线麻豆精品观看| 国产精品一区二区男女羞羞无遮挡| 欧美国产日韩精品| 欧美成人第一页| 免费成人小视频|