JP5699756B2 - 情報処理装置及び情報処理装置制御方法 - Google Patents

情報処理装置及び情報処理装置制御方法 Download PDF

Info

Publication number
JP5699756B2
JP5699756B2 JP2011081139A JP2011081139A JP5699756B2 JP 5699756 B2 JP5699756 B2 JP 5699756B2 JP 2011081139 A JP2011081139 A JP 2011081139A JP 2011081139 A JP2011081139 A JP 2011081139A JP 5699756 B2 JP5699756 B2 JP 5699756B2
Authority
JP
Japan
Prior art keywords
unit
communication
setting
communication unit
usb
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.)
Active
Application number
JP2011081139A
Other languages
English (en)
Other versions
JP2012217051A (ja
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.)
Fujitsu Ltd
Original Assignee
Fujitsu Ltd
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 Fujitsu Ltd filed Critical Fujitsu Ltd
Priority to JP2011081139A priority Critical patent/JP5699756B2/ja
Priority to US13/431,010 priority patent/US9154448B2/en
Publication of JP2012217051A publication Critical patent/JP2012217051A/ja
Application granted granted Critical
Publication of JP5699756B2 publication Critical patent/JP5699756B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L49/00Packet switching elements
    • H04L49/35Switches specially adapted for specific applications

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Information Transfer Systems (AREA)
  • Power Sources (AREA)
  • Communication Control (AREA)

Description

本発明は、情報処理装置及び情報処理装置制御方法に関する。
近年、情報をサーバから端末装置に配信する、プッシュ型のデータ配信サービスが普及してきている。このようなサービスはPUSHサービスと呼ばれる。PUSHサービスとは、端末装置の電源のオン/オフの状態又は端末装置のネットワーク接続の有無に関わらず、サーバから端末装置に情報が配信されると、端末装置が自動的にその情報を受信できるサービスである。
このようなサービスを実現するため、ユーザからの操作を待ち受け、端末装置の電源管理を行う遠隔操作通信装置を搭載する端末装置が提供されている。この遠隔操作通信装置は、独自のCPUを有し、端末装置のCPU(Central Processing Unit)による制御とは独立して端末装置の電源制御などを行うことができる装置である。以下では、端末装置のCPUにより制御される各部を総称して「端末装置本体」と言う。遠隔操作通信装置は、端末装置のソフトオフ時(以下では、「電源オフ」と言う。)にも動作することで機能を果たしている。このように、遠隔操作通信装置は、端末装置の電源オフ時にも動作することから常時電力を消費する。そこで、消費電力を減らすために、遠隔操作通信装置は、数MHz〜数十MHzで動作するMPU(Micro Processing Unit)を用いた通常低消費電力回路で実現されている。さらに、遠隔操作通信装置は、USB(Universal Serial Bus)などのインタフェースを介して通信デバイスを接続することで、ネットワーク接続が可能となる。
このような常時通電である遠隔操作通信装置を使用すれば、端末装置の電源オフ時においても、プッシュ通知の送信や、ファイルのダウンロードといったPUSHサービスを提供することができる。
ただし、遠隔操作通信装置は低クロックで実現されるため、遠隔操作通信装置の通信デバイスは、端末装置本体が有する通信デバイスに比べて十分な転送速度を得ることができない。端末装置が電源オフの場合には、端末装置において処理が行われていないため、低速な通信でも操作に影響はない。これに対して、端末装置が電源オンの場合には、操作者が端末装置を操作して端末装置本体に処理を行わせていることが考えられる。このような状況では、転送速度が低いと処理スピードが遅くなり、操作者の要求に十分に応えることが困難となる。すなわち、電源オンの場合に、遠隔操作通信装置経由で端末装置本体がデータを取得することは避けることが好ましい。そこで、例えばUSBインタフェースを介して通信デバイスと接続する場合には、端末装置本体及び遠隔操作通信装置のぞれぞれと通信デバイスとを結ぶUSBバスをUSBバススイッチを用いて選択的に切り替え、端末装置本体及び遠隔操作通信装置のいずれかをUSBホストとする方法がある。このような方法により、遠隔操作通信装置を搭載した端末装置において、電源オンの場合の通信速度を低下させることの無い常時接続を実現することが考えられる。
ここで、二重化された通信制御装置において、現用系と待機系の共通のメモリにデータを退避させ、切り替え時に退避系が共通のメモリを参照することで、系切り替え後も通信制御を継続する従来技術が提案されている。また、端末装置の内部に複数の処理回路を有し、バスを切り替えていずれかの処理回路にプロトコル処理を行わせる従来技術が提案されている。
特開平10−145456号公報 特開2004−147251号公報
しかしながら、USBホストをUSBバススイッチにより端末装置本体及び遠隔操作通信装置の一方から他方に切り替えることは、端末装置本体及び遠隔操作通信装置の一方からUSBデバイスを取り外し、他方へ取り付ける物理的な操作と同じである。すなわち、端末装置本体及び遠隔操作通信装置の一方から他方への切り替え後には、USBのエニュメレーション処理、ネットワークコネクションの確立及びアプリケーションのサーバへの接続が発生する。このため、端末装置本体及び遠隔操作通信装置の一方から他方へ切り替えた場合、ネットワーク接続が切断され、一時不通となるおそれがある。このように、切り替え時にネットワーク接続が一時不通となるとすると、PUSHサービスの品質が低下してしまう危険がある。
この点、二重化された通信制御装置において切り替え時に通信制御の継続性を維持する従来技術では、いずれの通信制御装置もネットワークとの接続はなされており、切り替えにおける通信デバイスのデタッチやアタッチの処理が必要ない。そこで、この従来技術では、通信デバイスのデタッチやアタッチによるネットワークの一時不通は考慮されておらず、そのような原因によるPUSHサービスの品質の低下を回避することはできない。また、バスを切り替えていずれかの処理回路にプロトコル処理を行わせる従来技術においても、切り替えにおけるネットワーク接続の一時不通を回避することができない。
開示の技術は、上記に鑑みてなされたものであって、搭載された遠隔操作通信装置による通信及び自装置における当該遠隔操作通信装置以外による通信の一方から他方に外部ネットワークとの通信を切り替える場合のネットワーク接続の一時不通を抑制する情報処理装置及び情報処理装置制御方法を提供することを目的とする。
本願の開示する情報処理装置及び情報処理装置制御方法は、一つの態様において、第1の制御部は、OSを実行する。第2の制御部は、前記OSから独立して動作する。第1通信部は、前記第1の制御部によって制御され、USBインタフェースによって外部ネットワークに接続して通信を行う。第2通信部は、前記第2の制御部によって制御され、USBインタフェースによって前記外部ネットワークに接続して通信を行う。共通記憶部は、入力された通信設定を記憶する。切替部は、前記外部ネットワークの接続先を前記第1通信部又は前記第2通信部のいずれか一方から他方に切り替える。第2通信設定部は、前記第2の制御部によって制御され、前記切替部が前記接続先を前記第2通信部から前記第1通信部へ切り替える場合、少なくともUSB設定及びネットワーク設定を含む前記第2通信部の通信設定を前記共通記憶部に書込む。第1通信設定部は、前記第1の制御部によって制御され、前記第2通信設定部により前記共通記憶部に書込まれた前記第2通信部の通信設定を取得し、取得した該通信設定を前記第1通信部に設定する。そして、前記切替部は、前記第1通信設定部により前記第1通信部に前記第2通信部の通信設定が設定された後、前記第2通信部から前記第1通信部へ前記外部ネットワークの接続先を切り替える。
本願の開示する情報処理装置及び情報処理装置制御方法の一つの態様によれば、搭載された遠隔操作通信装置による通信及び自装置における当該遠隔操作通信装置以外による通信の一方から他方に外部ネットワークとの通信を切り替える場合のネットワーク接続の一時不通を抑制できるという効果を奏する。
図1は、実施例に係る情報処理装置のブロック図である。 図2は、共通記憶部に格納されるデータのデータフォーマットを示す図である。 図3は、遠隔操作通信装置から情報処理装置への切り替え時のデータの流れを説明するための図である。 図4は、切り替え処理のフローチャートである。 図5は、切り替え処理におけるデータの流れを表すシーケンス図である。 図6は、切り替え処理の概略を表すシーケンス図である。 図7は、情報処理装置のハードウェア構成図である。
以下に、本願の開示する情報処理装置及び情報処理装置制御方法の実施例を図面に基づいて詳細に説明する。なお、以下の実施例により本願の開示する情報処理装置及び情報処理装置制御方法が限定されるものではない。
図1は、実施例に係る情報処理装置のブロック図である。図1に示すように、本実施例に係る情報処理装置1は、切替部11、制御部12、プロトコルスタック設定部13、USB通信部14、同期部15、記憶部16、スイッチ17及び遠隔操作通信装置100を有している。また、以下の説明では、情報処理装置1のうち遠隔操作通信装置100を除いた部分を指す場合、「情報処理装置1本体」という。
また、遠隔操作通信装置100は、切替部101、制御部102、プロトコルスタック設定部103、USB通信部104、同期部105、記憶部106及び共通記憶部110を有している。
スイッチ17は、例えば図1に示す3G通信モジュール2などのUSBデバイスと接続されている。そして、本実施例では、3G通信モジュール2は、外部ネットワークと接続している。また、スイッチ17は、切替部11又は切替部101からの指示を受けて、USB通信部14又はUSB通信部104のいずれかが3G通信モジュール2と接続するように選択的に切り替える。すなわち、スイッチ17がUSB通信部14を3G通信モジュール2の接続先として選択した場合、3G通信モジュール2とUSB通信部14との間でデータの送受信が可能となる。また、スイッチ17がUSB通信部104を3G通信モジュール2の接続先として選択した場合、3G通信モジュール2とUSB通信部104との間でデータの送受信が可能となる。
以下では、スイッチ17により3G通信モジュールとの接続がUSB通信部14からUSB通信部104へ切り替えられる場合を、「USB通信部104への切り替え」と言う。また、スイッチ17により3G通信モジュール2との接続がUSB通信部104からUSB通信部14へ切り替えられる場合を、「USB通信部14への切り替え」という。また、いずれかへの切り替えかを特に区別しない場合、単に「切り替え」という。さらに、いずれかへの切り替えかを特に区別しない場合、USB通信部14及びUSB通信部104のうち、切り替えの前に3G通信モジュール2と接続していた側を「切替元」といい、切り替えの後に3G通信モジュール2に接続される側を「切替先」という。
また、共通記憶部110は、メモリなどの記憶装置である。そして、共通記憶部110は、情報処理装置1本体の各部及び遠隔操作通信装置100の各部のいずれからもデータの読み書きが行える。図2は、共通記憶部に格納されるデータのデータフォーマットを示す図である。図2に示すように、共通記憶部110に格納されるデータのデータフォーマット200は、通知領域201、プロトコルスタック設定領域210及び同期領域220を有している。
通知領域201は、接続元から接続先に対する、切り替えの発生の通知や設定完了の通知といったデータを格納する領域である。
プロトコルスタック設定領域210は、プロトコルの各階層における通信設定を格納する領域である。プロトコルスタック設定領域210は、アプリ設定領域202、ネットワーク設定領域203及びUSB設定領域204を有している。後述するように、プロトコルスタック設定領域210に格納される通信設定は、切り替えの際に接続元から接続先へ通信設定を受け渡すために使用される。
アプリ設定領域202は、アプリケーションの設定情報を表すアプリケーション情報を格納する領域である。アプリケーションとは、例えば、PUSHサービスを受信するアプリケーションなどである。そして、アプリケーション情報とは、例えば、認証先サーバ情報、認証情報及びデバイス識別子などである。
また、ネットワーク設定領域203は、ネットワークの設定情報を表すネットワーク情報を格納する領域である。ネットワーク情報とは、例えば、IP(Internet Protocol)アドレスや、ポート番号、セッション管理情報及びPPP(Pont-to-Pont Protocol)におけるID(IDentification)やPW(Pass Word)などである。
また、USB設定領域204は、USBの設定情報を表すUSB情報を格納する領域である。USB情報とは、例えば、デバイスアドレス、エンドポイント及びデバイスドライバなどである。
また、同期領域220は、切り替え時に情報処理装置1本体及び遠隔操作通信装置100の動作を同期させるために必要な情報を格納する領域である。同期領域220は、データ転送領域205を有している。ここで、図2では、説明の便宜上、同期領域220は、データ転送領域205と同じ領域を指すように記載しているが、実際には、同期領域220にデータ転送領域205が含まれることを示しており、同期領域220には同期に必要な他の情報も書込まれる。
データ転送領域205は、3G通信モジュール2から受信したデータを接続先から接続元へ転送するための領域である。
図1に戻って、USB通信部14は、スイッチ17がUSB通信部14を3G通信モジュール2の接続先として選択している場合、3G通信モジュール2との間でデータの送受信を行う。さらに詳しくは、USB通信部14は、制御部12に指示されたデータを3G通信モジュール2を介して外部ネットワークへ送信する。また、USB通信部14は、3G通信モジュール2を介して外部ネットワークからのデータを受信する。USB通信部14は、受信したデータを制御部12へ出力する。ここで、USB通信部14は、1msの間隔でSOF(Start of Frame)パケットにより通信の同期を取っている。SOFパケットは、データの伝送を行う単位であるフレームの先頭に配置されている。言い換えれば、フレームは、1ms毎にSOFパケットを先頭にトランザクション群が続く構成となっている。そして、通信が発生する場合は、USB通信部14は、1つ又は複数のフレームにまたがったUSBトランザクションを送受信することで、データ通信を実現する。
これに対して、スイッチ17がUSB通信部104を3G通信モジュール2の接続先として選択している場合、USB通信部14は、通信を行わない。
また、USB通信部104への切り替えの場合、制御部12からの切り替え通知を受けて、USB通信部14は、3G通信モジュール2から受信したデータを制御部12へ出力するとともに、同期部15へ出力する。
これに対して、USB通信部14への切り替えの場合、USB通信部14は、同期部15からの制御を受けて、USB通信部104のSOFの受信タイミングでリセットが行われる。これにより、USB通信部14は、3G通信モジュール2と同期する。その後、USB通信部14は、後述するように共通記憶部110に構成された仮想的な3G通信モジュールである仮想3G通信モジュールと仮想的な接続が行われる。この、仮想的な3G通信モジュールについては後で詳細に説明する。これにより、USB通信部14は、共通記憶部110に構成された仮想3G通信モジュールとのデータの授受を行うことができる状態になる。そして、USB通信部14は、擬似的なUSB応答の仮想3G通信モジュールへの送信指示を制御部12から受ける。この指示を受けて、USB通信部14は、擬似的なUSB応答を共通記憶部110のデータ転送領域205に書き込む。そして、USB通信部14は、通知領域201を監視し、遠隔操作通信装置100の制御部102から擬似応答が通知領域201に書き込まれたかを判定する。擬似応答が通知領域201に書き込まれた場合、USB通信部14は、擬似応答を読み込む。そして、USB通信部14は、仮想3G通信モジュールとの通信が正常に確立したかを判定する。仮想3G通信モジュールとの通信が正常に確立したと判定した場合、USB通信部14は、同期完了を制御部12へ通知する。このUSB通信部14が、「第1通信部」の一例にあたる。
USB通信部104への切り替えの場合、同期部15は、同期命令を制御部12から受ける。そして、同期部15は、USBデバイスである3G通信モジュール2のUSBディスクリプタを制御部12から受信する。そして、同期部15は、受信したUSBディスクリプタを共通記憶部110の同期領域220に書き込む。これにより、共通記憶部110は、仮想3G通信モジュールとして構成される。
次に、同期部15は、3G通信モジュール2から受信したデータの入力をUSB通信部14から受ける。そして、同期部15は、受信したデータを共通記憶部110のデータ転送領域205に書き込む。
これに対して、USB通信部14への切り替えの場合、同期部15は、同期命令を制御部12から受ける。制御部12からの同期命令に従って、USB通信部14は、共通記憶部110のデータ転送領域205を監視する。そして、同期部15は、データ転送領域205に書き込まれるデータのSOFを参照し、SOFの受信タイミングでUSB通信部14のリセットを行い、USB通信部14を3G通信モジュール2に同期させる。この同期部15が、「第1同期部」の一例にあたる。
プロトコルスタック設定部13は、USB通信部104への切り替えの場合、通信設定格納命令を制御部12から受ける。そして、プロトコルスタック設定部13は、通信設定を共通記憶部110へ書き込む。具体的には、プロトコルスタック設定部13は、3G通信モジュール2を使用して行っている通信におけるアプリケーション情報をアプリ設定領域へ202書き込む。また、プロトコルスタック設定部13は、USB通信部14が3G通信モジュール2を介して行っていた外部ネットワークとの通信におけるネットワーク情報をネットワーク設定領域203へ書き込む。さらに、プロトコルスタック設定部13は、USBデバイスである3G通信モジュール2のUSB情報をUSB設定領域204へ書き込む。
これに対して、USB通信部14への切替の場合、プロトコルスタック設定部13は、通信設定の取得命令を制御部12から受ける。そして、プロトコルスタック設定部13は、共通記憶部110からUSB通信部104が使用していた通信設定を取得する。具体的には、プロトコルスタック設定部13は、3G通信モジュール2を使用して通信を行っているアプリケーション情報をアプリ設定領域202から取得する。また、プロトコルスタック設定部13は、USB通信部104が3G通信モジュール2を介して行っていた外部ネットワークとの通信におけるネットワーク情報をネットワーク設定領域203から取得する。さらに、プロトコルスタック設定部13は、USBデバイスである3G通信モジュール2のUSB情報をUSB設定領域204から取得する。そして、プロトコルスタック設定部13は、取得した通信設定を制御部12へ出力する。このプロトコルスタック設定部13が、「第1通信設定部」の一例にあたる。
記憶部16は、メモリやハードディスクなどの記憶装置である。そして、記憶部16には、OSやPUSHサービスのアプリケーションなどが記憶されている。
制御部12について、スイッチ17がUSB通信部14を3G通信モジュール2の接続先として選択している場合を説明する。制御部12は、USB通信部14からデータの入力を受ける。そして、制御部12は、記憶部16などを用いてデータの処理を行う。また、制御部12は、外部へのデータの送信が必要な場合には、USB通信部14へデータを出力する。
制御部12は、スイッチ17がUSB通信部14を3G通信モジュール2の接続先として選択している状態で、例えばシャットダウン命令などの切り替え要因が発生した場合、シャットダウンまたはスタンバイモードの制御部102を起動する。また、制御部12は、USB通信部14に切り替えを通知する。また、制御部12は、同期命令を同期部15に通知する。また、制御部12は、通信設定の格納命令をプロトコルスタック設定部13に通知する。さらに、制御部12は、共通記憶部110の通知領域201に切り替え開始の通知を書き込む。
次に、制御部12は、共通記憶部110の通知領域201を監視し、遠隔操作通信装置100の制御部102から同期設定完了通知が書き込まれたことを確認する。
次に、制御部12は、共通記憶部110の同期領域220を監視し、遠隔操作通信装置100のUSB通信部104からUSB応答が書き込まれたかを判定する。制御部12は、同期領域220にUSB応答が書き込まれた場合、擬似応答を同期領域220へ書き込む。その後、制御部12は、共通記憶部110の通知領域201を監視し、制御部102から同期完了の通知が書き込まれたことを判定する。さらに、制御部12は、共通記憶部110の通知領域201を監視し、通知領域201に切り替え通知が書き込まれたかを判定する。そして、同期完了通知及び切り替え通知が書き込まれると、制御部12は、USB通信部14からUSB通信部104へ3G通信モジュール2の接続先を切り替える命令を切替部11へ出力する。
次に、制御部12について、スイッチ17がUSB通信部104を3G通信モジュール2の接続先として選択している場合を説明する。この場合、制御部12は、通常はシャットダウンしている。そして、スイッチ17がUSB通信部104を3G通信モジュール2の接続先として選択している状態で、切り替え要因が発生した場合、遠隔操作通信装置100の制御部102からの制御により電力供給が開始され、起動する。
制御部12は、通信設定の取得命令をプロトコルスタック設定部13に通知する。その後、制御部12は、取得命令の応答として通信設定をプロトコルスタック設定部13から受信する。
そして、制御部12は、受信した通信設定からUSB情報を取得し、USB通信部14の設定を行う。例えば、制御部12は、受信したUSB情報から、USB通信部104が使用しているUSBデバイスアドレス、使用しているエンドポイント、デバイスドライバなどを用いて、USB通信部104が構成しているUSBホストと同じ振る舞いをするUSBホストをUSB通信部14に構成する。
また、制御部12は、受信した通信設定からネットワーク情報を取得し、USB通信部14に設定する。例えば、制御部12は、IPアドレス、ポート番号、セッション管理及びPPP接続情報などのネットワーク設定を行う。
また、制御部12は、受信した通信設定の中からアプリケーション情報を受信し、該当するアプリケーションを起動する。そして、制御部12は、起動したアプリケーションにアプリケーション情報を適応する。例えば、制御部12は、起動したアプリケーションに対して、PUSHサーバ、認証情報及びデバイス識別しなどを設定する。そして、制御部12は、設定完了の通知を共通記憶部110の通知領域201へ書き込む。
さらに、制御部12は、同期命令を同期部15に通知する。次に、制御部12は、USB通信部14における同期が完了したかを判定する。そして、制御部12は、USB通信部14の同期が完了した場合、同期完了通知を通知領域201に書き込む。
その後、制御部12は、3G通信モジュール2に対するUSBエニュメレーションを実行して、USBデバイスを登録する。ここで、制御部12は、デバイスアドレス、エンドポイントとして、USB通信部14に設定したものと同じものを使用する。
その後、制御部12は、USBディスクリプタの情報を共通記憶部110の同期領域220から取得する。制御部12は、同期領域220に書き込まれたUSBディスクリプタの情報を取得することで、3G通信モジュール2の仕様が取得できる。そこで、制御部12は、3G通信モジュール2のUSBディスクリプタを使用して、3G通信モジュール2に対するデータを作成することができる。そして、制御部12は、作成した3G通信モジュール2へのデータを共通記憶部110の通知領域201へ書き込むことができる。さらに、制御部12は、3G通信モジュール2の通知領域201から取得したデータを3G通信モジュール2から取得したデータとして取り扱う。このように、制御部12は、共通記憶部110を介して3G通信モジュール2との通信が行えるかのように振舞うことができる。すなわち、制御部12は、共通記憶部110を仮想3G通信モジュールとして使用することができる。
そこで、制御部12は、仮想3G通信モジュールに対して擬似的なUSB応答を行う指示をUSB通信部14へ通知する。その後、制御部12は、USB通信部14から同期完了の通知を受信した場合、切り替え通知を通知領域201に書き込む。
その後、制御部12は、USB通信部14への切り替えが行われ、USB通信部14からデータの入力を受けると、起動しているアプリケーションなどを用いて受信したデータに対する処理を開始する。
切替部11は、USB通信部14からUSB通信部104へ3G通信モジュール2の接続先を切り替える命令の入力を制御部12から受ける。そして、切り替え命令を受信すると、切替部11は、スイッチ17がUSB通信部104を3G通信モジュール2の接続先として選択するよう切替える。
次に遠隔操作通信装置100について説明する。USB通信部104は、スイッチ17がUSB通信部104を3G通信モジュール2の接続先として選択している場合、3G通信モジュール2と間でデータの送受信を行う。さらに詳しくは、USB通信部104は、制御部102に指示されたデータを3G通信モジュール2を介して外部ネットワークへ送信する。また、USB通信部104は、3G通信モジュール2を介して外部ネットワークからのデータを受信する。USB通信部104は、受信したデータを制御部102へ出力する。ここで、USB通信部104は、1msの間隔でSOFパケットにより通信の同期を取っている。
これに対して、スイッチ17がUSB通信部14を3G通信モジュール2の接続先として選択している場合、USB通信部104は、通信を行わない。
また、USB通信部14への切り替えの場合、制御部102からの切り替え通知を受けて、USB通信部104は、3G通信モジュール2から受信したデータを制御部102へ出力するとともに、同期部105へ出力する。
これに対して、USB通信部104への切り替えの場合、USB通信部104は、同期部105からの制御を受けて、USB通信部14のSOFの受信タイミングでリセットが行われる。これにより、USB通信部104は、3G通信モジュール2と同期する。その後、USB通信部104は、後述するように共通記憶部110に構成された仮想3G通信モジュールと仮想的な接続が行われる。すなわち、USB通信部104は、共通記憶部110に構成された仮想3G通信モジュールとのデータの授受ができる状態となる。そして、USB通信部104は、擬似的なUSB応答の仮想3G通信モジュールへの送信指示を制御部102から受ける。この指示を受けて、USB通信部104は、擬似的なUSB応答を共通記憶部110のデータ転送領域205に書き込む。そして、USB通信部104は、通知領域201を監視し、情報処理装置1本体の制御部12から擬似応答が通知領域201に書き込まれたかを判定する。擬似応答が通知領域201に書き込まれた場合、USB通信部104は、擬似応答を読み込む。そして、USB通信部104は、仮想3G通信モジュールとの通信が正常に確立したかを判定する。仮想3G通信モジュールとの通信が正常に確立したと判定した場合、USB通信部104は、同期完了を制御部102へ通知する。このUSB通信部104が、「第2通信部」の一例にあたる。
USB通信部14への切り替えの場合、同期部105は、同期命令を制御部102から受ける。そして、同期部105は、USBデバイスである3G通信モジュール2のUSBディスクリプタを制御部102から受信する。そして、同期部105は、受信したUSBディスクリプタを共通記憶部110の同期領域220に書き込む。これにより、共通記憶部110は、仮想3G通信モジュールとして構成される。
次に、同期部105は、3G通信モジュール2から受信したデータの入力をUSB通信部104から受ける。そして、同期部105は、受信したデータを共通記憶部110のデータ転送領域205に書き込む。
これに対して、USB通信部104への切り替えの場合、同期部105は、同期命令を制御部102から受ける。制御部102からの同期命令に従って、USB通信部104は、共通記憶部110のデータ転送領域205を監視する。そして、同期部105は、データ転送領域205に書き込まれるデータのSOFを参照し、SOFの受信タイミングでUSB通信部104のリセットを行い、USB通信部104を3G通信モジュール2に同期させる。この同期部105が、「第2同期部」の一例にあたる。
プロトコルスタック設定部103は、USB通信部14への切り替えの場合、通信設定格納命令を制御部102から受ける。そして、プロトコルスタック設定部103は、通信設定を共通記憶部110へ書き込む。
これに対して、USB通信部104への切替の場合、プロトコルスタック設定部103は、通信設定の取得命令を制御部102から受ける。そして、プロトコルスタック設定部103は、共通記憶部110からUSB通信部14が使用していた通信設定を取得する。具体的には、プロトコルスタック設定部103は、3G通信モジュール2を使用した通信におけるアプリケーション情報をアプリ設定領域202から取得する。また、プロトコルスタック設定部103は、USB通信部14が3G通信モジュール2を介して行っていた外部ネットワークとの通信におけるネットワーク情報をネットワーク設定領域203から取得する。さらに、プロトコルスタック設定部103は、USBデバイスである3G通信モジュール2のUSB情報をUSB設定領域204から取得する。そして、プロトコルスタック設定部103は、取得した通信設定を制御部102へ出力する。このプロトコルスタック設定部103が、「第2通信設定部」の一例にあたる。
記憶部106は、メモリやハードディスクなどの記憶装置である。そして、記憶部106には、OSやPUSHサービスのアプリケーションなどが記憶されている。
制御部102について、スイッチ17がUSB通信部104を3G通信モジュール2の接続先として選択している場合を説明する。制御部102は、USB通信部104からデータの入力を受ける。そして、制御部102は、記憶部106などを用いてデータの処理を行う。また、制御部102は、外部へのデータの送信が必要な場合には、USB通信部104へデータを出力する。
制御部102は、スイッチ17がUSB通信部104を3G通信モジュール2の接続先として選択している状態で、情報処理装置1の起動などの切り替え要因が発生した場合、シャットダウンまたはスタンバイモードの制御部12を起動する。また、制御部102は、USB通信部104に切り替えを通知する。また、制御部102は、同期命令を同期部105に通知する。また、制御部102は、通信設定の格納命令をプロトコルスタック設定部103に通知する。
次に、制御部12は、共通記憶部110の通知領域201を監視し、遠隔操作通信装置100の制御部102から同期設定完了通知が書き込まれたことを確認する。
次に、制御部102は、共通記憶部110の同期領域220を監視し、情報処理装置1本体のUSB通信部14からからUSB応答が書き込まれたかを判定する。制御部102は、同期領域220にUSB応答が書き込まれた場合、擬似応答を同期領域220へ書き込む。その後、制御部102は、共通記憶部110の通知領域201を監視し、制御部12から同期完了の通知が書き込まれたことを判定する。さらに、制御部102は、共通記憶部110の通知領域201を監視し、通知領域201に切り替え通知が書き込まれたかを判定する。そして、同期完了通知及び切り替え通知が書き込まれると、制御部102は、USB通信部104からUSB通信部14へ3G通信モジュール2の接続先を切り替える命令を切替部101へ出力する。
次に、制御部102について、スイッチ17がUSB通信部14を3G通信モジュール2の接続先として選択している場合を説明する。この場合でも、遠隔操作通信装置100は常時通電であるため、制御部102は、起動している。制御部102は、共通記憶部110の通知領域201を監視している。そして、情報処理装置1本体の制御部12により切り替え開始の通知が通知領域201に書き込まれた場合、制御部102は、通信設定の取得命令をプロトコルスタック設定部103に通知する。その後、制御部102は、取得命令の応答として通信設定をプロトコルスタック設定部103から受信する。
そして、制御部102は、受信した通信設定からUSB情報を取得し、USB通信部104の設定を行う。例えば、制御部102は、受信したUSB情報から、USB通信部14が使用しているUSBデバイスアドレス、使用しているエンドポイント、デバイスドライバなどを用いて、USB通信部14が構成しているUSBホストと同じ振る舞いをするUSBホストをUSB通信部104に構成する。
また、制御部102は、受信した通信設定からネットワーク情報を取得し、USB通信部104に設定する。例えば、制御部102は、IPアドレス、ポート番号、セッション管理及びPPP接続情報などのネットワーク設定を行う。
また、制御部102は、受信した通信設定の中からアプリケーション情報を受信し、該当するアプリケーションを起動する。そして、制御部102は、起動したアプリケーションにアプリケーション情報を適応する。例えば、制御部102は、起動したアプリケーションに対して、PUSHサーバ、認証情報及びデバイス識別しなどを設定する。そして、制御部12は、設定完了の通知を共通記憶部110の通知領域201へ書き込む。
さらに、制御部102は、同期命令を同期部105に通知する。次に、制御部102は、USB通信部104における同期が完了したかを判定する。そして、制御部102は、USB通信部104の同期が完了した場合、同期完了通知を通知領域201に書き込む。
その後、制御部102は、3G通信モジュール2に対するUSBエニュメレーションを実行して、USBデバイスを登録する。ここで、制御部102は、デバイスアドレス、エンドポイントとして、USB通信部14に設定したものと同じものを使用する。
その後、制御部102は、USBディスクリプタの情報を共通記憶部110の同期領域220から取得する。制御部102は、同期領域220に書き込まれたUSBディスクリプタの情報を取得することで、3G通信モジュール2の仕様が取得できる。そこで、制御部102は、3G通信モジュール2のUSBディスクリプタを使用して、3G通信モジュール2に対するデータを作成することができる。そして、制御部102は、作成した3G通信モジュール2へのデータを共通記憶部110の通知領域201へ書き込むことができる。さらに、制御部102は、3G通信モジュール2の通知領域201から取得したデータを3G通信モジュール2から取得したデータとして取り扱う。このように、制御部102は、共通記憶部110を介して3G通信モジュール2との通信が行えるかのように振舞うことができる。すなわち、制御部102は、共通記憶部110を仮想3G通信モジュールとして使用することができる。
そこで、制御部12は、仮想3G通信モジュールに対して擬似的なUSB応答を行う指示をUSB通信部14へ通知する。その後、制御部12は、USB通信部14から同期完了の通知を受信した場合、切り替え通知を通知領域201に書き込む。
その後、制御部102は、USB通信部104への切り替えが行われ、USB通信部104からデータの入力を受けると、起動しているアプリケーションなどを用いて受信したデータに対する処理を開始する。
切替部101は、USB通信部104からUSB通信部14へ3G通信モジュール2の接続先を切り替える命令の入力を制御部102から受ける。そして、切り替え命令を受信すると、切替部11は、スイッチ17がUSB通信部104を3G通信モジュール2の接続先として選択するよう切替える。
次に、図3を参照して、3G通信モジュール2の接続を遠隔操作通信装置100から情報処理装置1本体への切り替える場合のデータの流れについて説明する。図3は、遠隔操作通信装置から情報処理装置への切り替え時のデータの流れを説明するための図である。図3において、PUSHアプリ20及びPUSHアプリ120を点線で記載しているが、これは、図1における制御部12及び制御部102によって起動されたアプリケーションを表している。すなわち、PUSHアプリ20は、図1における制御部12及び記憶部16などにより実現され、図3におけるPUSHアプリ120は制御部102及び記憶部106により実現される。
ユーザによるPC起動またはPUSHサービスによるPC起動によって、切り替え要因が発生すると、情報処理装置1が起動する。プロトコルスタック設定部103は、PUSHアプリ120から取得したアプリケーション情報であるPUSHアプリ情報を共通記憶部110へ書き込む(ステップS1)。
また、プロトコルスタック設定部103は、USB通信部104が使用しているネットワーク情報を共通記憶部110へ書き込む(ステップS2)。
さらに、プロトコルスタック設定部103は、USB通信部104が使用しているUSB情報を共通記憶部110へ書き込む(ステップS3)。
これに対して、プロトコルスタック設定部13は、PUSHアプリ情報を共通記憶部110から取得する(ステップS4)。プロトコルスタック設定部13が取得したPUSHアプリ情報は、PUSHアプリ20へ通知される。
また、プロトコルスタック設定部13は、ネットワーク情報を共通記憶部110から取得する(ステップS5)。
さらに、プロトコルスタック設定部13は、USB情報を共通記憶部110から取得する(ステップS6)。
その後、同期部105は、USB通信部104からの通信を共通記憶部110へ転送し、3G通信モジュール2のUSBディスクリプタを共通記憶部110へ書き込む(ステップS7)。ここで、図3におけるUSB通信部104から仮想3G通信モジュールへの矢印は、USB通信部104からの通信の共通記憶部110への転送を表している。これにより、共通記憶部110の中に仮想3G通信モジュールが構成される。
そして、同期部15は、同期部105によって共通記憶部110に転送された通信のSOFを取得し(ステップS8)、USB通信部14をリセットすることで、USB通信部104とUSB通信部14との同期が取れる。
これにより、USB通信部14は、取得した各種通信設定を用いて共通記憶部110に構成された仮想3G通信モジュールに対して接続を仮想的に行うことができる(ステップS9)。
このように、USB通信部14を仮想3G通信モジュールとの接続を仮想的に確立しておくことで、USB通信部14は、スイッチ17の切り替えにより実際の3G通信モジュール2に接続されたときに、既に確立している設定を用いて接続を確立することができる。したがって、実際の切り替え後には通信設定などを行う必要が無いので、通信の中断を軽減することができる。
ここでは、遠隔操作通信装置100のUSB通信部104から情報処理装置1本体のUSB通信部14へ接続を切り替える場合について説明した。この点、情報処理装置1本体のUSB通信部14から遠隔操作通信装置100のUSB通信部104に切り替える場合においても、データの流れが逆になるだけで同様のデータの受け渡しが行われ、仮想3G通信モジュールが共通記憶部110に構成される。
次に、図4を参照して、遠隔操作通信装置100のUSB通信部104から情報処理装置1本体のUSB通信部14への接続の切り替え処理の流れを説明する。図4は、切り替え処理のフローチャートである。
遠隔操作通信装置100の動作時に、シャットダウンなどの切り替え要因が発生する(ステップS101)。
次に、制御部102は、移行先である情報処理装置1本体の制御部12が有するCPUに電源を供給し制御部12を起動させる(ステップS102)。
プロトコルスタック設定部103は、USB通信部104が使用している通信設定を共通記憶部110へ書き込む(ステップS103)。
プロトコルスタック設定部13は、通信設定を共通記憶部110から取得する。そして、制御部12は、プロトコルスタック設定部13が取得した通信設定をUSB通信部14などに設定する(ステップS104)。
制御部12は、共通記憶部110の通知領域201に設定完了の通知を書き込み、設定完了を通知する(ステップS105)。
同期部105は、USB通信部104が3G通信モジュール2から受信したデータを共通記憶部110のデータ転送領域205へ転送する(ステップS106)。
そして、同期部15は、データ転送領域205に書き込まれたデータのSOFを取得し、USB通信部14とUSBデバイスである3G通信モジュール2との同期を取る(ステップS107)。
そして、制御部12は、3G通信モジュール2に対するUSBエニュメレーションを実行して、USBデバイスを登録し設定する(ステップS108)。
次に、USB通信部14は、擬似的なUSB応答の通知を共通記憶部110の通知領域201に書き込み、制御部102は、通知領域201に書き込まれた擬似的なUSB応答の通知を取得する。これにより、USB通信部14は、制御部102に対して擬似的なUSB応答を通知する(ステップS109)。
次に、制御部102は、擬似応答の通知を共通記憶部110の通知領域201に書き込み、USB通信部14は、通知領域201に書き込まれた擬似応答の通知を取得する。これにより、制御部102は、USB通信部14に対して擬似応答を通知する(ステップS110)。
そして、制御部12は、USB通信部14が擬似応答の通知を制御部102から受けると、同期完了の通知を共通記憶部110の通知領域201に書き込み、制御部102は、通知領域201に書き込まれた同期完了の通知を取得する。これにより、制御部12は、制御部102に対して同期完了の通知を行う(ステップS111)。
さらに、制御部12は、切り替え通知を共通記憶部110の通知領域201に書き込み、制御部102は、通知領域201に書き込まれた切り替え通知を取得する。これにより、制御部12は、制御部102に対して切り替え通知を行う(ステップS112)。
制御部102は、制御部12から切り替え通知を受けると、バススイッチであるスイッチ17の切り替えを切替部101へ通知する。そして、切替部101は、スイッチ17をUSB通信部14に切り替える(ステップS113)。
その後、移行元である遠隔操作通信装置100のCPUが動作を停止する(ステップS114)。
次に、図5を参照して、切替元、切替先及び3G通信モジュール2の間の切り替え処理におけるデータの流れを説明する。図5は、切り替え処理におけるデータの流れを表すシーケンス図である。ここで、紙面に向かって左端に書かれた切替元、3G通信モジュール2及び切替先のそれぞれから延びる線の間を結ぶ矢印はデータの流れを示している。また、図5は、紙面に向かって右に向かって時間の経過を表している。
まず、切替元と3G通信モジュール2との間で通信が行われている(ステップS201)。ここで、点線250で表される時点で切り替え要因が発生したものとする。
すると、切替元から切替先へ、アプリケーション情報が通知される(ステップS202)。これにより、切替先で、アプリケーションの設定が行われる。
また、切替元から切替先へ、ネットワーク情報が通知される(ステップS203)。これにより、切替先で、ネットワークの設定が行われる。
さらに、切替元から切替先へ、USB情報が通知される(ステップS204)。これにより、切替先で、USBの設定が行われる。
ここで、範囲Pの間は、プロトコルスタック設定部13及びプロトコルスタック設定部103により各ステップの処理が実現される。
その後、共通記憶部110に仮想3G通信モジュールが構成されると、切替元と3G通信モジュールとの間の通信が行われる(ステップS205)と共に、そのデータが切替元から切替先へ転送される(ステップS206)。これにより、切替先と3G通信モジュール2との間で同期が取られる。
その後、切替先から切替元へ、切り替え通知が行われる(ステップS207)。
これにより、スイッチ17により、3G通信モジュール2との接続が切替元から切替先へ切り替えられ(ステップS208)、これにより、切替元の通信は切断される(ステップS209)。
ここで、範囲Qの間は、同期部15及び同期部105並びに制御部12及び制御部102により各ステップの処理が実現される。
その後、接続先と3G通信モジュール2との間で通信が行われる(ステップS210)。
次に、図6を参照して、遠隔操作通信装置100のUSB通信部104から情報処理装置1本体のUSB通信部14への接続の切り替えの概略についてさらに説明する。図6は、切り替え処理の概略を表すシーケンス図である。図6において示す情報処理装置1は情報処理装置1本体を表している。
遠隔操作通信装置100は、受信したSOF300を用いて3G通信モジュール2と同期を取っている。ここで、一例として先頭のSOFにだけ符号を付けたが、遠隔操作通信装置100から延びている線上に記載されたブロックは全てSOFを表している。そして、遠隔操作通信装置100は、SOF300と同様にそれぞれのタイミングで他のSOFを用いて3G通信モジュール2と同期を取っている。
そして、一点鎖線で表されるタイミングで情報処理装置1本体が起動されるなどの切り替え要因が発生する(ステップS301)。
そこで、遠隔操作通信装置100は、情報処理装置1に対して、電源を供給すると共に、通信設定を通知する(ステップS302)。
電源の供給を受けて、情報処理装置1本体は起動する(ステップS303)。
次に、情報処理装置1は、各種通信設定を行う(ステップS304)。
この間、遠隔操作通信装置100から共通記憶部110にUSBディスクリプタが書き込まれ、仮想3G通信モジュールが構成される(ステップS305)。
そして、情報処理装置1本体では、3G通信モジュール2に対するUSBホストを構成する(ステップS306)。
その後、遠隔操作通信装置100は、受信したSOF300を共通記憶部110を介して情報処理装置1本体に転送する(ステップS307)。これにより、情報処理装置1本体は、SOF301〜303を取得する。そして、情報処理装置1は、SOF301〜303を受信したタイミングでUSB通信部14をリセットすることにより、USB通信部14を3G通信モジュール2に同期させる。すなわち、矢印402で表される間に、情報処理装置1は、USBエニュメレーションを行う。
そして、USBエニュメレーション完了後、情報処理装置1のUSB通信部14は、接続先を仮想3G通信モジュールから3G通信モジュール2へ切り替える(ステップS308)。この時点で、遠隔操作通信装置100のUSB通信部104と3G通信モジュール2との接続が切断される(ステップS309)。
その後、情報処理装置1本体は、SOF304で表されるSOFを取得して、3G通信モジュール2と同期を取る。その後、情報処理装置1本体は、3G通信モジュール2とUSB通信を行う。
すなわち、矢印401の間は遠隔操作通信装置100が3G通信モジュールとUSB通信を行い、その間の矢印402の間に情報処理装置1はUSBエニュメレーションを行ってしまい、矢印403では情報処理装置1が3G通信モジュールとUSB通信を行う。したがって、図6で示すように、矢印401と矢印403との間にタイムラグが無く、通信の中断が発生しないことが分かる。
図7は、情報処理装置のハードウェア構成図である。図7に示すように、情報処理装置1は、グラフィックコントローラ501、メインCPU502、メモリ503、チップセット504、ストレージ505、USBホスト506、バススイッチ507及び遠隔操作通信装置100を有している。
さらに、遠隔操作通信装置100は、サブCPU601、USBデバイス共通領域602、メモリ603、USBホスト604を有している。
グラフィックコントローラ501、メモリ503及びチップセット504は、メインCPU502とバスで接続されている。そして、チップセット504は、ストレージ505及びUSBホスト506とバスで接続されている。さらに、USBホスト506は、USBデバイス共通領域602及びバススイッチ507とバスで接続されている。
ストレージ505及びメモリ503により、図1における記憶部16の機能を実現している。また、ストレージ505にはOSやPUSHサービスのアプリケーションなどが記憶されている。
そして、メインCPU502、チップセット504及びメモリ503は、例えば、図1に示した切替部11、制御部12、プロトコルスタック設定部13及び同期部15等の機能を実現する。例えば、メモリ503は、図1に例示した切替部11、制御部12、プロトコルスタック設定部13及び同期部15等による処理を実現する各種プログラムを記憶している。そして、メインCPU502及びチップセット504は、これらの各種プログラムを読み出して実行することで、上述した各機能を実現するプロセスを生成する。
また、USBホスト506は、図1に示したUSB通信部14の機能を実現する。さらに、グラフィックコントローラ501は、プロセスの実行結果などといった各種データをモニタに表示する。
バススイッチ507は、図1に示したスイッチ17の機能を実現する。バススイッチ507は、3G通信モジュール2と接続され、さらにUSBホスト506及びUSBホスト604が切り替え可能に接続されている。
USBデバイス共通領域602、メモリ603及びUSBホスト604は、サブCPU601とバスで接続されている。USBデバイス共通領域602には、メインCPU502はUSBホスト506を介してアクセスでき、サブCPU601はUSBホスト604を介してアクセスできる。
USBデバイス共通領域602は、共通記憶部110を実現する。そして、サブCPU601及びメモリ603は、例えば、図1に示した切替部101、制御部102、プロトコルスタック設定部103及び同期部105等の機能を実現する。例えば、メモリ603は、図1に例示した切替部101、制御部102、プロトコルスタック設定部103及び同期部105等による処理を実現する各種プログラムを記憶している。そして、サブCPU601は、これらの各種プログラムを読み出して実行することで、上述した各機能を実現するプロセスを生成する。また、サブCPU601は、情報処理装置1のメインCPU502とは独立して動作する。すなわち、メインCPU502が動作していない状態でも、サブCPU601は処理を行うことができる。
また、USBホスト604は、図1に示したUSB通信部104の機能を実現する。
以上に説明したように、本実施例に係る情報処理装置は、情報処理装置本体の通信部又は遠隔操作通信装置の通信部のいずれか一方から他方へUSBデバイスの接続先を切替える場合に、切り替え前に仮想の通信モジュールを構成する。そして、切替先の通信部を構成した仮想の通信モジュールに仮想的に接続させることで、情報処理装置は、実際のUSBデバイスとの接続に対して必要な通信設定を予め行い、切り替え後に予め設定した通信設定を用いて実際のUSBデバイスとの通信を行う。これにより、切り替え後のUSBデバイスに対する通信設定を省略することができる。したがって、通信の再接続による一時不通を発生させること無く、情報処理装置本体の通信部又は遠隔操作通信装置の通信部のいずれか一方から他方へUSBデバイスの接続先を切替えることができる。すなわち、情報処理装置の起動やシャットダウンといった使用状況に応じて、切り替えが発生した場合でも、PUSHサービスを中断無く継続して提供することが可能となり、PUSHサービスの品質を高めることが可能となる。
1 情報処理装置
2 3G通信モジュール
11 切替部
12 制御部
13 プロトコルスタック設定部
14 USB通信部
15 同期部
16 記憶部
17 スイッチ
100 遠隔操作通信装置
101 切替部
102 制御部
103 プロトコルスタック設定部
104 USB通信部
105 同期部
106 記憶部
110 共通記憶部

Claims (5)

  1. OSを実行する第1の制御部と、
    前記OSから独立して動作する第2の制御部と、
    前記第1の制御部によって制御され、USBインタフェースによって外部ネットワークに接続して通信を行う第1通信部と、
    前記第2の制御部によって制御され、USBインタフェースによって前記外部ネットワークに接続して通信を行う第2通信部と、
    入力された通信設定を記憶する共通記憶部と、
    前記外部ネットワークの接続先を前記第1通信部又は前記第2通信部のいずれか一方から他方に切り替える切替部と、
    前記第2の制御部によって制御され、前記切替部が前記接続先を前記第2通信部から前記第1通信部へ切り替える場合、少なくともUSB設定及びネットワーク設定を含む前記第2通信部の通信設定を前記共通記憶部に書込む第2通信設定部と、
    前記第1の制御部によって制御され、前記第2通信設定部により前記共通記憶部に書込まれた前記第2通信部の通信設定を取得し、取得した該通信設定を前記第1通信部に設定する第1通信設定部とを備え、
    前記切替部は、前記第1通信設定部により前記第1通信部に前記第2通信部の通信設定が設定された後、前記第2通信部から前記第1通信部へ前記外部ネットワークの接続先を切り替える
    ことを特徴とする情報処理装置。
  2. OSを実行する第1の制御部と、
    前記OSから独立して動作する第2の制御部と、
    前記第1の制御部によって制御され、外部ネットワークに接続して通信を行う第1通信部と、
    前記第2の制御部によって制御され、前記外部ネットワークに接続して通信を行う第2通信部と、
    入力された通信設定を記憶する共通記憶部と、
    前記外部ネットワークの接続先を前記第1通信部又は前記第2通信部のいずれか一方から他方に切り替える切替部と、
    前記第2の制御部によって制御され、前記切替部が前記接続先を前記第2通信部から前記第1通信部へ切り替える場合、前記第2通信部の通信設定を前記共通記憶部に書込む第2通信設定部と、
    前記第1の制御部によって制御され、前記第2通信設定部により前記共通記憶部に書込まれた前記第2通信部の通信設定を取得し、取得した該通信設定を前記第1通信部に設定する第1通信設定部とを備え、
    前記第1通信部は、前記第1通信設定部により前記第2通信部の通信設定が自己に設定された場合、前記共通記憶部に対して情報を書込み、且つ該書込んだ情報に対する応答が前記共通記憶部に書込まれた場合、該応答を読込むことで擬似的な通信を行い、該擬似的な通信が確立したか否かを判定し、
    前記第2通信部は、前記第1通信部により前記共通記憶部に書込まれた情報に対する応答を前記共通記憶部に書込み、
    前記切替部は、前記第1通信設定部により前記第1通信部に前記第2通信部の通信設定が設定された後、前記第1通信部によって擬似的な通信が確立したと判定された場合に、前記第2通信部から前記第1通信部へ前記外部ネットワークの接続先を切り替える
    ことを特徴とする情報処理装置。
  3. 前記第1の制御部によって制御され、前記切替部が前記接続先を前記第2通信部から前記第1通信部へ切り替える場合、前記第2通信部が前記外部ネットワークから受信した情報を前記共通記憶部に書込む第2同期部と、
    前記第2の制御部によって制御され、前記第2同期部によって前記共通記憶部書き込まれた情報を基に、前記第1通信部の動作を外部ネットワークからの通信に同期させる第1同期部と
    をさらに備えたことを特徴とする請求項1又は2に記載の情報処理装置。
  4. 前記切替部が前記接続先を前記第1通信部から前記第2通信部へ切り替える場合、
    第1通信設定部は、前記第1通信部の通信設定を前記共通記憶部に書込み、
    第2通信設定部は、前記第1通信設定部により前記共通記憶部に書込まれた前記第1通信部の通信設定を取得し、取得した該通信設定を前記第2通信部に設定し、
    前記切替部は、前記第2通信設定部により前記第2通信部に前記通信設定が設定された後、前記第1通信部から前記第2通信部への接続先の切り替えを行う
    ことを特徴とする請求項1〜のいずれか一つに記載の情報処理装置。
  5. OSを実行する第1のCPU及び前記OSから独立して動作する第2のCPUとを有する情報処理装置の制御方法であって、
    前記第1のCPUによって制御され、外部ネットワークに接続して通信を行う第1通信部から、前記第2のCPUによって制御され、前記外部ネットワークに接続して通信を行う第2通信部へ、前記外部ネットワークの接続先を切り替える場合、前記第2通信部における通信設定を共通メモリに書込み、
    前記共通メモリに書込まれた前記第2通信部の通信設定を取得し、
    取得した該通信設定を前記第1通信部に設定し、
    前記第2通信部の通信設定が前記第1通信部に設定された場合、前記第1通信部に、前記共通記憶部に対して情報を書込ませ、
    前記第2通信部に、前記第1通信部により前記共通記憶部に書込まれた情報に対する応答を前記共通記憶部に書込ませ、
    前記第1通信部が書込んだ情報に対する応答が前記共通記憶部に書込まれた場合、前記第1通信部に、該応答を読込ませることで擬似的な通信を行わせることで、該擬似的な通信が確立したか否かを判定し、
    前記第1通信部に前記第2通信部の通信設定が設定された後、前記擬似的な通信が確立したと判定した場合に、前記外部ネットワークの接続先を前記第1通信部から前記第2通信部へ切り替える
    ことを特徴とする情報処理装置制御方法。
JP2011081139A 2011-03-31 2011-03-31 情報処理装置及び情報処理装置制御方法 Active JP5699756B2 (ja)

Priority Applications (2)

Application Number Priority Date Filing Date Title
JP2011081139A JP5699756B2 (ja) 2011-03-31 2011-03-31 情報処理装置及び情報処理装置制御方法
US13/431,010 US9154448B2 (en) 2011-03-31 2012-03-27 Apparatus and method for switching connection to a communication network

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2011081139A JP5699756B2 (ja) 2011-03-31 2011-03-31 情報処理装置及び情報処理装置制御方法

Publications (2)

Publication Number Publication Date
JP2012217051A JP2012217051A (ja) 2012-11-08
JP5699756B2 true JP5699756B2 (ja) 2015-04-15

Family

ID=47021297

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2011081139A Active JP5699756B2 (ja) 2011-03-31 2011-03-31 情報処理装置及び情報処理装置制御方法

Country Status (2)

Country Link
US (1) US9154448B2 (ja)
JP (1) JP5699756B2 (ja)

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP6039339B2 (ja) * 2012-10-03 2016-12-07 キヤノン株式会社 画像形成装置、制御方法およびコンピュータプログラム
CN104469901B (zh) 2013-09-17 2018-09-07 华为终端(东莞)有限公司 数据处理的方法及装置
CN104392179A (zh) * 2014-10-08 2015-03-04 四川和芯微电子股份有限公司 Usb存储装置的加密方法
JP6458582B2 (ja) * 2015-03-20 2019-01-30 富士ゼロックス株式会社 情報処理装置及び情報処理プログラム
US10311001B2 (en) * 2017-10-09 2019-06-04 Getac Technology Corporation Electronic device and communication method thereof

Family Cites Families (28)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH02162457A (ja) * 1988-12-15 1990-06-22 Nec Corp マルチプロセッサシステム
US5530932A (en) * 1994-12-23 1996-06-25 Intel Corporation Cache coherent multiprocessing computer system with reduced power operating features
JPH10145456A (ja) * 1996-11-07 1998-05-29 Hitachi Ltd 通信制御の二重化システム
US6169789B1 (en) * 1996-12-16 2001-01-02 Sanjay K. Rao Intelligent keyboard system
GB2331379A (en) * 1997-11-13 1999-05-19 Advanced Telecommunications Mo Controlling access to a shared memory by dual mapping
JP2001186193A (ja) * 1999-12-24 2001-07-06 Fujitsu Ltd Ip通信インタフェース装置、回線交換機及びip通信ネットワークシステム
US20020032844A1 (en) * 2000-07-26 2002-03-14 West Karlon K. Distributed shared memory management
US7170851B1 (en) * 2001-07-26 2007-01-30 Ciena Corporation Systems and methods for automatic topology provisioning for SONET networks
FR2841669B1 (fr) * 2002-06-27 2006-01-06 St Microelectronics Sa Procede de transmission de paquets de donnees entre deux unites esclaves et une unite maitre comprenant deux processeurs
JP2004147251A (ja) * 2002-10-28 2004-05-20 Matsushita Electric Ind Co Ltd データ転送装置およびインタフェース制御半導体集積回路、ならびにプロトコル処理回路制御方法
JP4271520B2 (ja) * 2003-07-22 2009-06-03 株式会社リコー 画像形成装置
US7549145B2 (en) * 2003-09-25 2009-06-16 International Business Machines Corporation Processor dedicated code handling in a multi-processor environment
US20060098660A1 (en) * 2004-11-10 2006-05-11 Rajesh Pal Mechanism for automatic protection switching and apparatus utilizing same
US20070174429A1 (en) * 2006-01-24 2007-07-26 Citrix Systems, Inc. Methods and servers for establishing a connection between a client system and a virtual machine hosting a requested computing environment
KR100782592B1 (ko) * 2006-08-10 2007-12-06 엠텍비젼 주식회사 공유 메모리를 구비한 장치 및 공유 메모리 제어 방법
US20080062996A1 (en) * 2006-09-13 2008-03-13 Futurewei Technologies, Inc. Consumer Edge Initiated Pseudo-Wire Multi-Homing in Access Networks
US8296581B2 (en) * 2007-02-05 2012-10-23 Infineon Technologies Ag Secure processor arrangement having shared memory
US20080240093A1 (en) * 2007-03-28 2008-10-02 Horizon Semiconductors Ltd. Stream multiplexer/de-multiplexer
EP3806365B1 (en) * 2007-08-14 2022-10-05 Lg Electronics Inc. Method for acquiring resource region information for phich
US8014387B2 (en) * 2007-08-27 2011-09-06 International Business Machines Corporation Providing a fully non-blocking switch in a supernode of a multi-tiered full-graph interconnect architecture
US8374078B2 (en) * 2007-12-21 2013-02-12 Cisco Technology, Inc. Active fault management for metro Ethernet service over MPLS network
US7796585B2 (en) * 2008-05-21 2010-09-14 Dell Products, Lp Network switching in a network interface device and method of use thereof
KR101603108B1 (ko) * 2008-11-07 2016-03-14 엘지전자 주식회사 참조 신호 전송 방법
JP5377091B2 (ja) * 2009-06-05 2013-12-25 キヤノン株式会社 情報処理装置及びその制御方法
JP4830007B2 (ja) * 2009-06-22 2011-12-07 株式会社沖データ 画像形成装置
KR101670747B1 (ko) * 2009-06-30 2016-10-31 엘지전자 주식회사 제어 신호 자원의 유연한 할당
US20110151910A1 (en) * 2009-12-18 2011-06-23 Electronics And Telecommunications Research Institute Method and apparatus for allocating resources for physical channel in mobile communication system
US9317329B2 (en) * 2010-11-15 2016-04-19 Qualcomm Incorporated Arbitrating resource acquisition for applications of a multi-processor mobile communications device

Also Published As

Publication number Publication date
US9154448B2 (en) 2015-10-06
JP2012217051A (ja) 2012-11-08
US20120269193A1 (en) 2012-10-25

Similar Documents

Publication Publication Date Title
JP5597104B2 (ja) データ転送装置及びその制御方法
US7286252B2 (en) Printing system with enhanced efficiency in power-saving, printer, substitute server, and method and program used by the substitute server
JP5138100B2 (ja) 複数の通信インターフェイスを有する情報処理装置、該情報処理装置の制御方法
JP5699756B2 (ja) 情報処理装置及び情報処理装置制御方法
EP2306267A2 (en) Information processing apparatus, method for controlling the same, and program thereof
JP4512767B2 (ja) Usbデバイスの待機電力を省電力化する方法および省電力化するサーバコンピュータ
JP5377091B2 (ja) 情報処理装置及びその制御方法
JP2004157604A (ja) Usb機器制御方法および装置
US8665474B2 (en) Method, system, apparatus and medium for minimizing unnecessary processing associated with connection/disconnection of a same host
JP6550192B2 (ja) ネットワーク機器
JP5704904B2 (ja) データ処理装置、データ処理装置の制御方法及びプログラム
CN108885484B (zh) 远程终端设备、其控制方法、计算机系统和记录介质
JP5143191B2 (ja) 周辺装置を利用するためのシステム、サーバ装置、方法
JP2013020297A (ja) 集積回路装置及びその制御方法
JP2010244457A (ja) Usb通信制御方法、usb通信制御システム及びusbハブ機器
JPH11177598A (ja) ハブ装置およびハブ装置の通信方法およびコンピュータが読み出し可能なプログラムを格納した記憶媒体
JP2006059088A (ja) データ転送制御システム、電子機器及びプログラム
JP2010134508A (ja) ホットプラグ形式のデバイス機器を接続するための中継機器
EP2564578B1 (en) Port teaming
US9619005B2 (en) Apparatus and method for saving power of USB device
JP2015126445A (ja) 情報処理装置、情報処理方法、及びプログラム
JP2002335260A (ja) Usb中継装置
JP2016189617A (ja) デバイスおよびその制御方法、並びにプログラム
JP2018036810A (ja) デバイスサーバ
JP2004153742A (ja) ネットワーク機器及びネットワークシステム

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20140204

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20141127

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20141202

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20141226

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20150120

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20150202

R150 Certificate of patent or registration of utility model

Ref document number: 5699756

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150