欧美在线观看视频网站,亚洲熟妇色自偷自拍另类,啪啪伊人网,中文字幕第13亚洲另类,中文成人久久久久影院免费观看 ,精品人妻人人做人人爽,亚洲a视频

用于機器視覺應用的多核心分布式處理的制作方法

文檔序號:6495046閱讀:424來源:國知局
用于機器視覺應用的多核心分布式處理的制作方法
【專利摘要】設備的實施例包含:第一處理器核心,其上運行有本地代理,所述代理包括本地進程及委托代理;及第二處理器核心,其上運行有遠程代理,所述遠程代理是所述本地代理的實例。共享存儲器耦合到所述第一處理器核心及所述第二處理器核心,其中所述本地代理及所述遠程代理經由所述共享存儲器來通信。揭示并主張其它實施例。
【專利說明】用于機器視覺應用的多核心分布式處理
【技術領域】
[0001]本發(fā)明一般來說涉及數據處理,且明確地說(但非排他地),涉及用于機器視覺應用的多核心分布式處理。
【背景技術】
[0002]使用多個核心的微處理器對于許多應用具有改進的計算速度,但并非所有應用均顯著受益于多核心處理。對于的確受益于多核心實施方案的那些類型的應用,由于需要在核心之間進行通信及協調,因此所需代碼可是復雜的且難以維持的。
[0003]多核心軟件的一個實施方案使用遠程過程調用(RPC)來在核心當中進行通信及協調,但此方法具有一些缺點,明顯地,客戶端及服務器核心實施RPC所需的相關聯額外開銷及軟件復雜度。RPC層的實施方案涉及:將代碼分到兩個處理器或核心上,所述兩個處理器或核心中的一者稱為客戶端及另一者稱為服務器;及提供用以透明地連接客戶端與服務器之間的功能調用的層。此涉及兩個核心上的RPC模塊且不提供可易于維持或升級的架構。此外,數據在核心之間的傳送可消耗處理時間及存儲器帶寬。最后,在大部分RPC實施方案中,不存在客戶端主動參與由服務器提供的處理的規(guī)定,此意味著處理完全授權給服務器或遠程例程。

【發(fā)明內容】
【專利附圖】

【附圖說明】
[0004]參照以下各圖描述本發(fā)明的非限制性及非窮盡性實施例,其中除非另有說明,否則各個視圖中的相似元件符號指代相似部件。
[0005]圖1是機器視覺系統(tǒng)的實施例的框圖。
[0006]圖2是多核心處理器的實施例的框圖。
[0007]圖3是多核心處理器的替代實施例的框圖。
[0008]圖4A到4B —起是用于多核心處理器的軟件架構的實施例的框圖。
[0009]圖5是用于實施圖4中所展示的軟件架構的方法的實施例的流程圖。
【具體實施方式】
[0010]描述用于機器視覺應用的多核心分布式處理的系統(tǒng)及方法的實施例。描述眾多特定細節(jié)以提供對本發(fā)明的實施例的透徹理解,但所屬領域的技術人員將認識到,可在不具有所述特定細節(jié)中的一者或一者以上的情況下或借助其它方法、組件、材料等實踐本發(fā)明。在一些例子中,未詳細展示或描述眾所周知的結構、材料或操作,但盡管如此其仍囊括在本發(fā)明的范圍內。
[0011]本說明書通篇所提及的“一個實施例”或“一實施例”意味著結合所述實施例一起所描述的特定特征、結構或特性包含于至少一個所描述實施例中。因此,在本說明書中出現的短語“在一個實施例中”或“在一實施例中”未必全部指代同一實施例。此外,特定特征、結構或特性可以任何適合方式組合于一個或一個以上實施例中。
[0012]圖1圖解說明機器視覺系統(tǒng)100的實施例。系統(tǒng)100包含計算機102,在一個實施例中,所述計算機可是經由總線103耦合到多個機器視覺相機104、106及108的個人計算機(PC)。在一個實施例中,計算機102可另外(舉例來說)經由網絡(例如以太網或因特網)耦合到另一計算機110。在一個實施例中,機器視覺相機104、106及108可是相同種類的相機,但在其它實施例中,并不需要全部是相同種類的相機。機器視覺相機104、106及108可是相機或智能相機的混合,其中區(qū)別在于:相機圖像的處理是在相機自身而非相機連接到的計算機上進行。在仍其它實施例中,系統(tǒng)100可包含比所圖解說明的三個多或少的相機。
[0013]計算機102可包含存儲器、存儲裝置、顯示器及經由其計算機102可與相機104到108或與計算機110通信的通信接口。計算機110可具有類似元件,包含經由其計算機110可與計算機102通信的通信接口。計算機102及110各自包含處理器,所述計算機可使用所述處理器對數據執(zhí)行其與系統(tǒng)中的其它元件(例如機器視覺相機104到108)進行交換的操作或可直接對相機圖像執(zhí)行圖像處理操作。在一個實施例中,計算機102及110各自具有擁有兩個或兩個以上處理器核心(參見,例如,圖2)的多核心處理器。在另一實施例中,計算機102及110可各自具有單核心處理器,但通過使用到計算機110的連接,可使計算機102及110中的單核心處理器一起工作,就好像其是單個多核心處理器(參見,例如,圖3) —樣。在仍其它實施例中,計算機102及110兩者不需要具有相同類型的處理器;舉例來說,一個可具有多核心處理器及另一個可具有單核心處理器。
[0014]在操作中,數據(例如圖像)由機器視覺相機104到108捕獲且經由總線103傳送到計算機102及110中的一者或兩者以供處理??煞峙鋱D像數據(其在一個實施例中可是二維圖像)以取決于處理器在計算機102及110中的配置而以各種方式進行處理。在其中計算機102具有多核心處理器且將被期望進行所有圖像處理的實施例中,可分配個別圖像,其中一個核心處理圖像的一部分且另一個核心處理圖像的另一部分。在另一實施例中,每一核心可對完整圖像執(zhí)行不同處理任務。在其中計算機102及110經耦合以形成多核心處理器(參見,例如,圖3)的實施例中,可類似地分配任務。
[0015]圖2圖解說明多核心處理器200的實施例。處理器200形成于單個襯底202上且包含兩個處理器核心:第一核心A及第二核心B。每一處理器核心包含存儲器高速緩沖存儲器(針對核心A為高速緩沖存儲器A,針對核心B為高速緩沖存儲器B),且兩個處理器經由其相應高速緩沖存儲器耦合到共享存儲器204,所述共享存儲器在所圖解說明實施例中是在板存儲器,但在其它實施例中可在處理器200外部。核心A及B可接著經由其高速緩沖存儲器來讀取數據及將數據寫入到共享存儲器204。每一處理器核心還耦合到其自身核心內總線-針對核心A為核心內總線A及針對核心B為核心內總線B。核心內總線提供相同處理器核心內的元件之間的通信。核心內總線A及B進而耦合到核心問總線206,所述核心問總線提供核心A與核心B之間以及與處理器200外側的其它元件的通信,例如,經由其處理器200可接收及發(fā)射包含來自相機傳感器(舉例來說,來自機器視覺相機)的圖像數據的數據的通信接口。在一個實施例中,處理器200可是同質的,此意味著核心A及B兩者是相同類型的處理器,但在其它實施例中,處理器200可是異質的,此意味著核心A及B是不同類型的核心。舉例來說,在一個異質實施例中,核心A可是高級RISC機器(ARM)核心,而核心B可是數字信號處理器(DSP)核心。此外,處理器200的所圖解說明實施例具有兩個核心,但在其它實施例中,處理器200可具有兩個以上核心。
[0016]在處理器200的操作中,核心A及B各自執(zhí)行致使核心基于在處理器處所接收到的數據起作用的代碼(對象、進程、線程等)。指派給每一核心的處理任務可取決于其中將使用處理器200的應用的本質及將處理的數據的本質而變化。舉例來說,在其中機器視覺系統(tǒng)(例如系統(tǒng)100)中使用處理器200的實施例中,可分配從機器視覺相機所接收到的每一圖像且所述圖像的每一部分由不同核心處理。或者,每一核心可對整個圖像進行不同處理任務或可將每一圖像發(fā)送到其自身核心以使得每一核心對圖像進行完整處理。
[0017]在操作期間,核心A及B經由其相應高速緩沖存儲器而從共享存儲器204讀取及寫入到共享存儲器204。如果核心A及B上運行的任務是獨立的,那么核心A及B可讀取及寫入到共享存儲器204的不同部分(即,不同地址塊),但如果所述任務不是獨立的,那么核心A及B可讀取及寫入到共享存儲器204的相同部分(即,相同存儲器地址塊)?;旧希又攦蓚€核心使用共享存儲器204的相同部分時,共享存儲器可在核心之間提供直接通信通道。在操作期間,具有每一核心的元件可使用處理器核心內的通信通道或使用每一核心的相應處理器內總線通信。如果在操作期間需要核心A與B之間的通信,那么核心還可經由核心問總線206來通信。
[0018]圖3圖解說明多核心處理器300的替代實施例。與處理器200不同,處理器300不形成于單個襯底上,而是包含經耦合以使得其一起形成多核心處理器的一對單獨單核心處理器。于是,在多核心處理器300中,每一單獨單核心處理器被視為一個處理器核心。在一個實施例中,處理器300可是同質的,此意味著處理器A及B兩者是相同類型的處理器,但在其它實施例中,處理器A及B可是不同類型的處理器。舉例來說,在一個實施例中,處理器A可是高級RISC機器(ARM)核心,而處理器B可是數字信號處理器(DSP)核心。此外,處理器300的所圖解說明實施例具有兩個核心(處理器),但在其它實施例中,處理器300可具有兩個以上核心。在另外其它實施例中,處理器A及B兩者不需要具有相同數目個核心;舉例來說,一個可為多核心處理器及另一個可為單核心處理器。
[0019]多核心處理器300包含兩個處理器核心:第一處理器A為第一處理器核心及第二處理器B為第二處理器核心。每一處理器包含存儲器高速緩沖存儲器-針對處理器A為高速緩沖存儲器A及針對處理器B為高速緩沖存儲器B。處理器A經由其相應高速緩沖存儲器耦合到存儲器302,及處理器B經由其相應高速緩沖存儲器耦合到存儲器304。每一處理器還耦合到其自身核心內總線-針對處理器A為核心內總線A及針對處理器B為核心內總線B。核心內總線提供相同處理器內的元件之間的通信。核心內總線A及B進而耦合到對應通信接口 -針對處理器A為接口 306及針對處理器B為接口 308。通信接口使用某一種類的通信協議使得能夠經由通信路徑301在處理器A與處理器B之間進行通信。在一個實施例中,通信路徑301可是硬連線連接,但在其它實施例中,其可是無線連接且在另外其它實施例中,其可是硬連線與無線連接的某一組合。在不同實施例中,通信接口 306及308以及通信路徑301所使用的通信協議可是以太網、TCP / IP或某一其它通信協議。
[0020]在處理器300的操作中,處理器A及B各自執(zhí)行致使核心基于數據起作用的代碼(對象、進程、線程等)。指派給每一核心的任務可取決于處理器A及B的類型、其中將使用處理器300的應用的本質及將處理的數據的本質而變化。舉例來說,在其中機器視覺系統(tǒng)(例如系統(tǒng)100)中使用處理器300的實施例中,可分配從機器視覺相機所接收到的每一圖像且所述圖像的每一部分由不同處理器處理。或者,每一核心可對整個圖像進行不同處理任務或可將每一圖像發(fā)送到其自身核心以使得每一核心對圖像進行完整處理。
[0021]在操作期間,如果處理器A及B上運行的任務是獨立的,那么核心A及B可讀取及寫入到其自身相應存儲器302及304,但如果存在數據相關性,那么可設置處理器300,因此處理器A及B可讀取及寫入到共享存儲器。在一個實施例中,共享存儲器可是現有存儲器302或304中的一者,在此情形中,一個處理器讀取及寫入到其自身存儲器及另一個處理器經由通信路徑301從所述相同存儲器讀取及寫入。在另一實施例中,第三存儲器(未展示)可用作共享存儲器,以使得核心A及B兩者將均經由通信鏈路(例如通信鏈路301)從共享存儲器讀取及寫入。在操作期間,處理器A及B中的每一者內的元件可使用處理器核心內的通道或使用每一核心的相應處理器內總線來通信。
[0022]圖4A到4B —起圖解說明可用于多核心處理器(例如多核心處理器200及300)中的軟件架構400的實施例。軟件架構400實施于一對處理器核心上:核心A(圖4A中所展示),其將稱為本地或客戶端核心;及核心B (圖4B中所展示),其將稱為遠程或服務器核心。所圖解說明實施例展示雙核心處理器(例如處理器200)的架構,但在其它實施例中,所述架構可擴展到任何數目個處理器且在仍其它實施例中,其可適合于在多核心處理器(例如處理器300)上起作用。
[0023]核心A包含核心內通信總線402,而核心B包含核心內通信總線406。所述核心內通信總線可用于相同核心中的元件之間的通信。核心內通信總線402及406兩者進而耦合到核心問總線404,所述核心問總線可用于核心A與核心B之間的通信。在所圖解說明實施例中,用于核心內通信總線402及406以及核心問通信總線404的傳輸協議是由美國加利福尼亞州阿拉米達市的風河系統(tǒng)公司(Wind River Systems of Alameda,California,USA)開發(fā)的vxWorks操作系統(tǒng)的多操作系統(tǒng)進程問通信(MIPC)協議。風河系統(tǒng)公司現在是加利福尼亞州圣克拉拉市的英特爾公司(Intel Corporation of Santa Clara,California)的一部分。在其它實施例中,可使用其它通信協議。
[0024]每一核心內通信總線包含完成核心之間的連接的N個端口。在不同實施例中,可針對特定任務指派不同端口。舉例來說,在機器視覺系統(tǒng)的實施例中,端口可經指派如下:
[0025]端口功能
[0026]端口 O: 未使用。
[0027]端口 1: 主要(在處理器/核心B上運行最高優(yōu)先權的線程)。
[0028]端口 2: 圖像獲取。
[0029]端口 3到η:視覺代理分布式處理。
[0030]一旦在核心之間建立MIPC端口連接,其將永遠不會實際上斷開。而是,如果移除使用所述端口的任務,那么所述端口將變得可由另一任務加以使用。在一個實施例中,所述端口狀態(tài)經定義如下:
[0031]非作用: 尚未建立核心之間的端口連接。
[0032]經連接: 已建立核心之間的端口連接,但所述端口是可用的。
[0033]作用:所建立的端口連接及端口當前在使用中。[0034]在核心A內正運行各種進程,包含本地代理408及本地數據管理進程418。在核心A內還運行主要傳輸代理414及客戶端傳輸代理416。本地代理408是處理數據的代理;在架構400的機器視覺實施例中,本地代理408將是處理來自機器視覺相機的圖像數據的代碼。本地代理408包含本地進程412及委托代理410。本地進程412處置由核心A上的本地代理408實施的本地處理,而委托代理410將處理請求傳送到核心B上運行的遠程代理420。在一個實施例中,委托代理410可提供與遠程代理420相同的接口且將把操作請求中的一些操作請求傳送到所述遠程代理同時仍為自身保留一些操作請求。
[0035]本地數據管理進程418在架構400的操作期間讀取及寫入到共享存儲器(參見圖
2)。在一個實施例中,數據管理進程418使用數據類型類別,所述數據類型類別使用重定向的指針邏輯提供讀取及寫入到存儲器的能力,以使得其為核心提供用以重定向數據流以使得代理將寫入/更新用于適當處理器核心的數據的方法。此允許本地代理408及遠程代理420就好像其是步驟客戶端(step client)所觀看到的一個代理一樣起作用。此還允許兩個代理彼此透明地讀取及寫入數據,就好像存在數據的單個副本一樣,對于單核心實施方案也將是此情形。此通過利用將用作本地及遠程代理本機類型的基類的數據參考模板類別而實現。本地數據管理進程418還管理核心A上的高速緩沖存儲器的高速緩沖存儲器相干性,從而取決于數據流方向而提供高速緩沖存儲器失效指令及高速緩沖存儲器刷新指令。
[0036]在一個實施例中,本地數據管理進程418使用重定向的指針邏輯,其中委托代理410將參考到遠程代理數據位置的點使輸入類型指針重定向且遠程代理將參考本地代理數據位置使輸出類型指針重定向。借助重定向的指針邏輯,本地代理及遠程代理兩者均寫入到共享存儲器中的與遠程數據管理進程428相同的存儲器地址框,以使得共享存儲器提供核心之間的運行時通信且不需要在核心之間傳送數據,從而允許簡化且快速進程。
[0037]主要傳輸進程414及客戶端傳輸進程416處置核心A上運行的進程當中的通信以及核心A上的進程與核心B上或(總的來說)所述處理器外的特定進程之間的通信。主要傳輸進程414與核心內總線402的主要端口且與客戶端傳輸進程416進行通信??蛻舳藗鬏斶M程416進而與主要傳輸進程414、核心內總線402的代理端口及委托代理410通信。
[0038]核心B運行大致反映核心A中運行的進程的各種進程。在一個實施例中,所有進程可由任一核心執(zhí)行,因此存在可在任一核心上實例化或建構的所有軟件對象及方法的兩個版本。核心B中運行的進程包含遠程代理420及遠程數據管理進程428。核心B內還運行主要傳輸代理422及服務器傳輸代理424。遠程代理420是處理數據的代理;在架構400的機器視覺實施例中,遠程代理420將是處理來自機器視覺相機的圖像數據的代碼。遠程代理420包括與本地代理408大致相同的代碼,且在運行時,大致是本地代理408的另一實例,只不過遠程代理420不引發(fā)像本地進程412的本地進程。
[0039]類似于核心A,核心B運行遠程數據管理進程428。與遠程代理420 —樣,遠程數據管理進程428包括與本地數據管理進程418大致相同的代碼,且在運行時,是本地數據管理進程418的大致另一實例。遠程數據管理進程428還管理核心B上的高速緩沖存儲器的高速緩沖存儲器相干性,從而取決于數據流方向而提供高速緩沖存儲器失效指令及高速緩沖存儲器清除指令。在一個實施例中,如上文所描述,遠程數據管理進程428使用重定向的指針邏輯且寫入到共享存儲器中的與本地數據管理進程418相同的存儲器地址塊,以使得共享存儲器提供核心之間的運行時通信。[0040]主要傳輸進程422及服務器傳輸進程424可處置核心B上運行的進程之間的通信,以及核心B上的進程與核心A上或其它地方的進程之間的通信。主要傳輸進程422與核心內總線406的主要端口且與客戶端傳輸進程424進行通信。服務器傳輸進程424進而與主要傳輸進程422、核心內總線406的代理端口及遠程代理420通信。在一個實施例中,所述傳輸進程在如下期間使用:在于核心B上設置遠程進程期間以及在起始遠程代理420處理及在完成后旋即將結束信號發(fā)射到委托代理410,使得共享存儲器作為核心之間的運行時通信的主要構件期間。
[0041]在架構400的操作中,首先在核心A及B中設置相關進程(參見圖5)。核心A經由適當進程來接收相關數據(舉例來說,來自機器視覺相機的圖像數據)并將所述數據儲存于共享存儲器(參見,例如,圖2)中。本地代理408開始其處理共享存儲器中的數據的部分且致使委托代理410將Go命令經由核心內總線及核心問總線發(fā)射到遠程代理420,從而致使遠程代理428也開始其處理共享存儲器中的數據的部分。在一個實施例中,在委托代理410發(fā)射Go命令之后,本地代理及遠程代理在完成處理之前不具有經由核心內總線及核心問總線的進一步通信,當遠程代理428將結束信號發(fā)送到委托代理410時,替代地,使用本地數據管理進程418及遠程數據管理進程428主要地或排他地經由共享存儲器來通信。如上文所論述,為實現此通信,本地及遠程數據管理進程從共享存儲器內的相同存儲器地址框讀取及寫入,且在一個實施例中,其使用重定向的指針邏輯進行此。
[0042]當遠程代理420已完成其任務時,遠程代理420通過經由核心內總線及核心問總線將結束信號發(fā)送到委托代理410而用信號通知完成。遠程代理420接著進入等待狀態(tài)且如果需要進一步處理及在需要進一步處理時,等待來自委托代理的進一步Go命令。當遠程代理420及本地代理408兩者已完成其處理時,經處理數據可從共享存儲器讀取且發(fā)射到其它地方以供顯示、存儲或進一步處理。
[0043]圖5圖解說明用于實施圖4A到4B中所圖解說明的軟件架構的方法的實施例。在框502處,所述方法開始。在框504處,所述方法利用委托代理410確定將創(chuàng)建的本地代理408是本地進程412還是分布式進程。如果將在本地執(zhí)行所述方法,那么使用核心A中的本地進程412建構或導出本地代理408。如果所述方法將是分布式的,那么使用核心A中的委托代理410建構或導出本地代理408。在框508處,實例化本地數據管理進程418,且在框510處,實例化主要傳輸進程414。
[0044]在框512中,所述方法核對是否將執(zhí)行多核心處理。如果將不執(zhí)行多核心處理,那么所述方法轉到框514,其中使用框514中運行的進程而發(fā)生所有處理。如果將發(fā)生多核心處理,那么在框516處,在核心A中實例化本地客戶端傳輸進程416,且在框518處,客戶端傳輸進程416使用核心內總線402及406以及核心問總線404實例化核心B中的線程以接收連接請求。在框520處,客戶端傳輸進程416將連接請求發(fā)送到核心B。
[0045]在框522處,所述方法在接收來自本地代理408的請求后旋即實例化核心B中的主要傳輸進程422,及主要傳輸進程422接著實例化服務器傳輸進程424。在框524處,月艮務器傳輸進程424引發(fā)任務線程426,且在框526中,建構遠程代理420。在框528處,建構遠程數據管理進程428。
[0046]在框530處,在開始所有所需進程之后,遠程代理420將接收請求發(fā)射到本地委托代理410以告知委托代理其已準備就緒。在框532處,遠程代理420等待接收來自本地委托代理410的Go命令以告知其開始處理。在框534處,所述方法核對是否已接收Go命令。如果其不使所述方法返回到框532,那么否則所述方法轉到框536,其中多核心處理開始。
[0047]當經由提供重定向指針的能力的數據類型類別來管理數據流時,所揭示的本發(fā)明的實施例提供軟件模型,所述軟件模型提供處理核心之間的最小數據傳送。另外,兩個核心均含有視覺處理軟件,其中一者具有委托實施方案及另一者具有遠程實施方案。此允許兩個處理器使用相同代碼基及具有與遠程過程調用(RPC)層相關聯的最小代碼額外開銷。與大部分RPC實施方案相反,本地及遠程對象兩者主動參與處理,因此顯然地充當到其它對象的客戶端及服務器兩者。由于可復制架構,因此添加新的分布式視覺處理任務是件簡單的事情。此外,此架構可(舉例來說)經由以太網網絡擴展到不與客戶端共享相同的存儲器地址空間的遠程架構。
[0048]包含發(fā)明摘要中所描述的內容的本發(fā)明的所圖解說明實施例的以上說明并非打算為窮盡性的或將本發(fā)明限于所揭示的確切形式。雖然出于說明性目的而在本文中描述本發(fā)明的特定實施例及實例,但如所屬領域的技術人員將認識到,可在本發(fā)明的范圍內做出各種等效修改??筛鶕陨显敿氄f明對本發(fā)明做出這些修改。
[0049]所附權利要求書中使用的術語不應理解為將本發(fā)明限制于說明書及權利要求書中所揭示的特定實施例。而是,本發(fā)明的范圍將完全由所附權利要求書來確定,所附權利要求書將根據權利要求闡述的既定原則來加以理解。
【權利要求】
1.一種設備,其包括: 第一處理器核心,其上運行有本地代理,所述本地代理包括本地進程及委托代理; 第二處理器核心,其上運行有遠程代理,所述遠程代理是所述本地代理的實例 '及共享存儲器,其耦合到所述第一處理器核心及所述第二處理器核心,其中本地處理代理及遠程處理代理經由所述共享存儲器來通信。
2.根據權利要求1所述的設備,其進一步包括所述第一處理器核心與所述第二處理器核心之間的通信鏈路。
3.根據權利要求2所述的設備,其中所述通信鏈路是多操作系統(tǒng)進程問通信MIPC傳輸。
4.根據權利要求2所述的設備,其中所述委托代理經由所述通信鏈路來建構所述遠程代理。
5.根據權利要求1所述的設備,其中所述第一處理器核心不同于所述第二處理器核心。
6.根據權利要求5所述的設備,其中所述第一處理器核心是高級RISC機器ARM處理器,且所述第二處理器核心是數字信號處理器DSP。
7.根據權利要求1所述的設備,其中所述第一處理器核心上運行有本地數據管理進程,所述第二處理器核心上運行 有遠程數據管理進程,且所述本地及遠程數據管理進程經由所述共享存儲器來管理數據交換。
8.根據權利要求7所述的設備,其中所述本地及遠程數據管理進程使用重定向的指針邏輯經由所述共享存儲器來管理數據交換。
9.根據權利要求8所述的設備,其中第一及第二數據管理進程從所述共享存儲器中的相同地址空間讀取且寫入到所述共享存儲器中的相同地址空間。
10.根據權利要求7所述的設備,其中所述第一處理器核心包含其高速緩沖存儲器相干性由所述本地數據管理進程管理的第一高速緩沖存儲器,且所述第二處理器核心包含其高速緩沖存儲器相干性由所述遠程數據管理進程管理的第二高速緩沖存儲器。
11.根據權利要求1所述的設備,其中所述共享存儲器是所述第一處理器核心與所述第二處理器核心之間的專用運行時通信構件。
12.—種方法,其包括: 在第一處理器核心上運行本地代理,所述代理包括本地進程及委托代理; 在第二處理器核心上建構遠程代理,所述遠程代理是所述本地代理的實例;及經由耦合到所述第一處理器核心及所述第二處理器核心的共享存儲器在所述本地代理與所述遠程代理之間進行通信。
13.根據權利要求12所述的方法,其進一步包括使用所述第一處理器核心與所述第二處理器核心之間的通信鏈路進行通信。
14.根據權利要求13所述的方法,其中所述通信鏈路是多操作系統(tǒng)進程問通信MIPC傳輸。
15.根據權利要求13所述的方法,其中建構所述遠程代理包括使用所述委托代理經由所述通信鏈路來建構所述遠程代理。
16.根據權利要求12所述的方法,其中所述第一處理器核心不同于所述第二處理器核心。
17.根據權利要求16所述的方法,其中所述第一處理器核心是高級RISC機器ARM處理器,且所述第二處理器核心是數字信號處理器DSP。
18.根據權利要求12所述的方法,其進一步包括: 運行在所述第一處理器核心上運行的本地數據管理進程;及 在所述第二處理器核心上運行遠程數據管理進程,其中所述本地及遠程數據管理進程經由所述共享存儲器來管理通信。
19.根據權利要求18所述的方法,其中所述本地及遠程數據管理進程使用重定向的指針邏輯經由所述共享存儲器來通信。
20.根據權利要求19所述的方法,其中第一及第二數據管理進程從所述共享存儲器中的相同地址空間讀取且寫入到所述共享存儲器中的相同地址空間。
21.根據權利要求18所述的方法,其中所述第一處理器核心包含其高速緩沖存儲器相干性由所述本地數據管理進程管理的第一高速緩沖存儲器,且所述第二處理器核心包含其高速緩沖存儲器相干性由所述遠程數據管理進程管理的第二高速緩沖存儲器。
22.根據權利要求12所述的方法,其中所述共享存儲器是所述第一處理器核心與所述第二處理器核心之間的專用運行時通信`構件。
【文檔編號】G06F15/80GK103493037SQ201280020357
【公開日】2014年1月1日 申請日期:2012年2月29日 優(yōu)先權日:2011年3月16日
【發(fā)明者】丹尼·S·巴爾內斯, 澤格·H·利蒙丹 申請人:邁思肯系統(tǒng)公司
網友詢問留言 已有0條留言
  • 還沒有人留言評論。精彩留言會獲得點贊!
1
卓尼县| 盐城市| 涟水县| 齐齐哈尔市| 望城县| 宝丰县| 娱乐| 石渠县| 依安县| 夏津县| 大方县| 南安市| 神木县| 鄯善县| 澎湖县| 康乐县| 肥东县| 定襄县| 加查县| 株洲县| 遵义县| 德惠市| 满城县| 两当县| 金门县| 安乡县| 巍山| 阿拉善右旗| 西峡县| 白水县| 天祝| 铜川市| 申扎县| 图木舒克市| 东山县| 吉水县| 长垣县| 游戏| 光山县| 桃源县| 衡水市|