JP2007526544A - Communication protocol between processors - Google Patents
Communication protocol between processors Download PDFInfo
- Publication number
- JP2007526544A JP2007526544A JP2006517601A JP2006517601A JP2007526544A JP 2007526544 A JP2007526544 A JP 2007526544A JP 2006517601 A JP2006517601 A JP 2006517601A JP 2006517601 A JP2006517601 A JP 2006517601A JP 2007526544 A JP2007526544 A JP 2007526544A
- Authority
- JP
- Japan
- Prior art keywords
- ipc
- component
- server
- client
- session manager
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/54—Interprogram communication
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/30—Definitions, standards or architectural aspects of layered protocol stacks
- H04L69/32—Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2209/00—Indexing scheme relating to G06F9/00
- G06F2209/54—Indexing scheme relating to G06F9/54
- G06F2209/541—Client-server
Abstract
プロセッサ間通信(IPC)プロトコルネットワークは、少なくとも1つのIPCクライアント(102)とIPCサーバ(108)を含む。IPCプロトコルは、IPCクライアント(102)がIPCサーバ(108)に登録して、ソフトウェア・アーキテクチャ、オペレーティング・システム、ハードウェア等が何であるかという制約を受けずに自由に両者が通信する手段を提供する。本発明の1実施例によるIPCプロトコルは、サーバを基にしたIPC通信管理フレームワークにおいて動的IPCノード構成を提供する。 The inter-processor communication (IPC) protocol network includes at least one IPC client (102) and an IPC server (108). The IPC protocol provides a means for the IPC client (102) to register with the IPC server (108) and freely communicate with each other without being restricted by what software architecture, operating system, hardware, etc. To do. The IPC protocol according to one embodiment of the present invention provides a dynamic IPC node configuration in a server-based IPC communication management framework.
Description
本発明は一般的に電子分野に関し、特には、プロセッサ間通信(IPC)のプロトコル/ネットワークに関する。 The present invention relates generally to the field of electronics, and more particularly to interprocessor communication (IPC) protocols / networks.
ほとんどの電子システムは、システムを形成するハードウェアやソフトウェア等の、多くのネットワーク要素(部品)からなる。ほとんどのシステムにおいて、異なるネットワーク要素それ自身の間と同時に、ネットワーク要素を形成する異なる部品との間の通信に対応する層を有する。この層は一般的にプロセッサ間通信(IPC)と呼ばれる。 Most electronic systems are composed of many network elements (components) such as hardware and software forming the system. Most systems have layers that correspond to communication between different network elements themselves, as well as between the different components that form the network elements. This layer is commonly referred to as interprocessor communication (IPC).
近年、プロセッサ間通信を行う幾つかのプロトコルが導入されている。IPCの一例はPCIAGPコントローラ(PAC)であって、Host‐to‐PCIブリッジ、DRAMコントローラ、およびデータ経路とAccelerated Graphics Port(AGP)インタフェイスを集積する。IPCの別例はOMAP(登録商標)プラットフォームである。これらのプラットフォームではいずれも、すべてのサポートがハードウェアレベル以上の場合は多くの設計自由度を得られず、低レベル部品やチャネルレベル(物理層)では設計自由度はほとんどない。 In recent years, several protocols for performing communication between processors have been introduced. An example of an IPC is a PCIAGP controller (PAC), which integrates a host-to-PCI bridge, a DRAM controller, and a data path and an Accelerated Graphics Port (AGP) interface. Another example of an IPC is the OMAP® platform. In any of these platforms, when all support is above the hardware level, many design degrees of freedom cannot be obtained, and there is almost no degree of design freedom at low-level components and the channel level (physical layer).
例えば、PACプラットフォームは閉構造で、オペレーティング・システムのTAPI層に埋め込まれており、IPCコードは開発者にはアクセスできない。従って、これらのプラットフォームは部品システムには拡張しないので、IPC源の動的割り当てをできないだけでなく、IPC源の動的割り当て、ハードウェア・サポート機能、マルチノード・ルーチングをできない。 For example, the PAC platform is closed and embedded in the TAPI layer of the operating system, and the IPC code is not accessible to developers. Therefore, these platforms do not extend to component systems, so not only cannot dynamically allocate IPC sources, but also cannot dynamically allocate IPC sources, hardware support functions, and multi-node routing.
リアルタイム処理アプリケーション等のアプリケーションにおける1つの問題は、異なるプロセッサ上のサービスの発見及びIPC要求の迅速な処理に対する要件である。これらの状況において、良好なサポートを保証する1つの側面は、無線通信装置における移動体アプリケーション(MA)等の異なるアプリケーションの仕事を埋め合わせ、対象のMAへのデータの送付に先立ち共同処理をサポートすることである。この共同処理サポートには、通常、コプロセッサにIPCデータを輸送し、そして、そのデータを対象のMAに再度ルーチングし得るスマート・ハードウェア・ポートが必要である。良好なサポートを保証するもう1つの側面は、専用リンク(ポート)を用いて、異なるMA上のソフトウェア・コンポーネントに特定のソフトウェアサービスを搬送することによる。今日、これらの方法は、動的でもなく、実行時設定可能でもない。従って、以上のことから、従来技術におけるこれら幾つかの欠点に対する解決策を提供し得るIPCプロトコルに対するニーズが、当分野に存在する。 One problem in applications such as real-time processing applications is the requirement for service discovery on different processors and rapid processing of IPC requests. In these situations, one aspect of ensuring good support is to make up for the work of different applications, such as mobile applications (MA) in wireless communication devices, and support collaborative processing prior to sending data to the target MA. That is. This co-processing support usually requires a smart hardware port that can transport IPC data to the coprocessor and re-route that data back to the target MA. Another aspect of ensuring good support is by carrying specific software services to software components on different MAs using dedicated links (ports). Today, these methods are neither dynamic nor run-time configurable. Thus, there is a need in the art for an IPC protocol that can provide a solution to some of these shortcomings in the prior art.
本発明の特徴は、詳細に添付の請求項に記載されている。本発明は、添付図面を併用して行われる以下の説明を参照すると最も良く理解し得る。図面の幾つかの図では、同様な参照数字は、同様な要素を表す。 The features of the invention are set forth with particularity in the appended claims. The invention may best be understood with reference to the following description, taken in conjunction with the accompanying drawings. In the several figures of the drawings, like reference numerals represent like elements.
本明細書は、本発明の特徴を定める請求項で終わるが、本発明は、図面の図と共に以下の説明を考察すると、理解が深まると思われる。
IPCは、システムにおいて動作する異なるプロセッサが互いに通信を行うために必要なサポートを提供する。例えば、アプリケーションプロセッサ(AP)及びベースバンドプロセッサ(BP)が含まれる無線通信装置に用いる二重プロセッサ(又は多重プロセッサ)無線アーキテクチャにおいて、IPCは、プロセッサが互いに効率的に通信を行うために必要なサポートを提供する。IPCは、AP又はBPの設計に何らかの制約を課すことなく、このサポートを提供する。
While the specification concludes with the claims that characterize the invention, the invention will become better understood when the following description is considered in conjunction with the drawings.
IPC provides the support necessary for different processors operating in the system to communicate with each other. For example, in a dual processor (or multiprocessor) wireless architecture used in a wireless communication device that includes an application processor (AP) and a baseband processor (BP), the IPC is necessary for the processors to communicate efficiently with each other. Provide support. The IPC provides this support without imposing any restrictions on the AP or BP design.
IPCをそのプロセッサ間通信スタックとして採用するあらゆるプロセッサは、IPCにより、その2つが、共通のオペレーティング・システム及びメモリを共有する同じプロセッサコア上で実際に動作しているかの如く共存し動作し得る。通信装置において複数のプロセッサを用いることが標準になりつつある中で、IPCは、異なるプロセッサ間において信頼性の高い通信を提供する。 Any processor that employs IPC as its interprocessor communication stack can coexist and operate as if the two are actually running on the same processor core sharing a common operating system and memory. As the use of multiple processors in a communication device is becoming standard, IPC provides reliable communication between different processors.
IPCハードウェアは、異なるプロセッサをIPCネットワークに接続する物理接続を提供する。本発明の一実施形態において、データパケットは、好適には、異なるホスト間において非同期的に輸送される。IPCネットワークに接続されるプロセッサは、それらの物理及び論理アドレスが、静的に又は動的に割り当てられる(例えば、IPCアドレス)。また、データパケットは、本発明の一実施形態におけるIPCネットワーク内で任意の方向に流れ得ることから、パケットは、それらが到達しようとしているプロセッサの宛先アドレスを搬送する必要がある。また、好適には、パケットは、従来の周期的冗長検査(CRC)手法を用いて、エラーが無いかチェックされる。本発明のIPCネットワークのネットワークアクティビティは、伝送制御プロトコル/インターネットプロトコル(TCP/IP)ネットワーク等のIP輸送層を用いるインターネット・ネットワーク上に存在するものとある程度類似し得るが、本発明のIPCは、TCP/IPネットワークのようにゲートウェイにより小規模なネットワークに分割されない。 IPC hardware provides a physical connection that connects different processors to the IPC network. In one embodiment of the invention, data packets are preferably transported asynchronously between different hosts. Processors connected to the IPC network are assigned their physical and logical addresses statically or dynamically (eg, IPC addresses). Also, since data packets can flow in any direction within the IPC network in one embodiment of the present invention, the packets need to carry the destination address of the processor that they are trying to reach. Also preferably, the packet is checked for errors using conventional cyclic redundancy check (CRC) techniques. Although the network activity of the IPC network of the present invention may be somewhat similar to that present on an Internet network using an IP transport layer such as a Transmission Control Protocol / Internet Protocol (TCP / IP) network, the IPC of the present invention It is not divided into small networks by gateways like TCP / IP networks.
次に、図1において、本発明の実施形態に基づくIPCネットワーク100を示す。IPCネットワーク100には、複数のIPCクライアント102-106及び、幾つかの実例として、共有メモリ110、ユニバーサル非同期受信機/送信機(UART)112及びユニバーサル・シリアル・バス(USB)114等の異なるIPC物理リンクを用いて、IPCクライアント102-106に接続されたIPCサーバ108が含まれる。本発明のIPCにより、IPCクライアント102-106は、現IPCサーバ108と折衝して役割を交替し得ることに留意されたい。IPCクライアント102-106が、IPCサーバになるように折衝して新しいIPCサーバになる場合、残りの全てのIPCクライアントは、IPCサーバの変更があった場合、サーバのIPアドレスを変更するように指示される。
Next, in FIG. 1, an
図2において、本発明の実施形態に基づくIPCサーバ108(又はIPCクライアント102-108)のIPCスタック200を示す。IPCスタック200は、オペレーティングシステム(OS)の下で一体化されるように、また、コンポーネントトラフィックのプロセッサ間通信ニーズにサポートを提供するように設計されている。IPCスタックは、次の3つの主な層から構成される。即ち、
(1)IPCプレゼンテーション・マネージャ(202):この層は、異なるシステムコンポーネント(例えば、ソフトウェア・スレッド)間において異なるデータタイプを変換するために用いられる。
In FIG. 2, an
(1) IPC Presentation Manager (202): This layer is used to convert different data types between different system components (eg, software threads).
(2)IPCセッション・マネージャ(204):この層は、IPCスタックと全システムコンポーネントとの間における全着信/発信IPCトラフィック用の中央リポジトリである。IPCセッション・マネージャ204は、幾つかの機能を有する。即ち、IPCコンポーネントを参加させるためのコンポーネントIDの割当て;IPCデータを隠蔽する必要があるかどうかの判断;IPCデータのルーチング、IPCトラフィックの終止;IPCプロセッサ用のプレースホルダ;IPCアドレスの提供、IPCクライアントの割当及び認証等を有する。
(2) IPC Session Manager (204): This layer is a central repository for all incoming / outgoing IPC traffic between the IPC stack and all system components. The
IPCトランスポート層(208):IPCセッション・マネージャ(層)204内に配置される。IPCトランスポート層208は、異なるプロセッサ間において、IPCデータを輸送する目的のために、極めて基本的な周期的冗長検査を行う。更に、IPCトランスポート層208は、IPCメッセージを、IPCネットワーク100上のそれらの最終宛先にルーチングする役割を担う。トランスポート層のルーチング機能は、IPCサーバ上でのみ使用可能である。
IPC Transport Layer (208): Located in the IPC Session Manager (Layer) 204. The
IPCルータブロック(210):宛先コンポーネント(図示せず)にIPCデータを輸送する。着信IPCメッセージは、とりわけ、音声及びモデム等の発生元コンポーネントID、IPCメッセージOPコードを搬送する。本発明の実施形態によれば、固有のOPコードが、IPCネットワークに接続された音声及びモデム等の各コンポーネント/ソフトウェア・スレッドに割り当てられることに留意されたい(例えば、図5の502参照)。IPCセッション・マネージャ204は、ルータブロック210に依拠して、IPCデータを正しいコンポーネント(1つ又は複数)に送る。
IPC router block (210): Transports IPC data to a destination component (not shown). The incoming IPC message carries, among other things, the origin component ID, such as voice and modem, and the IPC message OP code. Note that according to embodiments of the present invention, a unique OP code is assigned to each component / software thread such as voice and modem connected to the IPC network (see, eg, 502 in FIG. 5). The
(3)デバイス・インターフェイス層(206):IPC物理対論理IPCチャネルを管理する役割を果たす。その主な機能は、スタックIPCがハードウェアに依存しなくなるように、IPCハードウェアを完全に抽出することである。デバイス・インターフェイス層206は、直下のIPCリンクの物理帯域幅を管理して全IPC論理チャネルをサポートする。着信経路において、デバイス・インターフェイス層206は、異なる物理チャネル110-114からデータを傍受して、それらを残りのIPCスタックに渡す。発信経路上では、デバイス・インターフェイス層206は、IPC論理チャネルのデータローディングを、それらを適切な物理チャネル上に送ることによって管理する。また、デバイス・インターフェイス層206は、同じIPCチャネルに属するIPCパケットの連結を行い、その後、それらをIPCハードウェアに送る。チャネル要件は、IPCセッション・マネージャ204とIPCデバイス・インターフェイス層206との間で事前に折衝される。デバイス・インターフェイス層206は、ハードウェアポートを備え、これは、IPCクライアント102-106とのデバイス・インターフェイスを提供する。
(3) Device interface layer (206): Plays a role in managing the IPC physical-to-logical IPC channel. Its main function is to extract the IPC hardware completely so that the stack IPC is not dependent on the hardware. The
図3において、IPCコンポーネントID割当てルーチンを示す。IPC通信に加わりたい新しいコンポーネントは、いずれも、(例えば、セッション・マネージャ204等の)そのIPCセッション・マネージャから、ステップ302において、IPC識別番号(ID)をまず要求することによって、そうしなければならない。すると、ローカル・セッション・マネージャ(例えば、コンポーネントが接続されているクライアントに配置されたセッション・マネージャ)は、新しいIPCコンポーネントのIPCサーバ・セッション・マネージャを呼出し、ステップ304において、コンポーネントID割当てを行う。本発明の実施形態によれば、コンポーネントIDは、動的であり、セッション・マネージャによって割り当てられる。主なIPCサーバ位置は、最も可能性が高いのは、主AP上である。各IPCノードは、好適には、固有のIPCノードIDを有し、セッション・マネージャは、そのデータベース中に、各関係IPCノード用の以下の情報を保持する。即ち、
IPCノードタイプ:例えば、特定のBP又はAP、無線ローカルエリアネットワーク(WLAN)AP等。
FIG. 3 shows an IPC component ID assignment routine. Any new component that wishes to participate in IPC communication must do so by first requesting an IPC identification number (ID) from its IPC session manager (eg, session manager 204) in
IPC node type: For example, specific BP or AP, wireless local area network (WLAN) AP, etc.
IPCアドレス:IPCノードのIPCアドレス
データタイプ:IPCノードのデータタイプ
OPコードリスト:これは、コンポーネントが申し込んだ全IPCメッセージOPコードのリストである。
IPC address: IPC node IPC address Data type: IPC node data type
OP Code List: This is a list of all IPC message OP codes that the component has applied for.
コンポーネントID:全コンポーネントIDのリスト
次に、図4において、全ての主IPCテーブルと共にIPCスタックを示す。動的ルーチング表402には、ノードタイプ、IPCアドレス/ポート#情報、データタイプ及び申込みリストが含まれる。コンポーネント・ルーチング・テーブル404には、OPコード情報と各特定のOPコードに申し込んだ全てのコンポーネントとをリンクする情報が含まれる。最後に、チャネル資源テーブル406には、物理チャネルIDのリストとの各チャネルIDのリンクが含まれる。
Component ID: List of all component IDs Next, FIG. 4 shows the IPC stack together with all the main IPC tables. The dynamic routing table 402 includes a node type, IPC address / port # information, a data type, and an application list. The component routing table 404 includes information for linking the OP code information and all the components applied for each specific OP code. Finally, the channel resource table 406 includes a link for each channel ID with a list of physical channel IDs.
図5において、本発明の実施形態に基づくIPCスタックが、ソフトウェア・スレッド等(例えば、音声等)のコンポーネントにIPCチャネルを如何に提供するかのブロック図を示す。コンポーネント502は、まず、ステップ504において、IPCチャネルを要求する。図5に示すセッション・マネージャは、定義されたAPIを用いて、ステップ506において、コンポーネントの要求をデバイス層と折衝する。そして、デバイス層(デバイスインターフェイス)は、データチャネル508等のハードウェア資源を要求する。要求に応答して、図5に示すセッション・マネージャは、ステップ510において、要求側にIPCチャネルを与える。次に、コンポーネント502は、割り当てられたチャネル508上でそのデータを送る。そして、デバイス層は、IPCネットワークにデータを転送する。論理から物理チャネルIDへのマッピングは、IPCデバイス・インターフェイスの機能である。
FIG. 5 shows a block diagram of how an IPC stack according to an embodiment of the present invention provides an IPC channel to components such as software threads (eg, voice, etc.). Component 502 first requests an IPC channel in step 504. The session manager shown in FIG. 5 negotiates a component request with the device layer in
次に、図6において、IPCクライアント初期化における第1ステップは、IPCクライアント602とIPCサーバ604との間において、登録要求(ステップ606)を送信することである。そして、IPCサーバ604は、ステップ608において、IPCクライアント602による要求を認証する。この後、IPCアドレスが、IPCクライアントに送信され、ステップ610において登録が完了する。IPCクライアントのセッション・マネージャは、ステップ612において、その動的ルーチング表のコピーをIPCサーバに送る。
Next, in FIG. 6, the first step in IPC client initialization is to send a registration request (step 606) between the
IPCクライアント初期化プロセス時に行われる詳細なステップを図7に示す。クライアント・セッション・マネージャ(セッション(クライアント)としてテーブルに示す)は、ステップ702において、IPCサーバのセッション・マネージャ(セッション(サーバ)としてテーブルに示す)に設定要求を送る。ステップ704において、認証は、IPCサーバのセッション・マネージャによって要求される。そして、IPCクライアントとIPCサーバとの間の認証は、ステップ706で実行される。
The detailed steps performed during the IPC client initialization process are shown in FIG. In
設定要求のパラメータには、ノードタイプ及びデータタイプが含まれる。ステップ702において、設定要求に応答して、セッションサーバは、要求側にIPCアドレスを割り当てる。また、もしなければ、要求側用の動的ルーチング表を設定する。そして、ステップ708において、要求側に設定指示を送る。設定指示パラメータには、サーバのIPCアドレス及びクライアントの新規に割り当てられたIPCアドレスが含まれる。
The parameter of the setting request includes a node type and a data type. In
設定指示の受信に応答して、セッションクライアントに取り付けられたコンポーネントは、クライアントのセッション・マネージャから制御/データを要求し得る。そして、セッションクライアントは、ステップ710において、セッションサーバに設定指示確認メッセージを送る。“設定指示確認”メッセージは、ステップ710における設定指示確認メッセージの受信時、パラメータを有さず、セッションサーバは、新規に設定されたセッションクライアントへのIPCストリームを起動し得る。そして、セッションサーバは、ステップ712及び714において、セッションクライアントに設定更新メッセージを送る。これによって、図7に示す両セッションクライアントは、それらのそれぞれの動的ルーチング表(図示せず)を更新し、ステップ716及び718において、セッションサーバに設定更新確認メッセージを送る。設定更新確認メッセージを受信すると、セッションサーバは、全ての参加したIPCが、更新されたことを確認する。
In response to receiving the setup indication, a component attached to the session client may request control / data from the client's session manager. In
パケットは、IPCセッション・マネージャによって受信される時、送信元コンポーネントID、宛先ID、チャネルID及びBP又はAPのタイプが含まれるデータの形態でやって来る。IPCセッション・マネージャは、宛先IDが挿入されていない場合、宛先コンポーネントIDを付加する。また、IPCセッション・マネージャは、IPCアドレスを挿入する。受信されたメッセージOPコードに基づき宛先IDを発見するのは、IPCセッション・マネージャである。宛先IDは、ルックアップテーブルに基づく。このルックアップテーブルは、コンポーネントが新しいIPCメッセージOPコードに申し込む(例えば、音声コンポーネントが、IPCセッション・マネージャに要求を送信することによって音声メッセージに申し込む)度に、動的に更新される。 When a packet is received by the IPC session manager, it comes in the form of data that includes the source component ID, destination ID, channel ID, and BP or AP type. The IPC session manager adds the destination component ID when the destination ID is not inserted. The IPC session manager also inserts an IPC address. It is the IPC session manager that finds the destination ID based on the received message OP code. The destination ID is based on a lookup table. This lookup table is dynamically updated each time a component subscribes to a new IPC message OP code (eg, a voice component subscribes to a voice message by sending a request to the IPC session manager).
図8において、コンポーネントと本発明の実施形態に基づくそのIPCセッション・マネージャとの間における一般的な宛先ID発見シーケンス時の一連のイベントを示す。ステップ802において、コンポーネントは、その送信元ID(宛先IDはない)、宛先BP又はAPのタイプ、及びヘッダ及びデータが含まれるIPCデータを送る。ステップ804において、IPCセッション・マネージャは、対応する動的ルーチング表を検索し、正しい宛先アドレスを見つけるために、IPCデータヘッダOPコード、及び宛先BP又はAPのタイプを見る。ステップ806において、IPCセッション・マネージャは、コンポーネントのIPCアドレスを挿入し、それをデバイス層に送る。
FIG. 8 shows a series of events during a typical destination ID discovery sequence between a component and its IPC session manager according to an embodiment of the present invention. In
図9において、IPCコンポーネント初期化時に行われる代表的なステップを示す。BPが、図9に示すIPCサーバによって一旦設定されると、コンポーネント902等のコンポーネントは、異なるサービスに申し込み得る。コンポーネントは、ステップ904において、音声や映像等の機能にそれら自体申し込む。そして、コンポーネント申込み情報は、IPCセッション・マネージャに送られ、(IDがまだ割り当てられていない場合)コンポーネントIDの生成が行われ、また、特定のI PCアドレス用動的ルーチング表の生成又は更新が行われる(ステップ906)。ステップ908において、セッション・マネージャは、ステップ906からの情報でIPCサーバを更新する。ステップ908において、更新された動的ルーチング表を受信すると、ステップ912において、更新の確認が、IPCサーバによってIPCクライアントに送信される。サーバが、一旦呼び出されると、新しい動的ルーチング表更新内容は、関係する全プロセッサステップ910に一斉送信される。
FIG. 9 shows typical steps performed when the IPC component is initialized. Once the BP is set by the IPC server shown in FIG. 9, components such as
図10において、同じコンポーネント初期化プロセスを、コンポーネント(クライアント)1002と、クライアント・セッション・マネージャ1004としても知られているセッション(クライアント)と、サーバ・セッション・マネージャ1006としても知られているセッション(サーバ)との間に示す。ステップ1008におけるコンポーネント設定要求は、コンポーネント(クライアント)1002によって送信される。要求に応答して、クライアント・セッション・マネージャ1004は、デバイス層(図示せず)と論理チャネルを取り決める。また、クライアント・セッション・マネージャ1004は、コンポーネントIDを割当て、その動的ルーチング表(図示せず)に新しいOPコードリストを付加する。ステップ1010において、クライアント・セッション・マネージャ1004は、パラメータとして、コンポーネントID及びチャネルIDが含まれる設定応答を送る。設定応答に応じて、コンポーネント(クライアント)1002は、そのID及びチャネルIDをクライアントのセッション・マネージャ1004から受信する。
In FIG. 10, the same component initialization process consists of a component (client) 1002, a session (client), also known as
一旦クライアント・セッション・マネージャ1004が、ステップ1008における設定要求に対して、ステップ1010で返信すると、クライアント・セッション・マネージャ1004は、ステップ1012において、セッションサーバ(サーバ・セッション・マネージャ)1006に設定更新要求を送る。設定更新要求のパラメータは、動的ルーチング表(図示せず)において行われた何らかの新しい変更である。サーバのセッション・マネージャ1006は、そのIPCアドレス用の動的ルーチング表を更新する。そして、ステップ1016において、サーバのセッション・マネージャ1006は、全てのIPCクライアント(図示せず)に設定更新内容を送り、その間、ステップ1014において、クライアントのセッション・マネージャ1004に設定更新指示を送る。サーバのセッション・マネージャ1006は、サーバが、送られた変更でそのルーチングテーブルを更新したことを確認する。
Once the
パラメータ(1つ又は複数)として動的ルーチング表を含むステップ1016の設定更新メッセージにおいて、セッションサーバ1006は、動的ルーチング表を更新し、ステップ1018において、設定更新確認メッセージを送る。そして、サーバは、参加した全IPCが更新されたことを確認する。
In the setting update message of
IPCセッション・マネージャは、着信及び発信IPCパケットのルーチング経路を決定する。発信パケットのルートは、コンポーネントのIPCアドレスによって決定される。宛先アドレスが、ローカルプロセッサのそれであると分かった場合、オペレーティングシステム(OS)へのIPCのマッピングは、セッション・マネージャ内で実行される。宛先アドレスが、ローカルIPCクライアント用であると分かった場合、パケットは、IPCスタックに送られ、更に処理(例えば、隠蔽)される。宛先コンポーネントが、IPCパケットを送信するコンポーネントとして、同じプロセッサ上に配置されている場合、隠蔽は不要であり、パケットは、通常のOSメッセージ呼出し(例えば、マイクロソフト・メッセージ・キュー等)を介して渡されることに留意されたい。このように、コンポーネントは、それらのメッセージ入力方式の修正について心配する必要はない。必要なことは、それらのメッセージ書き込み方法を、むしろOS特有の設計からIPC呼出しに変更することだけである。 The IPC session manager determines the routing path for incoming and outgoing IPC packets. The route of the outgoing packet is determined by the IPC address of the component. If the destination address is found to be that of the local processor, the mapping of the IPC to the operating system (OS) is performed within the session manager. If the destination address is found to be for a local IPC client, the packet is sent to the IPC stack for further processing (eg, concealment). If the destination component is located on the same processor as the component sending the IPC packet, concealment is not required and the packet is passed through a normal OS message call (e.g., Microsoft message queue). Please note. In this way, components do not have to worry about modifying their message input method. All that is required is to change the way they write messages rather from OS-specific design to IPC calls.
着信パケットの場合、メッセージの宛先アドレスが、IPCサーバのものと等しくない場合、着信パケットは、妥当なIPCクライアントにルーチングされる。着信パケットのルーチングは、IPCサーバのセッション・マネージャによって処理される。そうでない場合、メッセージは、コンポーネント宛先IDが、有効なコンポーネントIDに又は0XFFに設定されているかどうかに応じて、正しいコンポーネント又は複数のコンポーネントに転送される。 For incoming packets, if the destination address of the message is not equal to that of the IPC server, the incoming packet is routed to a valid IPC client. Incoming packet routing is handled by the session manager of the IPC server. Otherwise, the message is forwarded to the correct component or components depending on whether the component destination ID is set to a valid component ID or 0XFF.
IPCルータブロック(例えば、図2におけるIPCルータブロック210参照)は、宛先コンポーネントにIPCデータを輸送する。着信IPCメッセージは、とりわけ、発生元コンポーネントID、及び音声やモデム用等のIPCメッセージOPコードを搬送する。IPCセッション・マネージャは、そのコンポーネント・ルーチング・テーブルに依拠して、正しいコンポーネント(1つ又は複数)にIPCデータを送る。動的ルーチング表及びコンポーネント・ルーチング・テーブルは、双方共、IPCサーバ/クライアントによって更新される。
The IPC router block (eg, see
起動時、各コンポーネントは、そのセッション・マネージャにそれ自体登録して、IPCコンポーネントIDを取得しなければならない。更にまた、音声やモデム等の着信IPCメッセージを申し込まなければならない。この情報は、コンポーネント・ルーチング・テーブルに記憶され、IPCセッション・マネージャによって用いられる。 At startup, each component must register itself with its session manager to obtain an IPC component ID. In addition, incoming IPC messages such as voice and modem must be applied. This information is stored in the component routing table and used by the IPC session manager.
図11に示すように、コンポーネント(例えば、ソフトウェア・スレッド)1102が、ステップ1104において、そのデータ要求をIPCセッション・マネージャに送る場合、宛先IPCノード(例えば、BP)についてチェックが行われる。IPCノードが、IPCメッセージOPコードをサポートしない場合、エラー応答が、コンポーネント1102に返される。エラー応答に加えて、IPCセッション・マネージャは、その特定のOPコードを受信し得る全IPCノードの更新内容を返す。メッセージをIPCノード(1つ又は複数)のどれに転送するか判断するのは、コンポーネント次第である。IPCセッション・マネージャ1106は、引き続きIPCヘッダ情報によるデータの隠蔽を行い、その後、そのデータは、セッション・マネージャが、宛先コンポーネントは、ローカルプロセッサではなく、IPCネットワークに配置されていると判断した場合、IPCネットワーク上で送られる。
As shown in FIG. 11, if a component (eg, software thread) 1102 sends its data request to the IPC session manager at step 1104, a check is made for the destination IPC node (eg, BP). If the IPC node does not support the IPC message OP code, an error response is returned to the component 1102. In addition to the error response, the IPC session manager returns updates for all IPC nodes that can receive that particular OP code. It is up to the component to determine to which of the IPC node (s) the message will be forwarded. The
図12において、本発明の実施形態に基づくIPCデータヘッダ1202を示す。このヘッダには、送信元及び宛先IPCアドレス、送信元ポート、IPCルータによって提供された宛先ポート、IPCトランスポートによって提供された長さ及びチェックサム情報、並びにセッション・マネージャによって提供された送信元IPCコンポーネント及び宛先IPCコンポーネントが含まれる。メッセージOPコード、メッセージ長及びIPCデータは、コンポーネント1204によって提供される。
FIG. 12 shows an IPC data header 1202 according to an embodiment of the present invention. This header includes the source and destination IPC addresses, the source port, the destination port provided by the IPC router, the length and checksum information provided by the IPC transport, and the source IPC provided by the session manager. Components and destination IPC components are included. The message OP code, message length, and IPC data are provided by
本発明の実施形態に基づく代表的なIPCデータ要求を図13に示す。ステップ1302において、コンポーネントは、更新要求を送る。好適には、コンポーネント更新パラメータには、ノードタイプ及びOPコードが含まれる。コンポーネントは、その宛先OPコードをサポートするノードタイプを検索する。ノードタイプが0xFFに等しい場合、セッション・マネージャ(図13において、”セッション”として示す)は、引き続き、全ての参加したIPC用の全ノードテーブルにコンポーネント情報を送信する。OPコードフィールドが、0xFFに等しい場合、図13に示すセッション・マネージャは、引き続き、規定されたノードタイプに属するOPコードリストをコンポーネントに送る。他方、OPコードが特定の値を有する場合、セッション・マネージャは、引き続き、ノードタイプが、その特定のOPコードをサポートする又はサポートしないかどうかに対応する真の又は偽の値をコンポーネントに送る。
A representative IPC data request according to an embodiment of the present invention is shown in FIG. In
ステップ1304において、コンポーネント更新指示は、コンポーネントに送られる。ノードタイプが0xFFに等しい場合、ノードテーブルが、コンポーネントに返される。OPコードフィールドが0xFFに等しい場合、OPコードのリストは、コンポーネントに返される。しかしながら、OPコードが特定の値である場合、真の又は偽のメッセージが返される。ステップ1306において、コンポーネントデータ要求が行われる。コンポーネントデータ要求用のパラメータには、ノードタイプ、IPCメッセージOPコード、IPCメッセージデータ、チャネルID及びコンポーネントIDが含まれる。コンポーネントデータ要求において、セッション・マネージャは、ノードタイプをチェックし、OPコードがサポートされるかどうか判断する。ノードタイプがOPコードをサポートしない場合、コンポーネント更新指示は、ステップ1308において送られる。しかしながら、ノードタイプがOPコードをサポートする場合、データ要求が、ステップ1310においてデバイス層に送られる。データ要求パラメータには、IPCメッセージ、チャネルID及びIPCヘッダが含まれる。
In
デバイス層は、チャネルIDに基づき、データ要求メッセージを送るようにスケジュール設定する。デバイス層は、ポート#ヘッダ情報に基づき、IPCハードウェアを選択する。一旦データが投入されると、データ確認メッセージが、1312においてセッション・マネージャに送られる。ステップ1314において、セッション・マネージャは、引き続き、コンポーネントデータ確認メッセージをコンポーネントに送る。コンポーネントは、確認を待ち、その後、更に、IPCメッセージを送信し得る。一旦データ確認が受信されると、コンポーネントは、引き続き、次のIPCメッセージを送信し得る。
The device layer schedules to send a data request message based on the channel ID. The device layer selects IPC hardware based on the port # header information. Once the data is populated, a data confirmation message is sent at 1312 to the session manager. In
ステップ1316において、デバイス層は、IPCメッセージデータ及びIPCヘッダが含まれるデータ指示メッセージを送る。セッション・マネージャは、メッセージの宛先IPCヘッダをチェックし、ローカルIPCアドレスと異なる場合、セッション・マネージャは、正しいIPCノードにメッセージを送る(ルーチングする)。ステップ1310において、セッション・マネージャは、予約チャネルIDと共にデバイス層にデータ要求を送る。セッション・マネージャは、宛先コンポーネントIDをチェックし、それが0xFFに等しい場合、そのOPコードに申し込んだ全コンポーネントにメッセージをルーチングする。ステップ1318において、セッション・マネージャは、コンポーネントデータ指示メッセージを送り、コンポーネントは、IPCデータを受信する。
In
IPCスタックは、全ての関係するIPCノード間での通信のために予約制御チャネルを用いる。起動時、IPCサーバのセッション・マネージャは、このリンクを用いて、IPCクライアントに又はその逆にメッセージを一斉送信する。通常動作時、この制御チャネルは、全てのAPとBP間において制御情報を搬送するために用いられる。 The IPC stack uses a reservation control channel for communication between all relevant IPC nodes. At startup, the session manager of the IPC server uses this link to broadcast a message to the IPC client and vice versa. During normal operation, this control channel is used to carry control information between all APs and BPs.
図14において、IPCスタック(IPCスタック及びIPCスタックサーバとして示す)とIPCハードウェアとの間に配置された制御チャネル1402-1406を示す。また、制御チャネル情報1408は、異なるIPCハードウェア間でデータを送信する時、データパケット1410と共に送信される。IPCクライアントは、初期的には、IPC制御チャネル上でその設定要求を一斉送信する。IPCスタックサーバは、一斉送信を受信し、そのクライアント用のIPCアドレスで応答する。このIPCアドレスは、その特定のプロセッサ(AP又はBP)用の動的ルーチング表に対応付けられる。
In FIG. 14, control channels 1402-1406 arranged between the IPC stack (shown as IPC stack and IPC stack server) and the IPC hardware are shown. Also, the
IPCアプリケーション・プログラム・インターフェイス(API)
以下に、本発明のIPCプロトコル用APIの幾つかを列記する。
1)IPCセッション・マネージャからコンポーネントインターフェイスへ
CreateComponentInst()
IPCセッション・マネージャにコンポーネントデータベースを生成する。コンポーネントデータタイプ(ビッグ・エンディアン対リトル・エンディアン)等の情報及びメッセージOPコードの申込みが、IPCアドレスに属するダイナミック・データ・ルーチング・テーブルにおいて用いられる。
IPC application program interface (API)
Some of the APIs for the IPC protocol of the present invention are listed below.
1) From IPC session manager to component interface
CreateComponentInst ()
Create a component database in the IPC session manager. Information such as component data type (big endian vs. little endian) and message OP code subscription are used in the dynamic data routing table belonging to the IPC address.
OpenChannelKeep()
IPCチャネルを開く。そして、それが利用可能な場合、ChannelGrant()が発行される。チャネルは、CloseChannel()が発行されるまで予約される。コンポーネントは、IPCセッション・マネージャにQoS要求を送る。コンポーネントIDがまだ割り当てられていない場合、IPCチャネルは、それを割り当てる(例えば、ChannelGrant())。
OpenChannelKeep ()
Open the IPC channel. If it is available, ChannelGrant () is issued. The channel is reserved until CloseChannel () is issued. The component sends a QoS request to the IPC session manager. If the component ID has not yet been assigned, the IPC channel assigns it (eg, ChannelGrant ()).
OpenChannel()
IPCチャネルを開く。そして、それが利用可能な場合、ChannelGrant()が発行される。パラメータは、OpenChannelKeep()基本要素に用いられるものと同じである。
OpenChannel ()
Open the IPC channel. If it is available, ChannelGrant () is issued. The parameters are the same as those used for the OpenChannelKeep () basic element.
OpenChannelWThru()
IPCチャネルを開く。そして、それが利用可能な場合、ChannelGrant()が発行される。これは、このチャネル上では、その隠蔽を止めることを意味するチャネル経由の書き込み要求である(例えば、非UDP_AT命令)。
OpenChannelWThru ()
Open the IPC channel. If it is available, ChannelGrant () is issued. This is a write request via the channel which means that the concealment is stopped on this channel (eg non-UDP_AT command).
CloseChanneI()
IPCチャネルを閉じよという要求。コンポーネントは、チャネルをもはや必要としない。そして、資源は、開放される。
CloseChanneI ()
Request to close the IPC channel. The component no longer needs the channel. The resource is then released.
ChannelGrant()
チャネルが要求側に与えられる。チャネルIDは、まだ、それが割り当てられていない場合、IPCセッション・マネージャによって割り当てられる。
ChannelGrant ()
A channel is given to the requester. The channel ID is assigned by the IPC session manager if it is not already assigned.
ChannelError()
チャネルエラーが発生した。チャネルが閉じられ、要求側に通知される。
ChannelDataIndication()
要求側は、チャネルに関するデータを送付すべきであると警告される。このメッセージは、IPCプレゼンテーション・マネージャによって対象のコンポーネントに送信される。これには、制御チャネルデータも含まれる。
ChannelError ()
A channel error has occurred. The channel is closed and the requester is notified.
ChannelDataIndication ()
The requester is warned that data about the channel should be sent. This message is sent to the target component by the IPC presentation manager. This includes control channel data.
DataChannetRequest()
要求側が、開かれたチャネルに関するデータを送りたい。これには、制御チャネルデータも含まれる。
DataChannetRequest ()
The requester wants to send data about the opened channel. This includes control channel data.
ChannelClose()
IPCチャネルを閉じよという要求。チャネル不活動タイマが切れ、タイムアウトに関連するチャネルが閉じられる。これは、チャネルエラーによることもある。
ChannelClose ()
Request to close the IPC channel. The channel inactivity timer expires and the channel associated with the timeout is closed. This may be due to a channel error.
2)IPCセッション・マネージャとIPCデバイス・インターフェイス間
OpenChannel()
論理IPCチャネルを開く。そして、それが利用可能な場合、ChannelGrant()が発行される。IPCセッション・マネージャは、IPCデバイスインターフェイスマネージャにチャネル優先権要求を送る。
2) Between IPC session manager and IPC device interface
OpenChannel ()
Opens a logical IPC channel. If it is available, ChannelGrant () is issued. The IPC session manager sends a channel priority request to the IPC device interface manager.
CloseChannel()
IPC論理チャネルを閉じよという要求。コンポーネントは、もはやチャネルが必要ないと判断する。
CloseChannel ()
Request to close the IPC logical channel. The component determines that the channel is no longer needed.
ChannelGrant()
論理チャネルが、要求側に与えられる。
ChannelError()
チャネルエラーが発生した。(例えば、着信データに関するCRC障害又は物理チャネル障害)
ChannelDataIndication()
要求側は、チャネルに関するデータを送付すべきであると警告される。
ChannelGrant ()
A logical channel is provided to the requester.
ChannelError ()
A channel error has occurred. (For example, CRC failure or physical channel failure for incoming data)
ChannelDataIndication ()
The requester is warned that data about the channel should be sent.
DataChannelRequest()
要求側が、論理チャネルに関するデータを送りたい。
ChannelClose()
IPCチャネルを閉じよという要求。チャネル不活動タイマが切れ、タイムアウトに関連するチャネルが閉じられる。これは、チャネルエラーによることもある。
DataChannelRequest ()
The requester wants to send data about the logical channel.
ChannelClose ()
Request to close the IPC channel. The channel inactivity timer expires and the channel associated with the timeout is closed. This may be due to a channel error.
3)IPCセッション・マネージャからIPCプレゼンテーション・マネージャへ
ChannetDataIndication()
要求側は、チャネルに関するデータを送付すべきであると警告される。情報は、正しいデータフォーマットで対象のコンポーネントに転送される。
3) From IPC session manager to IPC presentation manager
ChannetDataIndication ()
The requester is warned that data about the channel should be sent. Information is transferred to the target component in the correct data format.
4)IPCハードウェア/IPCスタックインターフェイス
OpenChannel()
物理IPCチャネルを開く。そして、それが利用可能な場合、aChannelGrant()が発行される。IPCセッション・マネージャは、IPCハードウェアにチャネル優先権要求を送る。
4) IPC hardware / IPC stack interface
OpenChannel ()
Open physical IPC channel. If it is available, aChannelGrant () is issued. The IPC session manager sends a channel priority request to the IPC hardware.
CloseChannel()
IPC物理チャネルを閉じよという要求。コンポーネントは、もはやチャネルを必要としない。
CloseChannel ()
Request to close the IPC physical channel. The component no longer needs a channel.
ChannelGrant()
物理チャネルが、要求側に与えられる。
ChannelError()
チャネルエラーが発生した(例えば、着信データに関するCRC障害又は物理チャネル障害)。
ChannelGrant ()
A physical channel is provided to the requester.
ChannelError ()
A channel error occurred (eg, CRC failure or physical channel failure for incoming data).
ChannelDataIndication()
要求側は、チャネルに関するデータを送付すべきであると警告される。
DataChannetRequest()
要求側が、物理チャネルに関するデータを送りたい。
ChannelDataIndication ()
The requester is warned that data about the channel should be sent.
DataChannetRequest ()
The requester wants to send data about the physical channel.
ChannelClose()
IPCチャネルを閉じよという要求。チャネル不活動タイマが切れ、タイムアウトに関連するチャネルが閉じられる。これは、チャネルエラーによることもある。
ChannelClose ()
Request to close the IPC channel. The channel inactivity timer expires and the channel associated with the timeout is closed. This may be due to a channel error.
図15において、IPCネットワークを用いて互いに通信を行うベースバンドプロセッサ(BP)1502及びアプリケーションプロセッサ(AP)1504を有する(例えば、携帯電話等)無線通信装置1500等の電子装置のブロック図を示す。本発明のIPCプロトコルは、通信装置1500等のシステム中の複数のプロセッサ間において、通信を提供する。IPCは、専用通信システム(PCS)アプリケーション等のMAサーバへの移動体アプリケーション(MA)クライアント(例えば、iDENTM_WLAN)の登録を可能にし、また、2つのMAが、それ自体のMA内で、どんなソフトウェア・アーキテクチャ、オペレーティング・システム、ハードウェアに各々依存するかという制限を一切伴わず自由に通信するための手段を提供する。
FIG. 15 shows a block diagram of an electronic device such as a wireless communication device 1500 (eg, a mobile phone) having a baseband processor (BP) 1502 and an application processor (AP) 1504 that communicate with each other using an IPC network. The IPC protocol of the present invention provides communication between a plurality of processors in a system such as the
IPCプロトコルは、任意のIPC準拠MAをIPCリンクに動的に付加し通信を行わせる。従って、IPCネットワークは、コンパイル時間に一切依存せずに、即ち、他のいずれのソフトウェアも前提とせずに形成される。本発明のIPCは、ソフトウェア・コンポーネントがIPCスタック(図15に示さず)と通信を行うための標準的な方法を提示し、また、スタック下のハードウェアは、コンポーネントが通信を行うための異なるリンクを選択し得るように抽出される。 The IPC protocol dynamically adds an arbitrary IPC-compliant MA to the IPC link for communication. Thus, the IPC network is formed without any dependency on compile time, i.e. without any other software. The IPC of the present invention presents a standard way for software components to communicate with the IPC stack (not shown in FIG. 15), and the hardware under the stack is different for the components to communicate. Extracted so that a link can be selected.
本発明の好適な実施形態について例示し説明したが、本発明がそれに限定されないことは明らかである。数多くの修正、変更、バリエーション、置き換え及び等価物が、添付の請求項によって定義される本発明の精神及び範囲から逸脱することなく、当業者には起こり得る。 While the preferred embodiments of the invention have been illustrated and described, it will be clear that the invention is not so limited. Numerous modifications, changes, variations, substitutions and equivalents may occur to those skilled in the art without departing from the spirit and scope of the invention as defined by the appended claims.
Claims (10)
同IPCサーバに接続されたIPCクライアントとからなり、
同IPCクライアントは、
プレゼンテーション・マネージャと、
同プレゼンテーション・マネージャに接続されたセッション・マネージャと、
同セッション・マネージャに接続されたデバイス・インターフェイスと、を有するIPCスタックを含み、
IPCクライアントがIPCサーバと通信するためにIPCスタックを使用する、プロセッサ間通信(IPC)ネットワーク。 An IPC server;
An IPC client connected to the IPC server,
The IPC client
A presentation manager;
A session manager connected to the presentation manager;
An IPC stack having a device interface connected to the session manager;
An interprocessor communication (IPC) network in which an IPC client uses an IPC stack to communicate with an IPC server.
IPCサーバとIPCクライアントとのそれぞれの中にIPCスタックを備えるIPCネットワークを介して該IPCサーバとIPCクライアントとの間で通信する工程と、からなる第1と第2のプロセッサ間でIPCを行う方法。 A first processor acting as an IPC server and a second processor acting as an IPC client;
A method of performing IPC between a first processor and a second processor, comprising: communicating between the IPC server and the IPC client via an IPC network having an IPC stack in each of the IPC server and the IPC client. .
プレゼンテーション・マネージャと、
同プレゼンテーション・マネージャに接続されたセッション・マネージャと、
同セッション・マネージャに接続されたデバイス・インターフェイスと、
を含む、請求項8に記載の方法。 The IPC stack in each of the IPC server and the IPC client is
A presentation manager;
A session manager connected to the presentation manager;
A device interface connected to the session manager;
The method of claim 8 comprising:
同IPCサーバとIPCクライアントとのそれぞれの中の動的ルーチング表を使用して、同IPCクライアントからIPCサーバへ送信されるデータを適切にルーチングする工程、を更に含む請求項9に記載の方法。 A session manager in each of the IPC server and the IPC client has a dynamic routing table;
The method according to claim 9, further comprising: routing data sent from the IPC client to the IPC server appropriately using a dynamic routing table in each of the IPC server and the IPC client.
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/610,746 US7447735B2 (en) | 2003-07-01 | 2003-07-01 | Interprocessor communication protocol |
US10/610,746 | 2003-07-01 | ||
PCT/US2004/020212 WO2005006133A2 (en) | 2003-07-01 | 2004-06-24 | Interprocessor communication protocol |
Publications (3)
Publication Number | Publication Date |
---|---|
JP2007526544A true JP2007526544A (en) | 2007-09-13 |
JP2007526544A5 JP2007526544A5 (en) | 2012-04-05 |
JP4981444B2 JP4981444B2 (en) | 2012-07-18 |
Family
ID=34062323
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2006517601A Expired - Fee Related JP4981444B2 (en) | 2003-07-01 | 2004-06-24 | Communication protocol between processors |
Country Status (5)
Country | Link |
---|---|
US (2) | US7447735B2 (en) |
EP (1) | EP1644838B1 (en) |
JP (1) | JP4981444B2 (en) |
KR (1) | KR100854262B1 (en) |
WO (1) | WO2005006133A2 (en) |
Families Citing this family (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7623894B2 (en) | 2003-10-09 | 2009-11-24 | Freescale Semiconductor, Inc. | Cellular modem processing |
US7571222B1 (en) * | 2003-11-26 | 2009-08-04 | Sun Microsystems, Inc. | Network component identification |
FR2868638B1 (en) * | 2004-03-30 | 2006-05-19 | Sagem | METHOD OF EXCHANGING INFORMATION BETWEEN TWO NETWORKS OPERATING UNDER DIFFERENT ROUTING PROTOCOLS |
GB2446199A (en) | 2006-12-01 | 2008-08-06 | David Irvine | Secure, decentralised and anonymous peer-to-peer network |
US8725874B2 (en) * | 2007-09-27 | 2014-05-13 | International Business Machines Corporation | Dynamic determination of an ideal client-server for a collaborative application network |
KR101600951B1 (en) | 2009-05-18 | 2016-03-08 | 삼성전자주식회사 | Solid state drive device |
US9043634B2 (en) | 2011-04-29 | 2015-05-26 | Qualcomm Incorporated | Methods, systems, apparatuses, and computer-readable media for waking a SLIMbus without toggle signal |
US9065674B2 (en) * | 2011-04-29 | 2015-06-23 | Qualcomm Incorporated | Multiple slimbus controllers for slimbus components |
US8667193B2 (en) | 2011-04-29 | 2014-03-04 | Qualcomm Incorporated | Non-ported generic device (software managed generic device) |
US9351337B2 (en) | 2011-08-31 | 2016-05-24 | Telefonaktiebolaget L M Ericsson (Publ) | Virtual inter-process communication between a radio equipment and a radio equipment controller in a base station of a wireless communication system |
CN104993969B (en) * | 2015-07-28 | 2018-01-16 | 上海斐讯数据通信技术有限公司 | A kind of asynchronous configuration ONU methods, system and OLT |
CN113612671B (en) * | 2021-08-02 | 2022-09-06 | 上海同星智能科技有限公司 | Binding configuration method of bus adapter and channel, mapping manager and connection system |
CA3206530A1 (en) * | 2021-08-02 | 2023-02-09 | Chu Liu | Binding and configuration method for a bus adapter and a channel, mapping manager, and connection system |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH0883230A (en) * | 1994-09-14 | 1996-03-26 | Hitachi Ltd | Method and device for message transmission among decentralized objects |
JPH10200929A (en) * | 1996-12-20 | 1998-07-31 | Lucent Technol Inc | Automatic learning of network path decision using random path |
US6510465B1 (en) * | 1994-04-19 | 2003-01-21 | Ibm | Dual communication services interface for distributed transaction processing |
Family Cites Families (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP3003418B2 (en) | 1992-09-25 | 2000-01-31 | 株式会社日立製作所 | Data communication method between processors |
JP3490473B2 (en) * | 1993-02-17 | 2004-01-26 | 松下電器産業株式会社 | Communication system between processors |
US5623605A (en) * | 1994-08-29 | 1997-04-22 | Lucent Technologies Inc. | Methods and systems for interprocess communication and inter-network data transfer |
US6996823B1 (en) * | 2000-04-06 | 2006-02-07 | International Business Machines Corporation | Inter process communications in a distributed CP and NP environment |
US7263701B2 (en) * | 2001-09-04 | 2007-08-28 | Samsung Electronics Co., Ltd. | Interprocess communication method and apparatus |
US20030115358A1 (en) * | 2001-09-04 | 2003-06-19 | Yeong-Hyun Yun | Unified interprocess communication |
EP1322097A1 (en) * | 2001-12-21 | 2003-06-25 | Siemens Aktiengesellschaft | A method and computer system for client server inter process communication |
US7546365B2 (en) * | 2002-04-30 | 2009-06-09 | Canon Kabushiki Kaisha | Network device management system and method of controlling same |
-
2003
- 2003-07-01 US US10/610,746 patent/US7447735B2/en not_active Expired - Fee Related
-
2004
- 2004-06-24 WO PCT/US2004/020212 patent/WO2005006133A2/en active Application Filing
- 2004-06-24 KR KR1020057025477A patent/KR100854262B1/en active IP Right Grant
- 2004-06-24 JP JP2006517601A patent/JP4981444B2/en not_active Expired - Fee Related
- 2004-06-24 EP EP04755997.6A patent/EP1644838B1/en not_active Not-in-force
-
2008
- 2008-11-03 US US12/263,819 patent/US8326918B2/en not_active Expired - Fee Related
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6510465B1 (en) * | 1994-04-19 | 2003-01-21 | Ibm | Dual communication services interface for distributed transaction processing |
JPH0883230A (en) * | 1994-09-14 | 1996-03-26 | Hitachi Ltd | Method and device for message transmission among decentralized objects |
JPH10200929A (en) * | 1996-12-20 | 1998-07-31 | Lucent Technol Inc | Automatic learning of network path decision using random path |
Also Published As
Publication number | Publication date |
---|---|
EP1644838B1 (en) | 2014-09-03 |
KR20060033877A (en) | 2006-04-20 |
EP1644838A2 (en) | 2006-04-12 |
WO2005006133A3 (en) | 2005-06-09 |
US8326918B2 (en) | 2012-12-04 |
JP4981444B2 (en) | 2012-07-18 |
KR100854262B1 (en) | 2008-08-26 |
EP1644838A4 (en) | 2010-03-17 |
US20050027904A1 (en) | 2005-02-03 |
US20090064180A1 (en) | 2009-03-05 |
US7447735B2 (en) | 2008-11-04 |
WO2005006133A2 (en) | 2005-01-20 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP2007527566A (en) | Inter-processor communication protocol with smart streaming port | |
US8326918B2 (en) | Interprocessor communication protocol | |
US11777790B2 (en) | Communications methods and apparatus for migrating a network interface and/or IP address from one Pod to another Pod in a Kubernetes system | |
KR20080053299A (en) | Sharing a port with multiple processes | |
JP2001356973A (en) | Network system | |
JP4820940B2 (en) | Interprocessor communication network that dynamically dedicates port groups | |
JP2007526544A5 (en) | ||
US7356594B2 (en) | Interprocessor communication protocol providing intelligent targeting of nodes | |
KR100812680B1 (en) | Interprocessor communication protocol providing guaranteed quality of service and selective broadcasting | |
KR100787850B1 (en) | Interprocessor communication protocol with high level service composition | |
KR100805094B1 (en) | Interprocessor communication network providing dynamic dedication of ports | |
US20030093536A1 (en) | Support interface module | |
Cortes et al. | Narnia: A virtual machine for multimedia communication services | |
JP2000151739A (en) | Information processor, distributed processor and network system | |
Jank et al. | An object-oriented invocation layer for the Java Message Service |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20090821 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20090901 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20091201 |
|
A02 | Decision of refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A02 Effective date: 20100105 |
|
A524 | Written submission of copy of amendment under article 19 pct |
Free format text: JAPANESE INTERMEDIATE CODE: A524 Effective date: 20100506 |
|
A911 | Transfer to examiner for re-examination before appeal (zenchi) |
Free format text: JAPANESE INTERMEDIATE CODE: A911 Effective date: 20100528 |
|
A912 | Re-examination (zenchi) completed and case transferred to appeal board |
Free format text: JAPANESE INTERMEDIATE CODE: A912 Effective date: 20100618 |
|
A711 | Notification of change in applicant |
Free format text: JAPANESE INTERMEDIATE CODE: A712 Effective date: 20110531 |
|
A601 | Written request for extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A601 Effective date: 20110831 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20110901 |
|
A602 | Written permission of extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A602 Effective date: 20110913 |
|
A601 | Written request for extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A601 Effective date: 20110930 |
|
A602 | Written permission of extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A602 Effective date: 20111005 |
|
A601 | Written request for extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A601 Effective date: 20111031 |
|
A602 | Written permission of extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A602 Effective date: 20111104 |
|
A524 | Written submission of copy of amendment under article 19 pct |
Free format text: JAPANESE INTERMEDIATE CODE: A524 Effective date: 20120216 |
|
RD04 | Notification of resignation of power of attorney |
Free format text: JAPANESE INTERMEDIATE CODE: A7424 Effective date: 20120227 |
|
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20120420 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20150427 Year of fee payment: 3 |
|
R150 | Certificate of patent or registration of utility model |
Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
S533 | Written request for registration of change of name |
Free format text: JAPANESE INTERMEDIATE CODE: R313533 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20150427 Year of fee payment: 3 |
|
R350 | Written notification of registration of transfer |
Free format text: JAPANESE INTERMEDIATE CODE: R350 |
|
LAPS | Cancellation because of no payment of annual fees | ||
S111 | Request for change of ownership or part of ownership |
Free format text: JAPANESE INTERMEDIATE CODE: R313113 |
|
S531 | Written request for registration of change of domicile |
Free format text: JAPANESE INTERMEDIATE CODE: R313531 |
|
R360 | Written notification for declining of transfer of rights |
Free format text: JAPANESE INTERMEDIATE CODE: R360 |
|
R360 | Written notification for declining of transfer of rights |
Free format text: JAPANESE INTERMEDIATE CODE: R360 |
|
R371 | Transfer withdrawn |
Free format text: JAPANESE INTERMEDIATE CODE: R371 |