《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 一種嵌入式RPC的設計與實現
一種嵌入式RPC的設計與實現
電子設計工程
許 瓊,蔡文皓 西安科技大學
摘要: 一種嵌入式RPC的設計與實現,摘要:在研究遠程過程調用的原理和嵌入式系統特點的基礎上,提出一種遠程過程調用的設計以及在VxWorks操作系統上服務器端和在Win-dows探作系統上客戶端的實現。經在項目中的應用,本設計與實現體現了良好的實用性、移
關鍵詞: SOC Vxworks 嵌入式
Abstract:
Key words :

摘要:在研究遠程過程調用的原理和嵌入式系統特點的基礎上,提出一種遠程過程調用的設計以及在VxWorks操作系統上服務器端和在Win-dows探作系統上客戶端的實現。經在項目中的應用,本設計與實現體現了良好的實用性、移植性和擴展性。
關鍵詞:遠程過程調用;嵌入式系統;網絡;狀態機

    遠程過程調用(Renmte Procedure call,RPC)最早是在B.J.Nelson的博士論文中論述的。這里的過程等價于例程,函數的意思。RPC的思想源于大多數的程序都以過程作為最小設計單位。RPC擴展了過程調用機制,允許客戶端的過程通過網絡調用服務器端的過程。
    從RPC的思想出發,不同的組織和公司開發了不同的RPC協議。有SUN公司的ONC RPC,開放軟件基金會的DCE RPC,微軟公司的MSRPC等。這些RPC都依賴與特定操作系統,并且定義了自己的接口描述語言(IDL),對于嵌入式開發過于復雜。

1 RPC的機制
1.1 過程調用
    典型的過程調用就是過程A將參數和控制權交給過程B,過程B經過一系列運算或者下一級過程,最后把結果和控制權返回給過程A。
1.2 RPC流程
    RPC分為同步RPC和異步RPC。在同步RPC中客戶端發出RPC調用的線程將被阻塞,直到從服務器端完成。異步RPC中客戶端發出調用的線程不會被阻塞而是繼續執行。本文以同步RPC為研究對象。
    RPC的思想就是使遠程過程調用看上去就像在本地的過程調用一樣。從程序運行角度來看,其流程如圖1所示??蛻舳?MACHINE A)的進程通過網絡發送遠程過程調用請求給服務器(MACHINE B)。服務器收到請求后處理,調用相應的過程執行,執行完畢后服務器返回結果給客戶進程??蛻暨M程在發出遠程過程調用后被阻塞,直到服務器返回結果給客戶進程。

a.JPG


1.3 RPC的結構模型
    從描述的角度出發,產生不同的RPC模型如Andrew S.Tanenhum在其著作分布式操作系統中論述的模型以及B.J.Nelson論文中的RPC模型等。但這些模型的主要組件都是相同的。圖2是B.J.Nelson博士的RPC結構模型??蛻暨M程、客戶存根和RPC運行庫實例在客戶端執行。服務進程、服務器存根和RPC運行庫實例在服務器端執行。客戶過程調用相應的客戶存根??蛻舸娓虬鼌???蛻舳说腞PC運行庫將打包好的參數通過網絡發送給服務器RPC運行庫。服務器存根拆包參數,然后調用服務器過程。完成后返回結果給服務器存根。服務器存根打包結果給服務器RPC運行庫。服務器RPC運行庫發送打包好的參數給客戶RPC運行庫??蛻舸娓鸢⒔Y果取出返回給客戶。

b.JPG


    盡管RPC的思想比較簡單,但有很多問題需要考慮。由于有很多不同的CPU,如X86、ARM、SPARC等以及各種DSP、單片機,產生了參數傳遞問題。如X86采用最低有效字節優先,而SPARC是最高字節優先。有些大型機采用EBCDIC碼,而其他處理器采用ASCII碼。存根就是用來解決這些問題。還有指針問題,涉及物理地址、虛擬地址、地址空間等很多考慮。我們知道不同計算機之間無法直接訪問彼此的地址。還有過程的參數如果為數據結構,這就引出數據對齊的問題。由此可以推斷所有的RPC實現都在一定的范圍適用。本文的RPC設計假定客戶端和服務器端有相同的大小端和并且都是32位處理器。
1.4 SunRPC
    Sun RPC有時也稱為ONC(Open Network Computing)RPC。Sun RPC提供了一個接口語言IDL和rpcgen用于C語言支持。這門語言可以定義constants,typedef,structure,union。rpcgen可以產生server code,client stub和頭文件。server code主要是建立socket,注冊端口和監聽,接受連接,拆參數,調用實際的過程,打包返回值。client stub則是打包參數,發送給server,將返回值解包。Sun RPC缺點就是對Windows沒有很好的支持。

2 設計
    本設計與傳統的模型不同,服務器端分為:網絡通訊,接收狀態機和過程處理。客戶端分為網絡通訊,發送狀態機和過程調用。
    圖3是服務器端的狀態機。服務器進程從初始狀態進入GetHeader狀態。GetHeader是讀取遠程過程調用的頭信息。如果一次得到了所有數據,也就是nCurLen>=dwTotalSize,則進入GetComplatePacket狀態,反之進入GetData狀態。GetData是讀取參數數據,讀取數據直到得到所有的數據進入GetComplatePacket狀態。期間如果超時,則回到GetHeader狀態。超時的起始時間從GetHeader韻第一個字節算起,如果在定義的時間無法讀取dwTotalSize個字節,則Timeout從而回到GetHeader狀態。在GetHeader和GetData時,如果讀取數據有錯誤(如客戶端斷開連接,recv函數返回錯誤)則狀態機退出。GetComplatePacket是得到了完整的包。CheckCall判斷當前的調用是否是有效的過程調用。如果無效則進入狀態,并回復無效命令給客戶端,最后進入GetHeader狀態。如果有效,則處理此調用,最后發送結果給客戶端。

c.JPG          d.JPG


    圖4為客戶端狀態機。首先是打包參數,發送到服務器端,等待服務器端的回復,進入GetHeader狀態。GetHeader,GetData和Get Com-plate Packet與服務器相應的狀態意義相同。如果timeout則返回timeout錯誤。如果得到了整個packet則拆分最后返回。
    DCE—RPC和ONC—RPC允許選擇UDP或TCP協議。TCP協議傳輸控制協議,提供的是面向連接、可靠的字節流服務。UDP協議不提供可靠性,它只是把應用程序傳給IP層的數據報發送出去,但是并不能保證它們能到達目的地。基于TCP協議的可靠性,選擇TCP作為通訊協議。
3 實現
3.1 數據結構
    服務器和客戶用共用包頭信息和每個過程的參數結構。頭信息定義如下。dwCallID是過程的標識號。每個過程都有一個唯一的號碼。bCallType是調用的類型。dwTotalSize是整包的字節數。dwReturn是返回結果。
    e.JPG
    過程調用的類型定義如下。RPC_TYPE_SIMPLE_WRITEREAD是簡單的讀寫,輸入參數和輸出參數都在頭信息和過程的參數數據結構中。RPC_TYPE_READ指返回結果保存在單獨的內存。RPC_TYPE_WRITE指寫信息保存在單獨的內存。RPC_TYPE_WRITE_READ調用是需要內存保存輸入數據,返回時需要保存輸出的結果。
  f.JPG
    每個過程定義自己的輸入輸出參數結構。例如對獲取串口狀態GetCommState過程,建立RPC_GETCOMMSTATE結構。
    h.JPG
    由于各個編譯器對struct數據結構的成員的對齊實現不同。這樣同樣的struct在客戶端和服務器端的大小可能不同,同樣的成員在結構中的位置不同。為了確??蛻舳撕头掌鞫擞邢嗤膶R,我們采用字節對齊用#pragma pack(1)。
3.2 Packet內存布局
    開始依次是頭信息和參數,其余部分根據特定的過程而不同。以RPC_TYPE_WRITE_READ類型的布局為例:頭信息,參數,輸入內存塊[1…N],輸出內存塊[1…N]。其他的過程類型布局類似。
3.3 服務器端實現
3.3.1 網絡模塊實現
    RPC在單獨的任務中執行。圖5為RPC任務流程圖。調用VxWorks的系統函數taskSpawn建立RPC任務。調用socket( )建立面向連接的SOCK_ STREAM套接字,bind將套接字與本地網絡地址和端口號捆綁,listen申明要在該端口偵聽客戶連接請求,accept阻塞等待請求的到來。

h.JPG


3.3.2 狀態機實現
    當accept后,進入服務器端狀態機。設置accept返回的socket為非阻塞狀態。在阻塞的socket上調用send時,如果沒有足夠的輸出緩沖區,該調用將被阻塞。Recv也是一樣,要讀的數據沒有就緒時,調用者阻塞。服務器不知道每次要讀取的字節數,所以阻塞的socket無法工作。
    分配2塊內存:A和B。內存A用來保存recv的內容,內存B用來保存客戶端發送的Packet內容。因為服務器不知道客戶會發送多大的內容過來,每次從內存A拷貝到內存B之前檢查內存B的大小,如果內存B剩余大小不夠則重新分配。
    在得到了整個Packet后,即GetComplatePacket后,根據dwCallID調用服務器的本地過程,待返回后將返回值和內存打包發送給客戶端。
3.4 客戶端實現
   客戶端的流程如圖6所示。在Windows下運行,首先調用WSAStartup,Windows根據請求的Socket版本來搜索相應的Socket庫,然后綁定找到的Socket庫到該應用程序中。然后初始化socket,連接到服務器,接著過程調用。比如過程調用1會進入圖4狀態機。狀態機和服務器端類似,只是首先參數打包,發送給服務器,返回后拆包并拷貝返回信息到內存中。

i.JPG



4 結束語
    本文設計和實現的RPC可應用于白盒測試、跨平臺開發環境和開發客戶端軟件等。商用的嵌入式IDE軟件都很昂貴,通過本RPC,測試人員就可用開源的環境如cygwin等開發白盒測試代碼。另外對于有大量操作界面的嵌入式開發,需要頻繁下載到開發板上驗證,本文RPC可應用于構建跨平臺的開發環境,直接在Windows上開發界面部分,最后下載到開發板上,從而大大提高開發效率。大多數的嵌入式軟件都有相應的PC客戶端軟件,本文的實現也適用于開發PC客戶端軟件。

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          亚洲人在线视频| 久久精品二区| 欧美日本一道本在线视频| 精品va天堂亚洲国产| 亚洲小视频在线| 先锋影音国产精品| 欧美成人免费在线视频| 国产精品久久波多野结衣| 99在线热播精品免费99热| 国产精品网站在线观看| 久久综合色影院| 激情视频一区二区三区| 亚洲精品日韩综合观看成人91| 一本色道久久综合一区| 一本大道久久精品懂色aⅴ| 一区二区91| 欧美视频在线一区二区三区| 欧美午夜宅男影院在线观看| 久久久91精品| 国产毛片一区| 欧美不卡激情三级在线观看| 极品少妇一区二区| 欧美一区二区三区日韩视频| 亚洲精品日韩精品| 国产欧美一区在线| 久久看片网站| 亚洲欧美区自拍先锋| 99精品国产一区二区青青牛奶| 在线成人欧美| 亚洲国产精品va在线看黑人动漫| 欧美日韩在线播| 一本色道久久综合| 午夜久久影院| 亚洲综合成人婷婷小说| 快she精品国产999| 亚洲性视频网址| 欧美另类videos死尸| 亚洲一区尤物| 国产精品99一区| 亚洲精品一区二区网址| 欧美~级网站不卡| 亚洲国产精品成人精品| 亚洲影视在线播放| 欧美a一区二区| 国产亚洲一本大道中文在线| 久久一区精品| 国产亚洲成精品久久| 欧美日韩123| 午夜亚洲伦理| 欧美一区二区福利在线| 欧美一区深夜视频| 亚洲国产婷婷香蕉久久久久久| 黑丝一区二区| 在线视频免费在线观看一区二区| 日韩网站在线观看| 欧美专区中文字幕| 久久大逼视频| 极品尤物一区二区三区| 久久免费视频一区| 久久影院亚洲| 亚洲精品视频在线观看网站| 尤物在线精品| 葵司免费一区二区三区四区五区| 亚洲专区一区| 乱中年女人伦av一区二区| 国产欧美日韩不卡| 99综合电影在线视频| 欧美色欧美亚洲另类二区| 国产精品国产三级国产普通话蜜臀| 亚洲美女少妇无套啪啪呻吟| 亚洲精品乱码久久久久久| 国产麻豆精品在线观看| 欧美精品在线免费| 在线视频欧美日韩精品| 99在线精品视频在线观看| 亚洲午夜高清视频| 黑人极品videos精品欧美裸| 羞羞答答国产精品www一本| 精品不卡一区二区三区| 中日韩在线视频| 在线精品视频免费观看| 国产视频精品xxxx| 欧美日韩日日骚| 一本色道久久综合狠狠躁篇怎么玩| 欧美亚洲尤物久久| 国产日韩av在线播放| 久久婷婷国产综合精品青草| 欧美韩日一区二区三区| 国产麻豆成人精品| 9l国产精品久久久久麻豆| 国模吧视频一区| 欧美国产精品中文字幕| 欧美吻胸吃奶大尺度电影| 欧美美女福利视频| 久久精品一区二区三区中文字幕| 免播放器亚洲一区| 激情婷婷亚洲| 国产日韩欧美高清免费| 久久人人爽国产| 性欧美1819性猛交| 久久aⅴ乱码一区二区三区| 美女性感视频久久久| 久久国产一二区| 国产一区二区三区在线免费观看| 一区二区三区国产在线观看| 国产主播一区二区三区四区| 久久理论片午夜琪琪电影网| 快she精品国产999| 久久久久久久999精品视频| 9l视频自拍蝌蚪9l视频成人| 国产欧美一区二区三区在线看蜜臀| 欧美日韩高清在线| 免费在线欧美视频| 久久深夜福利| 亚洲欧美精品一区| 欧美日韩黄色一区二区| 欧美人与性禽动交情品| 国产精品av久久久久久麻豆网| 久久精品视频99| 久久成人亚洲| 亚洲国语精品自产拍在线观看| 亚洲美女在线观看| 精品不卡视频| 久久婷婷人人澡人人喊人人爽| 欧美日韩一区二区在线播放| 欧美黑人国产人伦爽爽爽| 亚洲在线成人| 久久不射中文字幕| 午夜精品福利一区二区三区av| 亚洲国产三级| 亚洲图片你懂的| 日韩亚洲视频| 亚洲婷婷国产精品电影人久久| 欧美刺激性大交免费视频| 亚洲主播在线| 一区二区免费在线视频| 亚洲精品一区二区三区福利| 亚洲欧美日韩一区| 国产精品揄拍500视频| 亚洲日本乱码在线观看| 国产一区二区三区电影在线观看| 国产免费成人av| 久久久无码精品亚洲日韩按摩| 欧美一区二区三区在| 欧美在线视频二区| 夜夜嗨av一区二区三区网站四季av| 久久久久久伊人| 欧美日韩999| 欧美亚洲综合另类| 午夜精品久久99蜜桃的功能介绍| 香港久久久电影| 亚洲欧洲在线免费| 久久综合一区二区| 亚洲国产精品专区久久| 先锋亚洲精品| 狼狼综合久久久久综合网| 国产无遮挡一区二区三区毛片日本| 欧美乱妇高清无乱码| 日韩亚洲欧美精品| 国产日韩综合一区二区性色av| 欧美视频精品在线| 欧美日韩亚洲视频| 欧美一区二区免费| 亚洲人成在线播放网站岛国| 亚洲精一区二区三区| 久久综合狠狠综合久久综青草| 久久野战av| 国产九色精品成人porny| 精品成人久久| 欧美在线视频观看| 国产欧美日韩免费看aⅴ视频| 久久久99国产精品免费| 亚洲色无码播放| 亚洲伦理一区| 久久影视精品| 国产精品久久国产愉拍| 久久亚洲一区二区| 久久成人综合视频| 欧美日韩国产成人| 久久欧美肥婆一二区| 日韩亚洲在线观看| 亚洲国产一二三| 韩国av一区二区三区| 欧美一区二区三区在线| 欧美α欧美αv大片| 一色屋精品视频在线观看网站| 午夜免费在线观看精品视频| 欧美精品免费看| 欧美激情1区2区3区| 亚洲人久久久| 樱桃国产成人精品视频| 亚洲欧美一区二区在线观看| 亚洲精品国产品国语在线app| 一本色道久久99精品综合| 国产精品你懂的| 欧美精品午夜视频| 欧美日韩视频免费播放| 亚洲天堂男人| 亚洲欧洲av一区二区三区久久| 在线亚洲电影| 欧美黑人一区二区三区| 免费日韩一区二区| 久久久免费精品| 欧美午夜国产| 亚洲激情在线观看| 久久手机免费观看| 亚洲免费网站| 欧美激情亚洲一区| 一区二区三区四区在线| 亚洲区一区二区三区| 午夜日韩在线观看| 亚洲视频二区| 国产精品va在线播放我和闺蜜| 亚洲国产欧美日韩精品| 欧美日韩视频专区在线播放| 国产精品国色综合久久| 国产在线精品成人一区二区三区| 欧美视频一区二区在线观看| 在线免费观看视频一区| 亚洲第一区在线| 亚洲欧美一区二区三区极速播放| 国产精品一国产精品k频道56| 欧美日本在线一区| 久久视频在线免费观看| 国产喷白浆一区二区三区| 国产精品国产三级国产专播精品人| 国产精品二区在线| 亚洲国产日韩综合一区| 国产精品久久久久天堂| 欧美国产日韩在线| 狠狠色伊人亚洲综合网站色| 国产一区二区三区高清播放| 久久久亚洲欧洲日产国码αv| 国产精品无码专区在线观看| 午夜亚洲一区| 欧美国产日韩精品| 日韩午夜精品| 国产精品入口| 精品成人免费| 亚洲精品乱码久久久久久| 99成人在线| 欧美久久在线| 国产麻豆一精品一av一免费| 在线日韩电影| 欧美日韩三级视频| 精品96久久久久久中文字幕无| 久久久免费观看视频| 国产自产v一区二区三区c| 国产一区二区高清视频| 久久黄色影院| 欧美岛国激情| 你懂的视频一区二区| 欧美激情一级片一区二区| 国产精品亚发布| 欧美日韩在线直播| 亚洲高清资源综合久久精品| 亚洲成色777777在线观看影院| 亚洲人精品午夜| 欧美三级资源在线| 欧美激情国产精品| 亚洲国产一区在线| 欧美午夜精品| 亚洲清纯自拍| 欧美激情亚洲国产| 久久人人超碰| 欧美一区=区| 欧美成人免费视频| 欧美国产视频在线观看| 欧美一级网站| 精品二区视频| 亚洲精品久久嫩草网站秘色| 久久久久综合一区二区三区| 亚洲国产va精品久久久不卡综合| 久久精品在线视频| 国产酒店精品激情| 欧美日韩免费高清| 伊人成综合网伊人222| 欧美亚洲一区在线| 狠狠色2019综合网| 欧美日韩四区| 久久国产精品久久久久久| 欧美777四色影视在线| 欧美精品乱码久久久久久按摩| 亚洲日本在线观看| 国产农村妇女毛片精品久久莱园子| 欧美成人免费在线| 亚洲网站视频福利| 亚洲午夜一区二区| 午夜伦欧美伦电影理论片| 欧美一级专区免费大片| 日韩视频免费观看| 国产一区二区三区黄| 在线日韩欧美视频| 最近看过的日韩成人| 国产毛片精品国产一区二区三区| 欧美精品一区二区在线播放| 亚洲日韩欧美一区二区在线| 欧美日韩久久久久久| 欧美sm极限捆绑bd| 美女精品自拍一二三四| 狠狠色狠狠色综合日日小说| 欧美电影免费网站| 欧美成人精品一区| 国内不卡一区二区三区| 销魂美女一区二区三区视频在线| 国产日韩欧美一区二区三区在线观看| 国产亚洲女人久久久久毛片| 欧美精品免费在线| 国产日韩欧美在线播放不卡| 久久久久久9999| 欧美日在线观看| 国产精品一区免费在线观看| 欧美日韩中文字幕| 国产精品区一区二区三区| 亚洲高清自拍| 国产精品夜色7777狼人| 欧美在线视频免费| 欧美午夜精品| 欧美日韩一级视频| 国产精品久久久一区二区| 蜜臀va亚洲va欧美va天堂| 影音先锋日韩有码| 激情91久久| 欧美在线视频网站| 欧美黑人在线播放| 国产伦精品一区二区三区视频黑人| 久久看片网站| 亚洲一区二区三区精品在线观看|