JP2007526544A - Communication protocol between processors - Google Patents

Communication protocol between processors Download PDF

Info

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
Application number
JP2006517601A
Other languages
Japanese (ja)
Other versions
JP2007526544A5 (en
JP4981444B2 (en
Inventor
カワンド、シャーベル
カワンド、ジーン
ピー. ウォン、チン
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Motorola Solutions Inc
Original Assignee
Motorola Inc
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Motorola Inc filed Critical Motorola Inc
Publication of JP2007526544A publication Critical patent/JP2007526544A/en
Publication of JP2007526544A5 publication Critical patent/JP2007526544A5/ja
Application granted granted Critical
Publication of JP4981444B2 publication Critical patent/JP4981444B2/en
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2209/00Indexing scheme relating to G06F9/00
    • G06F2209/54Indexing scheme relating to G06F9/54
    • G06F2209/541Client-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 IPC network 100 according to an embodiment of the present invention is shown. IPC network 100 includes a plurality of IPC clients 102-106 and, as some examples, different IPCs such as shared memory 110, universal asynchronous receiver / transmitter (UART) 112, and universal serial bus (USB) 114. An IPC server 108 connected to IPC clients 102-106 using a physical link is included. Note that with the IPC of the present invention, the IPC clients 102-106 can negotiate with the current IPC server 108 to switch roles. When IPC clients 102-106 negotiate to become IPC servers and become new IPC servers, all remaining IPC clients are instructed to change the server's IP address if there is a change in the IPC server Is done.

図2において、本発明の実施形態に基づくIPCサーバ108(又はIPCクライアント102-108)のIPCスタック200を示す。IPCスタック200は、オペレーティングシステム(OS)の下で一体化されるように、また、コンポーネントトラフィックのプロセッサ間通信ニーズにサポートを提供するように設計されている。IPCスタックは、次の3つの主な層から構成される。即ち、
(1)IPCプレゼンテーション・マネージャ(202):この層は、異なるシステムコンポーネント(例えば、ソフトウェア・スレッド)間において異なるデータタイプを変換するために用いられる。
In FIG. 2, an IPC stack 200 of an IPC server 108 (or IPC client 102-108) according to an embodiment of the present invention is shown. The IPC stack 200 is designed to be integrated under an operating system (OS) and to provide support for the interprocessor communication needs of component traffic. The IPC stack consists of three main layers: That is,
(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 session manager 204 has several functions. That is, assigning component IDs to join IPC components; determining whether IPC data needs to be hidden; routing IPC data, terminating IPC traffic; placeholders for IPC processors; providing IPC addresses, IPC Includes client assignment and authentication.

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 transport layer 208 performs very basic cyclic redundancy checks for the purpose of transporting IPC data between different processors. In addition, the IPC transport layer 208 is responsible for routing IPC messages to their final destination on the IPC network 100. The transport layer routing function is only available on the IPC server.

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 IPC session manager 204 relies on the router block 210 to send the IPC data to the correct component (s).

(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 device interface layer 206 manages the physical bandwidth of the immediate IPC link and supports all IPC logical channels. In the incoming path, the device interface layer 206 intercepts data from different physical channels 110-114 and passes them to the rest of the IPC stack. On the outgoing path, the device interface layer 206 manages the data loading of the IPC logical channels by sending them on the appropriate physical channel. The device interface layer 206 also concatenates IPC packets belonging to the same IPC channel and then sends them to the IPC hardware. Channel requirements are negotiated in advance between the IPC session manager 204 and the IPC device interface layer 206. The device interface layer 206 includes a hardware port, which provides a device interface with the IPC clients 102-106.

図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 step 302. Don't be. The local session manager (eg, the session manager located at the client to which the component is connected) then calls the IPC server session manager for the new IPC component and performs component ID assignment at step 304. According to an embodiment of the invention, the component ID is dynamic and is assigned by the session manager. The main IPC server location is most likely on the main AP. Each IPC node preferably has a unique IPC node ID, and the session manager maintains the following information for each participating IPC node in its database. That is,
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 step 506 using the defined API. The device layer (device interface) then requests hardware resources such as the data channel 508. In response to the request, the session manager shown in FIG. 5 provides an IPC channel to the requester in step 510. Component 502 then sends the data on the assigned channel 508. Then, the device layer transfers data to the IPC network. The mapping from logical to physical channel ID is a function of the IPC device interface.

次に、図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 client 602 and the IPC server 604. In step 608, the IPC server 604 authenticates the request made by the IPC client 602. Thereafter, the IPC address is transmitted to the IPC client, and registration is completed in step 610. The IPC client session manager sends a copy of its dynamic routing table to the IPC server in step 612.

IPCクライアント初期化プロセス時に行われる詳細なステップを図7に示す。クライアント・セッション・マネージャ(セッション(クライアント)としてテーブルに示す)は、ステップ702において、IPCサーバのセッション・マネージャ(セッション(サーバ)としてテーブルに示す)に設定要求を送る。ステップ704において、認証は、IPCサーバのセッション・マネージャによって要求される。そして、IPCクライアントとIPCサーバとの間の認証は、ステップ706で実行される。   The detailed steps performed during the IPC client initialization process are shown in FIG. In step 702, the client session manager (shown in the table as a session (client)) sends a setting request to the session manager of the IPC server (shown in the table as a session (server)). In step 704, authentication is requested by the session manager of the IPC server. Authentication between the IPC client and the IPC server is then performed at step 706.

設定要求のパラメータには、ノードタイプ及びデータタイプが含まれる。ステップ702において、設定要求に応答して、セッションサーバは、要求側にIPCアドレスを割り当てる。また、もしなければ、要求側用の動的ルーチング表を設定する。そして、ステップ708において、要求側に設定指示を送る。設定指示パラメータには、サーバのIPCアドレス及びクライアントの新規に割り当てられたIPCアドレスが含まれる。   The parameter of the setting request includes a node type and a data type. In step 702, in response to the configuration request, the session server assigns an IPC address to the requester. If not, set up a dynamic routing table for the requester. In step 708, a setting instruction is sent to the requesting side. The setting instruction parameter includes the IPC address of the server and the newly assigned IPC address of the client.

設定指示の受信に応答して、セッションクライアントに取り付けられたコンポーネントは、クライアントのセッション・マネージャから制御/データを要求し得る。そして、セッションクライアントは、ステップ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 step 710, the session client sends a setting instruction confirmation message to the session server. The “setting instruction confirmation” message does not have a parameter when the setting instruction confirmation message is received in step 710, and the session server can start an IPC stream to the newly set session client. The session server then sends a setting update message to the session client in steps 712 and 714. This causes both session clients shown in FIG. 7 to update their respective dynamic routing tables (not shown) and in steps 716 and 718 send a configuration update confirmation message to the session server. When the setting update confirmation message is received, the session server confirms that all participating IPCs have been updated.

パケットは、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 step 802, the component sends its source ID (no destination ID), destination BP or AP type, and IPC data including header and data. In step 804, the IPC session manager looks up the corresponding dynamic routing table and looks at the IPC data header OP code and the type of destination BP or AP to find the correct destination address. In step 806, the IPC session manager inserts the component's IPC address and sends it to the device layer.

図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 component 902 can subscribe to different services. In step 904, the components subscribe themselves to functions such as audio and video. The component application information is then sent to the IPC session manager to generate a component ID (if an ID has not yet been assigned) and to generate or update a dynamic routing table for a specific IP address. Performed (step 906). In step 908, the session manager updates the IPC server with the information from step 906. Upon receipt of the updated dynamic routing table at step 908, an update confirmation is sent by the IPC server to the IPC client at step 912. Once the server is called, the new dynamic routing table update is broadcast to all relevant processor steps 910.

図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 client session manager 1004, and a session (also known as server session manager 1006) ( Server). The component setting request in step 1008 is transmitted by the component (client) 1002. In response to the request, the client session manager 1004 negotiates a device layer (not shown) and a logical channel. The client session manager 1004 also assigns a component ID and adds a new OP code list to its dynamic routing table (not shown). In step 1010, the client session manager 1004 sends a setup response including the component ID and channel ID as parameters. In response to the setting response, the component (client) 1002 receives the ID and channel ID from the session manager 1004 of the client.

一旦クライアント・セッション・マネージャ1004が、ステップ1008における設定要求に対して、ステップ1010で返信すると、クライアント・セッション・マネージャ1004は、ステップ1012において、セッションサーバ(サーバ・セッション・マネージャ)1006に設定更新要求を送る。設定更新要求のパラメータは、動的ルーチング表(図示せず)において行われた何らかの新しい変更である。サーバのセッション・マネージャ1006は、そのIPCアドレス用の動的ルーチング表を更新する。そして、ステップ1016において、サーバのセッション・マネージャ1006は、全てのIPCクライアント(図示せず)に設定更新内容を送り、その間、ステップ1014において、クライアントのセッション・マネージャ1004に設定更新指示を送る。サーバのセッション・マネージャ1006は、サーバが、送られた変更でそのルーチングテーブルを更新したことを確認する。   Once the client session manager 1004 responds to the setting request in step 1008 in step 1010, the client session manager 1004 sends a setting update request to the session server (server session manager) 1006 in step 1012. Send. The parameter of the setting update request is any new change made in the dynamic routing table (not shown). The server's session manager 1006 updates the dynamic routing table for that IPC address. In step 1016, the session manager 1006 of the server sends the setting update contents to all IPC clients (not shown). Meanwhile, in step 1014, a setting update instruction is sent to the session manager 1004 of the client. The server's session manager 1006 confirms that the server has updated its routing table with the changes sent.

パラメータ(1つ又は複数)として動的ルーチング表を含むステップ1016の設定更新メッセージにおいて、セッションサーバ1006は、動的ルーチング表を更新し、ステップ1018において、設定更新確認メッセージを送る。そして、サーバは、参加した全IPCが更新されたことを確認する。   In the setting update message of step 1016 that includes the dynamic routing table as parameter (s), the session server 1006 updates the dynamic routing table and sends a setting update confirmation message in step 1018. The server then confirms that all participating IPCs have been updated.

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 router block 210 in FIG. 2) transports IPC data to the destination component. The incoming IPC message carries, among other things, the origin component ID and the IPC message OP code for voice or modem. The IPC session manager relies on its component routing table to send the IPC data to the correct component (s). Both the dynamic routing table and the component routing table are updated by the IPC server / client.

起動時、各コンポーネントは、そのセッション・マネージャにそれ自体登録して、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 IPC session manager 1106 continues to conceal the data with the IPC header information, after which the data is determined by the session manager if the destination component is located in the IPC network, not the local processor, Sent over an IPC network.

図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 component 1204.

本発明の実施形態に基づく代表的な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 step 1302, the component sends an update request. Preferably, the component update parameters include a node type and an OP code. The component searches for a node type that supports the destination OP code. If the node type is equal to 0xFF, the session manager (shown as “session” in FIG. 13) continues to send component information to all node tables for all participating IPCs. If the OP code field is equal to 0xFF, the session manager shown in FIG. 13 continues to send the OP code list belonging to the specified node type to the component. On the other hand, if the OP code has a specific value, the session manager continues to send a true or false value to the component corresponding to whether the node type supports or does not support that specific OP code.

ステップ1304において、コンポーネント更新指示は、コンポーネントに送られる。ノードタイプが0xFFに等しい場合、ノードテーブルが、コンポーネントに返される。OPコードフィールドが0xFFに等しい場合、OPコードのリストは、コンポーネントに返される。しかしながら、OPコードが特定の値である場合、真の又は偽のメッセージが返される。ステップ1306において、コンポーネントデータ要求が行われる。コンポーネントデータ要求用のパラメータには、ノードタイプ、IPCメッセージOPコード、IPCメッセージデータ、チャネルID及びコンポーネントIDが含まれる。コンポーネントデータ要求において、セッション・マネージャは、ノードタイプをチェックし、OPコードがサポートされるかどうか判断する。ノードタイプがOPコードをサポートしない場合、コンポーネント更新指示は、ステップ1308において送られる。しかしながら、ノードタイプがOPコードをサポートする場合、データ要求が、ステップ1310においてデバイス層に送られる。データ要求パラメータには、IPCメッセージ、チャネルID及びIPCヘッダが含まれる。   In step 1304, the component update instruction is sent to the component. If the node type is equal to 0xFF, the node table is returned to the component. If the OP code field is equal to 0xFF, a list of OP codes is returned to the component. However, if the OP code is a specific value, a true or false message is returned. In step 1306, a component data request is made. The parameter for requesting component data includes a node type, an IPC message OP code, IPC message data, a channel ID, and a component ID. In the component data request, the session manager checks the node type and determines if the OP code is supported. If the node type does not support OP code, a component update instruction is sent in step 1308. However, if the node type supports OP codes, a data request is sent to the device layer in step 1310. The data request parameters include an IPC message, a channel ID, and an IPC header.

デバイス層は、チャネル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 step 1314, the session manager continues to send a component data confirmation message to the component. The component may wait for confirmation and then send further IPC messages. Once the data confirmation is received, the component can continue to send the next IPC message.

ステップ1316において、デバイス層は、IPCメッセージデータ及びIPCヘッダが含まれるデータ指示メッセージを送る。セッション・マネージャは、メッセージの宛先IPCヘッダをチェックし、ローカルIPCアドレスと異なる場合、セッション・マネージャは、正しいIPCノードにメッセージを送る(ルーチングする)。ステップ1310において、セッション・マネージャは、予約チャネルIDと共にデバイス層にデータ要求を送る。セッション・マネージャは、宛先コンポーネントIDをチェックし、それが0xFFに等しい場合、そのOPコードに申し込んだ全コンポーネントにメッセージをルーチングする。ステップ1318において、セッション・マネージャは、コンポーネントデータ指示メッセージを送り、コンポーネントは、IPCデータを受信する。   In step 1316, the device layer sends a data indication message including IPC message data and an IPC header. The session manager checks the destination IPC header of the message and if it is different from the local IPC address, the session manager sends (routes) the message to the correct IPC node. In step 1310, the session manager sends a data request to the device layer with a reserved channel ID. The session manager checks the destination component ID, and if it is equal to 0xFF, routes the message to all components that have applied for that OP code. In step 1318, the session manager sends a component data indication message and the component receives the IPC data.

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 control channel information 1408 is transmitted together with the data packet 1410 when data is transmitted between different IPC hardware. Initially, the IPC client broadcasts its setting request on the IPC control channel. The IPC stack server receives the broadcast and responds with the IPC address for that client. This IPC address is associated with the dynamic routing table for that particular processor (AP or BP).

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 communication device 1500. IPC allows registration of mobile application (MA) clients (eg, iDEN TM _WLAN) to MA servers such as dedicated communication system (PCS) applications, and two MAs within their own MA, It provides a means to communicate freely without any restrictions on what software architecture, operating system, or hardware it depends on.

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.

本発明の実施形態に基づくIPCネットワークを示す図。The figure which shows the IPC network based on embodiment of this invention. 本発明の実施形態に基づくIPCスタックを示す図。FIG. 3 shows an IPC stack according to an embodiment of the present invention. 本発明の実施形態に基づくIPCコンポーネントIPC割当てを示す図。FIG. 4 illustrates IPC component IPC assignment according to an embodiment of the present invention. 本発明の実施形態に基づく主IPCテーブルを示す図。The figure which shows the main IPC table based on embodiment of this invention. 本発明の実施形態に基づくチャネルアロケーションを示す図。FIG. 4 shows channel allocation according to an embodiment of the present invention. 本発明の実施形態に基づくIPCクライアント初期化ルーチン時に関与するステップを強調表示して示す図。FIG. 6 is a diagram showing highlighted steps involved in an IPC client initialization routine according to an embodiment of the present invention. 本発明の実施形態に基づくIPCクライアント初期化時に関与するステップを強調表示して示すもう1つの図。FIG. 6 is another diagram highlighting and illustrating the steps involved during IPC client initialization according to an embodiment of the present invention. 本発明の実施形態に基づく第1レベルのIPC隠蔽を強調表示して示す図。FIG. 3 is a diagram showing highlighted first level IPC concealment according to an embodiment of the present invention. 本発明の実施形態に基づくIPCコンポーネント初期化時に行われるステップを強調表示して示す図。The figure which highlights and shows the step performed at the time of IPC component initialization based on embodiment of this invention. 本発明の実施形態に基づくコンポーネント初期化時に行われるステップを強調表示して示す図。The figure which highlights and shows the step performed at the time of the component initialization based on embodiment of this invention. 本発明の実施形態に基づくIPCクライアントとIPCサーバとの間のIPCデータ転送を示す図。The figure which shows the IPC data transfer between the IPC client and IPC server based on embodiment of this invention. 本発明の実施形態に基づくIPCデータヘッダを示す図。The figure which shows the IPC data header based on embodiment of this invention. 本発明の実施形態に基づくIPCデータ要求時に行われるステップを示す図。The figure which shows the step performed at the time of the IPC data request based on embodiment of this invention. 本発明の実施形態に基づくIPCネットワークを示す図。The figure which shows the IPC network based on embodiment of this invention. 本発明の実施形態に基づく無線通信装置等の電子装置を示す図。The figure which shows electronic devices, such as a radio | wireless communication apparatus based on embodiment of this invention.

Claims (10)

IPCサーバと、
同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.
少なくとも1つのコンポーネントがIPCクライアントと接続している請求項1に記載のIPCネットワーク。 The IPC network of claim 1, wherein at least one component is connected to an IPC client. 少なくとも1つのコンポーネント間で異なるデータタイプを言い換えるために前記プレゼンテーション・マネージャが使用される、請求項2に記載のIPCネットワーク。 The IPC network of claim 2, wherein the presentation manager is used to paraphrase different data types between at least one component. 少なくとも1つのコンポーネントのために、前記セッション・マネージャが部品IDを割り当てる請求項2に記載のIPCネットワーク。 The IPC network of claim 2, wherein the session manager assigns a part ID for at least one component. 少なくとも1つのコンポーネントに割り当てられる部品IDは動的であって再割り当てが可能な請求項4に記載のIPCネットワーク。 5. The IPC network according to claim 4, wherein the part ID assigned to at least one component is dynamic and can be reassigned. 前記セッション・マネージャが、コンポーネント・ルーチング表を有するIPCルータブロックを更に備え、該コンポーネント・ルーチング表は、前記セッション・マネージャがIPCデータを特定のオプコードでリンクされた1つ以上のコンポーネントに送信するために使用される、請求項2に記載のIPCネットワーク。 The session manager further comprises an IPC router block having a component routing table for the session manager to send IPC data to one or more components linked with a particular opcode. The IPC network according to claim 2, wherein the IPC network is used. 少なくとも1つのIPCハードウェアが装置インタフェイスに接続され、同装置インタフェイスは少なくとも1つのIPCハードウェアを抽出し、それによってIPCスタックはハードウェアから独立する、請求項1に記載のIPCネットワーク。 The IPC network of claim 1, wherein at least one IPC hardware is connected to the device interface, the device interface extracting at least one IPC hardware, whereby the IPC stack is independent of the hardware. 第1のプロセッサがIPCサーバとして働き、第2のプロセッサがIPCクライアントとして働く工程と、
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. .
IPCサーバとIPCクライアントとのそれぞれの中のIPCスタックが、
プレゼンテーション・マネージャと、
同プレゼンテーション・マネージャに接続されたセッション・マネージャと、
同セッション・マネージャに接続されたデバイス・インターフェイスと、
を含む、請求項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クライアントとのそれぞれの中の動的ルーチング表を使用して、同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.
JP2006517601A 2003-07-01 2004-06-24 Communication protocol between processors Expired - Fee Related JP4981444B2 (en)

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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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

Patent Citations (3)

* Cited by examiner, † Cited by third party
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