国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

嵌入式Web訪問時的內(nèi)存丟失問題

發(fā)布時間:2010-2-18 15:50    發(fā)布者:李寬
關(guān)鍵詞: Web , 訪問 , 內(nèi)存 , 嵌入式
由于嵌入式技術(shù)的發(fā)展,嵌入式Web服務(wù)器軟件越來越大,對硬件的要求也相應(yīng)地提高,但在工業(yè)現(xiàn)場的底層控制中,一般嵌入式系統(tǒng)的硬件配置都不是很高,導(dǎo)致了軟件和硬件的沖突。本文就是對實際應(yīng)用過程中,偶爾出現(xiàn)的Web頁面訪問出錯問題進行深入的研究。

1 嵌入式Web在系統(tǒng)中的應(yīng)用

多支點觸發(fā)系統(tǒng)包括以下幾個模塊:控制臺模塊、網(wǎng)絡(luò)觸發(fā)源模塊、被觸發(fā)設(shè)備模塊。其中,網(wǎng)絡(luò)觸發(fā)源和被觸發(fā)設(shè)備都是掛載在總線上的,通過現(xiàn)場總線可以將系統(tǒng)各個節(jié)點相互連接起來以方便管理。嵌入式web就是應(yīng)用于網(wǎng)絡(luò)觸發(fā)源模塊中,它負責(zé)控制臺和被觸發(fā)設(shè)備之間的通信。控制臺通過瀏覽器訪問網(wǎng)絡(luò)觸發(fā)源,在 Web頁面上完成相應(yīng)控制操作后,由網(wǎng)絡(luò)觸發(fā)源把操作命令發(fā)送到總線上,被觸發(fā)設(shè)備從總線上接收到命令后,完成相應(yīng)操作。在網(wǎng)絡(luò)觸發(fā)源模塊中,Web服務(wù)器采用的是Boa,嵌入式操作系統(tǒng)采用的是uClinux,處理器采用的是Sam-sung公司的S3C44BO。多支點觸發(fā)系統(tǒng)結(jié)構(gòu)如圖1所示。



2 Boa的運行流程及出現(xiàn)的問題

Boa是單任務(wù)的http服務(wù)器,源碼開放,性能高。與傳統(tǒng)的Web服務(wù)器不同,它并不對每個進入服務(wù)器的連接開辟新的進程,所有活動的http連接都在內(nèi)部進行處理,而只為每個CGI連接啟動新進程。在已進行的測試中,Boa服務(wù)器比其他的Web服務(wù)器要快,所以它應(yīng)用在嵌入式系統(tǒng)中是具有良好前景的。圖2是Boa基本的運行流程。

在Boa運行過程中,用戶請求初始Lo-gin頁面時,系統(tǒng)能正常響應(yīng)操作。當(dāng)用戶輸入正確的Login信息,要實現(xiàn)頁面跳轉(zhuǎn)時,PC機上的瀏覽器里面不能正確瀏覽,提示錯誤:“502 bad gate-way The CGI was notCGI/1.1 compliant”。由于運行的是CGI程序,通過調(diào)試和查看錯誤日志,發(fā)現(xiàn)系統(tǒng)停留在步驟⑤~⑦間。在排除CGI程序錯誤后,通過串口調(diào)試終端打印出的錯誤信息發(fā)現(xiàn):在執(zhí)行CGI程序時,內(nèi)核申請內(nèi)存時出錯,提示申請的內(nèi)存塊不能得到,即內(nèi)存丟失。



3 系統(tǒng)內(nèi)存丟失分析

3.1 uClinux的內(nèi)存管理

uClinux不能使用處理器的虛擬內(nèi)存管理技術(shù),它仍然采用存儲器的分頁管理。系統(tǒng)啟動時對存儲器分頁,加載應(yīng)用程序?qū)Τ绦蚍猪摷虞d。由于沒有 MMU管理,所以uClinux采用實存儲器管理。uClinux系統(tǒng)對內(nèi)存的訪問是直接的(它對地址的訪問不經(jīng)MMU,而是直接送到地址線上輸出),所有程序訪問的地址是物理地址。那些比物理內(nèi)存還大的程序?qū)o法執(zhí)行。

uClinux將整個物理內(nèi)存劃分成為4 KB的頁面。由數(shù)據(jù)結(jié)構(gòu)page管理,有多少頁面就有多少page結(jié)構(gòu),它們又作為元素組成數(shù)組men_map[]。物理頁面可作為進程代碼、數(shù)據(jù)和堆棧的一部分,還可存儲裝入的文件,也可作緩沖區(qū)。

uClinux用標準Linux內(nèi)核變型BuddySystem機制管理空閑物理頁面。

3.2 內(nèi)存丟失原因

由于uClinux提供了跟普通Linux一樣的內(nèi)存分配器,普通Linux中缺省的內(nèi)存分配器是使用“2的冪”的分配方法,這樣可以快速找到符合要求的內(nèi)存區(qū)域。在系統(tǒng)開發(fā)過程初期,采用的就是“2的冪”的分配方法。如果一個應(yīng)用程序要求(X)KB內(nèi)存空間進行裝載,則實際使用占用的內(nèi)存空間大小為Y=2m(Y≥X)。試想一個65 KB應(yīng)用程序,如果按照“2的冪”的分配方法,就必須分配128 KB(2的7次方)的內(nèi)存空間,這樣就有63 KB的內(nèi)存空間不能被利用上。這對于小內(nèi)存的嵌入式系統(tǒng)來說是相當(dāng)大的浪費。

多支點觸發(fā)系統(tǒng)運行時,嵌入式操作系統(tǒng)uClinux使用“2的冪”的內(nèi)存分配方法,大多數(shù)情況下都能正常工作。但在不斷反復(fù)測試中,偶爾會出現(xiàn)上述頁面出錯問題。錯誤的原因是不能獲得足夠的內(nèi)存加載程序。通過調(diào)試終端,用free命令查看系統(tǒng)內(nèi)存分配情況如表1所列。



由表1可以看出,空閑的內(nèi)存空間還有1560 KB,而應(yīng)用程序所需的內(nèi)存空間為400多KB,但是內(nèi)核認為并沒有足夠的內(nèi)存空間用來加載程序。例如一個系統(tǒng)內(nèi)存大小為1 MB,有400KB的空閑內(nèi)存,為了裝載一個應(yīng)用程序需要分配100 KB的空間。大家可能覺得這個需要肯定能得到滿足,然而,由于uClinux必須給應(yīng)用程序分配連續(xù)內(nèi)存空間的特性,所以必須有100KB連續(xù)的內(nèi)存空間才能滿足這個需要。而當(dāng)系統(tǒng)內(nèi)存分配如圖3所示時,最大的連續(xù)內(nèi)存塊的大小只有80 KB,這樣是沒有辦法分配給這個應(yīng)用程序的。這就是系統(tǒng)中頁面訪問出錯的問題所在,雖然有足夠的空閑內(nèi)存空間,但是沒有應(yīng)用程序所需的連續(xù)內(nèi)存空間。



這就是內(nèi)存丟失問題。雖然系統(tǒng)會顯示大量的可用內(nèi)存,但是應(yīng)用程序卻不能得到。

4 內(nèi)存丟失問題的解決

由于系統(tǒng)的內(nèi)存管理默認采用“2的冪”的分配方法,這就造成了內(nèi)存空間的巨大浪費,當(dāng)某些應(yīng)用程序要申請較大的連續(xù)空間時,卻不能滿足。為了解決這個問題,專門為uClinux內(nèi)核設(shè)計了可選的內(nèi)存分配器。不同的內(nèi)核版本,這個可選的內(nèi)存分配器不同,一般是page_alloc2和 kmalloc2。

page_alloc2能解決缺省的分配方法造成的浪費問題。雖然它也是使用“2的冪”的分配方法,但它是按頁(每頁4 096B,即4 KB)分配的,分配的內(nèi)存大小如果已經(jīng)滿足了要求,則只是將當(dāng)前的一頁分配出去,其他的就不再分配。還是一個65 KB的應(yīng)用程序,如果使用這種方法,就只是分配68 KB(≥65 KB,且為整頁)即可,這樣就能節(jié)省60 KB的空間。

page_alloc2還采取了一些避免內(nèi)存碎片的方法。它將所有的兩頁(8 KB)或更少的內(nèi)存需求從空閑內(nèi)存開始部分向上分配,所有大的內(nèi)存需求從剩余內(nèi)存的末尾部分開始向下分配。這樣防止了網(wǎng)絡(luò)緩存等的臨時分配,避免了內(nèi)存碎片的出現(xiàn)。同時,它支持一次申請超過1 MB的內(nèi)存空間,這對一些大的應(yīng)用程序是很好的支持。采用此方法后,在系統(tǒng)運行過程中,并未出現(xiàn)過頁面訪問出錯問題。通過free命令查看內(nèi)存分配如表2 所列。



結(jié)語

在嵌入式系統(tǒng)應(yīng)用日益廣泛的情況下,本文結(jié)合嵌入式Web在多支點觸發(fā)系統(tǒng)中的應(yīng)用,介紹了Web訪問出現(xiàn)的問題以及它的解決方法。在實際應(yīng)用中,新的內(nèi)存分配方法能讓系統(tǒng)穩(wěn)定地工作,但是從表2可以發(fā)現(xiàn):采用“page_alloc2'’的內(nèi)存分配方法時,系統(tǒng)的Cache較小,這就造成了頁面訪問有一定的延時。而“2的冪”的分配方法,系統(tǒng)的Cache較大,訪問速度較快。從這個對比得知,在反應(yīng)時間要求不是很高的情況下,“page_alloc2”的內(nèi)存分配方法更適合小內(nèi)存的嵌入式系統(tǒng);而“2的冪”的分配方法更合適那些內(nèi)存足夠大的嵌入式系統(tǒng)。系統(tǒng)開發(fā)者可以根據(jù)實際情況采用不同的方案。

參考文獻

   1. 吳堅,張家奇,蔣平.uClinux下Web Server及CGI技術(shù)的實現(xiàn)[J].測控技術(shù),2007,26(4):64.
   2. 李慶坤.基于uClinux的嵌入式動態(tài)Web服務(wù)器的設(shè)計[D].武漢:武漢理工大學(xué),2007.
   3. uclinux org.GETTING STARTED[R/OL].(2005-03).http://www.uclinux.org.
   4. David McCullough.uClinux for Linux Programmers[OL].(2004-06).http://www.linuxjournal.com/article/7221.

作者:南京航空航天大學(xué) 周賓 章勇    來源:單片機與嵌入式系統(tǒng) 2009(10)
本文地址:http://www.qingdxww.cn/thread-8338-1-1.html     【打印本頁】

本站部分文章為轉(zhuǎn)載或網(wǎng)友發(fā)布,目的在于傳遞和分享信息,并不代表本網(wǎng)贊同其觀點和對其真實性負責(zé);文章版權(quán)歸原作者及原出處所有,如涉及作品內(nèi)容、版權(quán)和其它問題,我們將根據(jù)著作權(quán)人的要求,第一時間更正或刪除。
您需要登錄后才可以發(fā)表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區(qū)
  • 更佳設(shè)計的解決方案——Microchip模擬開發(fā)生態(tài)系統(tǒng)
  • 我們是Microchip
  • 深度體驗Microchip自動輔助駕駛應(yīng)用方案——2025巡展開啟報名!
  • 利用模擬開發(fā)工具生態(tài)系統(tǒng)進行安全電路設(shè)計
  • 貿(mào)澤電子(Mouser)專區(qū)

相關(guān)視頻

關(guān)于我們  -  服務(wù)條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權(quán)所有   京ICP備16069177號 | 京公網(wǎng)安備11010502021702
快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 尤物精品国产福利网站 | 人人干操 | 四虎国产成人永久精品免费 | 香蕉尹人 | 四虎成人免费观看在线网址 | 欧美成人性色生活片免费在线观看 | 亚洲欧美一区二区久久 | 国产盗摄一区二区欧美精品 | 亚洲资源在线视频 | 久久久久毛片成人精品 | 欧美激情在线精品video | 国产精品一区二区四区 | 久久免费视频1 | 欧美va在线播放免费观看 | 丁香伊人五月综合激激激 | 国产做a爰片久久毛片 | 天天插在线视频 | 欧美大陆日韩一区二区三区 | 欧美一区二区手机在线观看视频 | 极品国产一区二区三区 | 青青青国产在线观看免费网站 | 黄视频在线免费 | 10000拍拍18勿入免费视频| 在线亚洲欧美 | 日日噜噜夜夜狠狠视频欧美人 | 操插| 向日葵在线观看视频免费2019 | 老司机亚洲精品影院在线 | 9热这里只有真品 | 天天做天天爱天天做天天吃中 | 无码h肉动漫在线观看 | 亚洲欧美精品一区二区 | 九九国产| 爱情综合症泰剧在线观看 | 91区国产福利在线观看午夜 | 亚洲精品色婷婷在线影院麻豆 | 三级欧美日韩 | 国产精成人品 | 亚洲国产日韩在线人成下载 | 亚洲国产经典 | 成人精品一区久久久久 |