www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 嵌入式 > 嵌入式教程
[導(dǎo)讀]嵌入式Linux中的進程同步無競爭態(tài)讀寫

摘要 Linux作為一個開源、穩(wěn)健的操作系統(tǒng),支持多種平臺,擁有豐富的開發(fā)工具和應(yīng)用軟件,尤其是其內(nèi)核可裁減的特性,非常適合嵌入式系統(tǒng)。在數(shù)據(jù)實時性、準(zhǔn)確度要求很高的情況下,系統(tǒng)在對數(shù)據(jù)的采集和處理過程中,由于其進程協(xié)調(diào)性問題,往往會造成數(shù)據(jù)的丟失。利用經(jīng)典進程同步模型,可解決嵌入式Linux系統(tǒng)中數(shù)據(jù)同步讀寫沖突的問題。
關(guān)鍵詞 嵌入式 Linux進程同步 無競爭態(tài)讀寫


引 言
    在對實時采集更新的數(shù)據(jù)進行處理時,往往會遇到數(shù)據(jù)更新速度與數(shù)據(jù)處理的速度不匹配的問題。這種情況下,會出現(xiàn)數(shù)據(jù)丟失而導(dǎo)致數(shù)據(jù)處理結(jié)果不準(zhǔn)確,甚至?xí)聿豢深A(yù)測的后果,因此需要一種機制來協(xié)調(diào)數(shù)據(jù)更新與數(shù)據(jù)處理,從而保證數(shù)據(jù)的完整性和處理結(jié)果的準(zhǔn)確性。作為一個多任務(wù)、多用戶操作系統(tǒng),Linux支持多個進程在系統(tǒng)中并發(fā)運行,由于進程本身的動態(tài)特性,用來描述實時數(shù)據(jù)處理非常合適,因此,解決好Linux進程間的同步與通信問題就能解決實時數(shù)據(jù)處理的問題。
    在Linux環(huán)境下,進程通常存在運行(running)、阻塞(blocked)、就緒(ready)、終止(terminated)四種狀態(tài)。當(dāng)多個進程并發(fā)執(zhí)行時,往往會出現(xiàn)進程間的競態(tài)。我們希望進程能協(xié)調(diào)彼此間的行為,使得一個進程只有在其他的進程執(zhí)行到一個特定的點時才會執(zhí)行一個動作,即控制同步;同時,當(dāng)并發(fā)進程訪問共享數(shù)據(jù)時不應(yīng)當(dāng)出現(xiàn)競爭條件。這一點通過在訪問共享數(shù)據(jù)時執(zhí)行互斥來確保,即數(shù)據(jù)訪問同步。
    實現(xiàn)同步的基本技術(shù)是阻塞一個進程,直到一個特定條件滿足為止;實現(xiàn)數(shù)據(jù)訪問同步是通過阻塞一個進程直到另外的進程完成訪問共享數(shù)據(jù)。


1 有限長度緩沖區(qū)的生產(chǎn)者一消費者問題模型
   
當(dāng)僅存在單個生產(chǎn)者和消費者時,生產(chǎn)進程和消費進程所對應(yīng)的是同樣的數(shù)據(jù)結(jié)構(gòu),它們共享同一個數(shù)據(jù)空間。生產(chǎn)進程和消費進程如何進行相互協(xié)調(diào),使得消費進程每次使用的數(shù)據(jù)都是生產(chǎn)進程新生產(chǎn)寫人的,又使生產(chǎn)進程新寫入的數(shù)據(jù)不會覆蓋還未被消費進程讀出使用的數(shù)據(jù),是該問題模型實現(xiàn)的關(guān)鍵問題。
    在生產(chǎn)者一消費者問題模型中,生產(chǎn)者進程不斷生產(chǎn)產(chǎn)品并把它們放入緩沖區(qū),消費者進程不斷從緩沖區(qū)中取走產(chǎn)品進行消費。當(dāng)緩沖區(qū)中產(chǎn)品已經(jīng)放滿時,表示生產(chǎn)速度高于消費速度,出現(xiàn)了供過于求,此時生產(chǎn)者必須等待產(chǎn)品被消費;當(dāng)緩沖區(qū)為空時,表示消費速度高于生產(chǎn)速度,出現(xiàn)了供不應(yīng)求,此時消費者進程必須等待產(chǎn)品的生產(chǎn)。生產(chǎn)和消費的進程必須達到同步運行,才能實現(xiàn)供需平衡。
    處理讀寫同步的兩種常見的策略被稱為“強讀者同步(strong reader synchronization)”和“強寫者同步(strongwriter synchronization)”。在強讀者同步中,總是給讀者以優(yōu)先權(quán),只要寫者當(dāng)前沒有進行寫操作,讀者就可以獲得訪問權(quán);在強寫者同步中,寫者總是獲得優(yōu)先權(quán),只要強讀者當(dāng)前沒有進行讀操作,寫者就可以獲得訪問權(quán)。而生產(chǎn)者消費者同步與單純的讀寫同步又有不同,消費者可以通過訪問資源對資源進行刪除或銷毀。
    一個有限長度緩沖區(qū)的生產(chǎn)者消費者問題模型,是由若干生產(chǎn)者和消費者進程以及一個有限的緩沖池構(gòu)成的。每個緩沖區(qū)能夠存儲一個信息記錄,一個生產(chǎn)者一次生產(chǎn)一個信息記錄。產(chǎn)生一個記錄之后,等待單獨進入一個空的緩沖區(qū)后將記錄寫入緩沖區(qū)。一個消費者進程一次消費一個信息記錄。當(dāng)它需要消費時,它等待單獨進入一個滿的緩沖區(qū)后將記錄讀出。
    通過上面的描述可以得出,解決生產(chǎn)者一消費者問題模型的方案需要滿足以下幾個條件:
    ◇生產(chǎn)者不應(yīng)覆蓋一個滿的緩沖區(qū);
    ◇消費者不應(yīng)使用一個空的緩沖區(qū);
    ◇生產(chǎn)者和消費者應(yīng)按互斥方式訪問數(shù)據(jù)緩沖區(qū);
    ◇數(shù)據(jù)必須按照先進先出(FIFO)方式;
    ◇不能出現(xiàn)忙等待。
    必須避免數(shù)據(jù)寫進程不斷、反復(fù)地檢查緩沖區(qū)直到找到一個空緩沖區(qū)為止,而讀進程也必須避免不斷檢查直到找到一個滿緩沖區(qū)為止。這相當(dāng)于系統(tǒng)內(nèi)部產(chǎn)生忙等待,是在僅使用臨界段(CS)算法實現(xiàn)進程同步時難以避免的問題。
    針對問題模型解決方案的限制條件,采用信號量方式解決實時更新數(shù)據(jù)處理的進程同步問題,即上述的生產(chǎn)者一消費者問題模型。
    信號量是一個非負值的共享整數(shù)值,只能用于初始化和不可分操作。不可分操作是指在對一個數(shù)據(jù)D進行操作時不能與任何其他對D的操作重疊的操作。定義操作P和V為不可分操作。P和V的不可分性意味著這些操作不能并發(fā)執(zhí)行,避免了對信號量的競爭條件。定義P和V的操作語義為:

   
    由上述定義的語義看,對一個信號量S的操作,P和V為改變S的值,或者掛起或喚醒一個對S進行P操作的進程。被掛起的進程為阻塞狀態(tài),因而避免了忙等待問題。一個二進制的信號量只取0和1,用來實現(xiàn)互斥。
    在P和V操作中,對進程的阻塞和喚醒需要操作系統(tǒng)的進程管理組件的參與,因此信號量會被操作系統(tǒng)實現(xiàn)而不是應(yīng)用程序?qū)崿F(xiàn)。
    生產(chǎn)者一消費者問題模型描述:

   
2 結(jié)構(gòu)設(shè)計
   
對于有限緩沖區(qū)的生產(chǎn)者消費者問題模型的執(zhí)行包括以下部件:共享數(shù)據(jù)一緩沖區(qū)組、操作一緩沖區(qū)的訪問、進程一生產(chǎn)者消費者。
    在生產(chǎn)者一消費者同步中,由生產(chǎn)者創(chuàng)建資源,與單純的讀程序不同,消費者可以通過訪問資源,將資源刪除或銷毀。由于生產(chǎn)者進程和消費者進程共享一個緩沖區(qū),因此在插入和刪除條目時必須同步。實現(xiàn)中必須避免表l所列的同步異常問題。

    生產(chǎn)者一消費者問題的傳統(tǒng)的信號量解決方案使用了2個信號量,分別用來表示緩沖區(qū)中的條目數(shù)和空閑槽的數(shù)目。當(dāng)進程需要特定類型的資源時,它可以通過函數(shù)調(diào)用對相應(yīng)的信號量進行減量操作;同樣,當(dāng)進程釋放資源時,它可以通過函數(shù)調(diào)用來對相應(yīng)的信號量進行增量操作。由于信號量永遠不會降到零以下,所以進程不能使用不存在的資源。因此,始終將計數(shù)信號量初始化為開始時可用的資源數(shù)。
    定義循環(huán)隊列緩沖區(qū)存放待處理數(shù)據(jù),控制臺數(shù)據(jù)處理進程從該循環(huán)隊列緩沖區(qū)中消費數(shù)據(jù),并將該數(shù)據(jù)存儲位標(biāo)記為“廢棄”。數(shù)據(jù)采集寫進程僅能將數(shù)據(jù)存放于標(biāo)記為“廢棄”的循環(huán)隊列緩沖區(qū)中,如圖1所示。

    在沒有多個生產(chǎn)者或消費者的情況下,如果仔細實現(xiàn),循環(huán)緩沖區(qū)就不需要鎖。生產(chǎn)者是唯一允許修改寫入索引以及該索引指向的數(shù)組位置的進程。只要寫入者在更新寫入索引之前將新的值保存到緩沖區(qū),則讀取者將始終看到一致的數(shù)據(jù)結(jié)構(gòu);同時,讀取者是唯一可以訪問讀取索引以及該索引指向位置的數(shù)據(jù)的進程。只要確保兩個指針不要互相重疊,生產(chǎn)者和消費者可以在無竟態(tài)的情況下訪問該緩沖區(qū),如圖2所示。

    對于只有單個生產(chǎn)者和消費者,通過使用修正的使用信號量方式的生產(chǎn)者一消費者問題模型解決方案來實現(xiàn)。

   

    以上用信號量方式解決了優(yōu)先緩沖區(qū)問題,信號量“empty”和“full”的值分別指示空和滿的緩沖區(qū)的數(shù)量,如圖3所示。緩沖區(qū)指針i和j用來確保緩沖區(qū)按先進先出的順序提供并使用。只要系統(tǒng)中存在一些滿的和空的緩沖區(qū),數(shù)據(jù)更新進程和數(shù)據(jù)處理進程就能無競態(tài)并發(fā)執(zhí)行。筆者在華恒ARM嵌入式平臺HHARM2410-R5上按照上述方案成功實現(xiàn)了用例測試。

3  討論

    以上的結(jié)構(gòu)設(shè)計,將生產(chǎn)者與消費者分別簡化為一個。當(dāng)存在多個生產(chǎn)者和消費者的情況時,可以上述修正的解決方案為基礎(chǔ),設(shè)計多個計數(shù)器來統(tǒng)計并行讀者(reader)、并行寫者(writer)、讀者或待讀者(pre_reader)、寫者或待寫者(pre_writer)的數(shù)量。計數(shù)器的值在進程中的相應(yīng)位置進行增減。讀者和寫者在被允許閱讀和寫入之前必須被阻塞,這可以通過P操作來完成。當(dāng)讀者或?qū)懻咴谶M程被阻塞時控制開始閱讀或書寫的條件并未滿足。這些條件隨著任意一個計數(shù)器值的變化而改變,所以,進程在完成閱讀或書寫后必須執(zhí)行相應(yīng)的V操作。

    在實行多讀、多寫進程同步解決方案時,必須要避免不同計數(shù)器的競爭條件,因而必須在臨界段(CS)中執(zhí)行對允許讀或?qū)懖僮鳁l件的檢查。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

蔡司在蘇州工業(yè)園區(qū)奠基啟動"鳳棲"工程建設(shè),這是蔡司在國內(nèi)首次購地自建項目,標(biāo)志著蔡司在中國本土化進程的進一步深化與擴展。 "鳳棲"工程建成后,蔡司蘇州將成為蔡司在中國更高規(guī)格的研發(fā)與制造的重要據(jù)點,為其工業(yè)質(zhì)量、研究顯...

關(guān)鍵字: 顯微鏡 進程

成都2022年10月19日 /美通社/ -- 近期,平安養(yǎng)老險積極籌備個人養(yǎng)老金的產(chǎn)品設(shè)計和系統(tǒng)開發(fā)工作,發(fā)展多樣化的養(yǎng)老金融產(chǎn)品,推動商業(yè)養(yǎng)老保險、個人養(yǎng)老金、專屬商業(yè)養(yǎng)老保險等產(chǎn)品供給。 搭養(yǎng)老政策東風(fēng) ...

關(guān)鍵字: 溫度 BSP 東風(fēng) 大眾

廣東佛山2022年10月19日 /美通社/ -- 空間是人居生活的基礎(chǔ)單元,承載著生存與活動的最基本功能。而對于理想空間的解構(gòu)意義卻在物理性容器之外,體現(xiàn)出人們對于空間和生活深層關(guān)系的思考,同時也塑造著人與空間的新型連接...

關(guān)鍵字: 溫度 BSP 智能化 進程

上海2022年10月19日 /美通社/ -- 10月17日晚間,安集科技披露業(yè)績預(yù)告。今年前三季度,公司預(yù)計實現(xiàn)營業(yè)收入7.54億元至8.33億元,同比增長60.24%至77.03%;歸母凈利潤預(yù)計為1.73億...

關(guān)鍵字: 電子 安集科技 BSP EPS

北京2022年10月19日 /美通社/ -- 10月18日,北京市經(jīng)濟和信息化局發(fā)布2022年度第一批北京市市級企業(yè)技術(shù)中心創(chuàng)建名單的通知,諾誠健華正式獲得"北京市企業(yè)技術(shù)中心"認定。 北京市企業(yè)技...

關(guān)鍵字: BSP ARMA COM 代碼

北京2022年10月18日 /美通社/ -- 10月14日,國際數(shù)據(jù)公司(IDC)發(fā)布《2022Q2中國軟件定義存儲及超融合市場研究報告》,報告顯示:2022年上半年浪潮超融合銷售額同比增長59.4%,近5倍于...

關(guān)鍵字: IDC BSP 數(shù)字化 數(shù)據(jù)中心

上海2022年10月18日 /美通社/ -- 2022年9月5日,是首都銀行集團成立60周年的紀(jì)念日。趁著首都銀行集團成立60周年與首都銀行(中國)在華深耕經(jīng)營12年的“大日子”,圍繞作為外資金融機構(gòu)對在華戰(zhàn)略的構(gòu)想和業(yè)...

關(guān)鍵字: 數(shù)字化 BSP 供應(yīng)鏈 控制

東京2022年10月18日  /美通社/ -- NIPPON EXPRESS HOLDINGS株式會社(NIPPON EXPRESS HOLDINGS, INC.)旗下集團公司上海通運國際物流有限公司(Nipp...

關(guān)鍵字: 溫控 精密儀器 半導(dǎo)體制造 BSP

廣州2022年10月18日 /美通社/ -- 10月15日,第 132 屆中國進出口商品交易會("廣交會")于"云端"開幕。本屆廣交會上高新技術(shù)企業(yè)云集,展出的智能產(chǎn)品超過140,...

關(guān)鍵字: 中國智造 BSP 手機 CAN

要問機器人公司哪家強,波士頓動力絕對是其中的佼佼者。近來年該公司在機器人研發(fā)方面獲得的一些成果令人印象深刻,比如其開發(fā)的機器人會后空翻,自主爬樓梯等。這不,波士頓動力又發(fā)布了其機器人組團跳男團舞的新視頻,表演的機器人包括...

關(guān)鍵字: 機器人 BSP 工業(yè)機器人 現(xiàn)代汽車

嵌入式教程

6897 篇文章

關(guān)注

發(fā)布文章

編輯精選

技術(shù)子站

關(guān)閉