JP2014053920A - 高データレートインターフェース装置および方法 - Google Patents

高データレートインターフェース装置および方法 Download PDF

Info

Publication number
JP2014053920A
JP2014053920A JP2013209726A JP2013209726A JP2014053920A JP 2014053920 A JP2014053920 A JP 2014053920A JP 2013209726 A JP2013209726 A JP 2013209726A JP 2013209726 A JP2013209726 A JP 2013209726A JP 2014053920 A JP2014053920 A JP 2014053920A
Authority
JP
Japan
Prior art keywords
packet
client
data
field
host
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.)
Pending
Application number
JP2013209726A
Other languages
English (en)
Inventor
Jon James Anderson
ジョン・ジェームズ・アンダーソン
Steel Brian
ブライアン・スティール
A Wiley George
ジョージ・エー.・ウィレイ
Shashank Shekhar
シャシャンク・シェカー
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.)
Qualcomm Inc
Original Assignee
Qualcomm 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 Qualcomm Inc filed Critical Qualcomm Inc
Publication of JP2014053920A publication Critical patent/JP2014053920A/ja
Pending legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/2866Architectures; Arrangements
    • H04L67/30Profiles
    • H04L67/303Terminal profiles
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/1066Session management
    • H04L65/1069Session establishment or de-establishment
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/1066Session management
    • H04L65/1101Session protocols
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/61Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/80Responding to QoS
    • 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/18Multiprotocol handlers, e.g. single devices capable of handling multiple protocols
    • 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/22Parsing or analysis of headers
    • 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/24Negotiation of communication capabilities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M1/00Substation equipment, e.g. for use by subscribers
    • H04M1/72Mobile telephones; Cordless telephones, i.e. devices for establishing wireless links to base stations without route selection
    • H04M1/724User interfaces specially adapted for cordless or mobile telephones
    • H04M1/72403User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality
    • H04M1/72409User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality by interfacing with external accessories
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M1/00Substation equipment, e.g. for use by subscribers
    • H04M1/72Mobile telephones; Cordless telephones, i.e. devices for establishing wireless links to base stations without route selection
    • H04M1/724User interfaces specially adapted for cordless or mobile telephones
    • H04M1/72403User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality
    • H04M1/72409User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality by interfacing with external accessories
    • H04M1/72412User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality by interfacing with external accessories using two-way short-range wireless interfaces
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D30/00Reducing energy consumption in communication networks
    • Y02D30/70Reducing energy consumption in communication networks in wireless communication networks

Abstract

【課題】デジタル制御データとプレゼンテーションデータのあらかじめ選択されたセットを通信するための通信プロトコルを形成するために一緒にリンクされたパケット構造を用いて通信路を介してホストとクライアントとの間でデジタルデータを転送するためのデジタルインターフェースを提供する。
【解決手段】信号プロトコルは、通信プロトコルを形成するパケットを発生し、送信し、受信するように構成され、デジタルデータを1つ以上のデータパケットのタイプに形成するように構成されたリンクコントローラーにより使用され、リンクコントローラーの少なくとも1つはホスト装置に常駐し、通信路を介してクライアントと接続される。
【選択図】図3

Description

35米国特許法第119条に基づく優先権の主張
この特許出願は、この出願の譲受人に譲渡され参照することにより明示的にここに組み込まれる、2004年3月24日に出願した「切替可能なしきい値差動インターフェース」(Switchable Threshold Differential Interface)というタイトルの米国仮出願第60/556,345の優先権を主張する。
分野
この開示における発明の実施形態は、デジタルシグナルプロトコル、プロセス、および高データレートでホスト装置とクライアント装置との間で信号を通信または転送する集積回路およびコンポーネントを含む装置に関する。
さらに具体的には、本開示は、内蔵デバイスアプリケーション及び外部デバイスアプリケーションを有する低電力高データレート転送機構を使用して、エンドユーザに対するプレゼンテーション又はディスプレイのためにホスト又はコントローラーデバイスからクライアントデバイスにマルチメディア及び他の種類のデジタル信号を転送する技法に関する。
技術背景
コンピューター、電子ゲーム関連製品及び多様なビデオ技術(例えばデジタルバーサタイルディスク(DVD’s)及び高解像度VCR)は、いくつかの種類のテキストを含むときにもますます高解像度化する静止画像、ビデオ画像、ビデオオンデマンド画像、及びグラフィック画像をこのような装置のエンドユーザへのプレゼンテーションに備えるために過去数年間に著しく進歩した。
同様に、これらの進歩により高解像度ビデオモニタ、高解像度テレビジョン(HDTV)モニタ、又は特殊画像投影要素などのさらに高解像度の電子表示装置の使用を使用しなければならなくなった。コンパクトディスク(CD)型音響再生、DVD、サラウンドサウンド、及び音声信号出力に関連する他の装置を使用するときなど、このような視覚映像を高解像度又は高品質音声データと組み合わせることは、エンドユーザのためによりリアリスティックなコンテンツリッチな、又は真のマルチメディア経験を作り出すために使用される。加えて、MP3プレーヤなどのきわめて移動性の高品質サウンドシステム及びミュージックトランスポート機構がエンドユーザに対する音声専用プレゼンテーションのために開発された。これは、コンピューターからテレビ及び電話まで、現在、高品質つまり品質を誇る生産に慣れ、それを期待している市販の電子機器の典型的なユーザの期待を高める結果となった。
電子製品を必要とする典型的なビデオプレゼンテーションシナリオでは、ビデオデータは、通常、毎秒約1キロビットから10キロビットである、よくても低速又は中速と呼べる速度で現在の技法を使用して転送される。次にこのデータは所望される表示装置上での遅れた(後の)再生のためにバッファに入れられるか、あるいは一時的な又は長期の記憶装置に記憶されるかのどちらかである。例えば、画像は画像をデジタルで表すのに有効なデータを受信又は送信するためにモデム又はインターネット接続装置を有するコンピューターに常駐するプログラムを使用するインターネット「全体で」又はインターネットを使用して転送されてよい。類似する転送は無線モデム又は無線パーソナルデータアシスタント(PDA)又は無線電話を備えるポータブルコンピューターなどの無線装置を使用して行うことができる。
データはいったん受信されると、プレイバックのために内蔵記憶装置又は小型ハードディスク等の外部記憶装置を含むランダムアクセスメモリ(RAM)又はフラッシュメモリなどのメモリエレメント、記憶回路又はメモリ素子に記憶される。データ量と画像解像度に応じて、プレイバックは相対的に迅速に開始するか、あるいはより長期間の遅延を伴なって提示される可能性がある。すなわち、いくつかの例では、画像プレゼンテーションは、多くのデータを必要としない、あるいは何らかのタイプのバッファリングを使用する非常に小さい又は低い解像度の画像にはある程度のリアルタイムプレイバックを可能にし、その結果より多くのデータが転送されている間に、少し遅延した後にいくらかのデータが提示される。転送リンクに中断がない、あるいは使用されている転送チャネルに関して他のシステム又はユーザからの干渉がないならば、いったんプレゼンテーションが開始すると、転送は表示装置のエンドユーザに適度にトラスペアレントである。結線されたインターネット接続のような単一の通信路を複数のユーザが共用する場合、転送は割り込まれたり、所望されるより低速になる可能性がある。
静止画像又は動画ビデオのどちらかを作成するために使用されるデータは、通信リンク上でのデータの転送を加速するために、多くの場合、ジェイペグ(Joint Photographic Experts Group)(JPEG)、エムペグ(Motion Picture Experts Group)(MPEG)、及びメディア業界、コンピューター業界、及び他の通信業界の周知の規格組織又は企業によって指定される技法等のいくつかの周知の技法の1つを使用して圧縮される。これにより、既定量の情報を転送するためにより少ないビット数を使用してより速く画像又はデータを転送することが可能になる。
データがいったんメモリあるいは磁気記憶素子又は光学記憶素子などの保存メカニズムを有するコンピューター又は他の受取人装置などの「ローカル」デバイスに転送されると、結果として生じる情報は解凍され(あるいは特殊な復号プレーヤを使用して再生され)、必要な場合には復号され、対応する使用可能な提示解像度及び制御要素に基づいて適切なプレゼンテーションのために準備される。例えば、Xピクセル×Yピクセルの画面解像度に関して典型的なコンピュータービデオ解像度は、一般的には所望されるようにあるいは必要に応じて種々の他の解像度が可能であるが、通常、480ピクセル×640ピクセルほどの低さから600×800から1024×1024の範囲である。
画像プレゼンテーションは、画像コンテンツ及び既定のビデオコントローラーの特定の所定のカラーレベル又はカラー階調(色を生じさせるために使用されるピクセルあたりビット)及び輝度に関して画像を操作する能力、及び追加の利用されているオーバヘッドビットによっても影響を受ける。例えば典型的なコンピュータープレゼンテーションは、他の値にも遭遇するが、多様な色(陰影と色相)を表現するために1ピクセルあたり約8から32以上のビットを予想するであろう。
前記値から、既定の画面画像はそれぞれ最低から最高の典型的な解像度と深度の範囲で約2.45メガビット(Mb)から約33.55Mbのデータの転送を必要とすることが分かる。毎秒30コマの速度でビデオ又は動画タイプの画像を見るとき、必要とされるデータ量は毎秒約73.7メガビットから1,006メガビット、つまり毎秒9.21メガバイトから125.75メガバイトである。加えて、マルチメディアプレゼンテーション用の画像と共に、あるいはCD品質の音楽などの別個の高解像度音声プレゼンテーションとして音声データを提示することを所望する場合がある。対話型コマンド、コントロール、又は信号を処理する追加の信号も利用されてよい。これらのオプションの各々は、転送されるより多くのデータを追加する。さらにHDTV及び映画の録画を含む最新の送信技術は、さらに多くのデータと制御情報を追加してもよい。いずれにせよ、高品質又は高解像度の画像データと高品質音声情報又はデータ信号をコンテンツリッチな経験を生じさせるためにエンドユーザに転送することを所望するとき、プレゼンテーション要素と、このようなタイプのデータを提供するように構成されるソース又はホストデバイスの間では高データ転送レートリンクが必要とされる。
1秒あたり約115キロバイト(KBps)又は920キロビット(Kbps)のデータレートは、現代のシリアルインターフェースによって日常的に処理できる。USBシリアルインターフェースなどの他のインターフェースは、12Mbpsほどの速度のデータ転送に対処し、米国電気電子技術者協会(IEEE)1394規格を使用して構成される転送などの特殊高レート転送が約100MBpsから400MBpsの速度で行われる。残念なことにこれらの速度は、ポータブルビデオディスプレイ又は音声デバイスを駆動するための高解像度でコンテンツリッチな出力信号を提供するために未来の無線データ装置とサービスと共に使用するために意図される前述された所望される高データレートには及ばない。これは、事業用コンピューター及びその他のプレゼンテーション、ゲーム機などを含む。加えて、これらのインターフェースは、操作するためにはかなりの量のホスト又はシステム及びクライアントソフトウェアの使用を必要とする。そのソフトウェアプロトコルスタックは、特にモバイルワイヤレス機器又は電話の応用例が意図される場合に、望ましくないほど大量のオーバヘッドも生じさせる。このような装置はすでに課されている計算能力だけではなく、厳しいメモリ制限と電力消費量制限も有する。さらに、これらのインターフェースのいくつかは、高度に美的指向のモバイル応用例には重すぎ、不満足な嵩張るケーブル、コストを追加する、つまり単に消費電力が多すぎる複雑なコネクタを活用する。
アナログビデオグラフィックスアダプタ(AVGA)、デジタルビデオインタラクティブ(DVI)又はギガビットビデオインターフェース(GVIF)インターフェースなどの他の公知のインターフェースがある。これらの最初の2つは、さらに高い転送レートでデータを処理するが、重いケーブルも利用し、大量の電力、つまり約数ワットを消費する並列型インターフェースである。これらの特性のどれも携帯型家庭用電子機器と使用するために修正できない。3番目のインターフェースも電力消費が大きすぎ、高価なあるいは嵩張るコネクタを使用する。
前記インターフェースのいくつか、及び他の非常に高レートデータシステム/プロトコル又は固定インストールコンピューター装置用のデータ転送と関連付けられた転送機構の場合、別の主要な欠点がある。所望されるデータ転送速度に対処することは、大量の電力及び/又は高電流レベルでの動作も必要とする。これは、高度に移動性の消費財のためのこのような技法の実用性を大きく削減する。
一般的には例えば光ファイバ型接続及び転送要素などの代替策を使用してこのようなデータ転送速度に対処することは、真に商業的な消費財に所望されるよりはるかに高い複雑度と費用をもたらす多くの追加の変換器及び要素も必要とする。今のところは、光学系の一般的に高価な性質は別として、その電力要件と複雑度が軽量で低電力の携帯型応用例のための一般的な使用を妨げる。
携帯型、無線又はモバイル応用例のために業界で欠如してきたものは、それが音声であるのか、ビデオであるのか、あるいはマルチメディアベースであるのかに関係なく、きわめて移動性の高いエンドユーザ向けの高品質のプレゼンテーション経験を提供するための技法である。すなわち、携帯型コンピューター、無線電話、PDA又は他の高度に移動性の通信デバイス又は装置を使用するとき、使用されている現在のビデオプレゼンテーションシステム又はデバイス及び音声プレゼンテーションシステム又はデバイスは単に所望される高品質レベルで出力を配信することができない。多くの場合、欠如している知覚される品質は、高品質プレゼンテーションデータを転送するために必要とされる入手できない高データレートの結果である。これは、エンドユーザに対するプレゼンテーションのためのより効率的で高度なあるいは機能満載(feature laden)の外付け装置への転送と、コンピューター、ゲーム機などの携帯装置と携帯電話などの無線装置の内部のホストとクライアント間の転送も含むことがある。
後者の場合、さらに高解像度の内蔵ビデオ画面、及び他の特殊入力装置及び/出力装置及び接続をいわゆる第三世代電話のような無線装置に、及びいわゆるラップトップコンピューターに追加する上で大きな前進があった。しかしながら、ホスト及び/又は多様な他の制御要素及び出力構成要素が存在する、ビデオ画面又は他の要素を主要筐体に取り付ける又は接続する、回転式又はスライド式蝶番又は蝶番状の構造にかかるブリッジを含んでよい内蔵データバスと接続。これらは一般的に高帯域幅のまたは高スループットのインターフェースである。一例としては、例えば、無線電話で所望されるスループットを達成するためには最高90個の導体を必要とすることがある従来の技法を使用する高スループットデータ転送インターフェースを構築することは非常に困難である。現在の解決策は、相互接続をより高価に、より低い信頼性と、装置の機能と干渉する可能性がある放射妨害波を潜在的に発生させることができる相対的に高い信号レベルを有したパラレルインターフェースを採用することを含む。これは、克服しなければならない多くの製造の桁違いの費用がかかる信頼性に課題がある問題を提示する。
このような問題点及び要件は、一例として、高度なデータ機能、インターネット及びデータ転送接続又は内蔵エンターテインメントを提供するために、通信装置又は計算型装置が電気製品及び他の消費者装置に追加される、固定されたロケーションのシステムにも見られる。別の例は、個別ビデオ及び音声プレゼンテーション画面がシートバックに取り付けられた、飛行機及びバスであろう。しかしながら、これらの状況では多くの場合、メイン記憶装置、処理要素及び通信制御要素を、情報のプレゼンテーションのための相互接続リンク又はチャネルとの可視画面又は音声出力からある距離離れて位置させる方が、より便利で効率的、且つ容易に実用的である。このリンクは、前述されたように所望のスループットを達成するために大量のデータを処理することを必要とする。
したがって、データを提供するホストデバイスとエンドユーザに出力を提示するクライアントディスプレイ装置又は要素の間のデータスループットを高めるためには新しい転送機構が必要とされる。
出願人は、そのような新しい転送機構を、2001年12月14日に出願された米国特許出願シリアル番号第10/020,520であって、現在は、2004年7月6日にZou他に発行された米国特許第6,760、772、および2002年9月6日に出願された米国特許出願シリアル番号第10/236,657であって、両方ともタイトルは、「高データレート信号転送のための通信プロトコルおよびインターフェースの発生および実施」(Generating And Implementing A Communication Protocol And Interface For High Data Rate Signal Transfer)であり、両方ともこの出願の譲受人に譲渡され、参照することによりここに組み込まれる。それらの出願で説明されている技法は、高レートデータ信号の中の大量のデータのための転送速度を大幅に改善できる。しかしながら、特にビデオプレゼンテーションに関して増加の一途を辿るデータレートに対する需要は伸び続ける。データ信号技術における他の継続中の開発をもってしても、依然としてなおさらに高い転送レート、通信リンク効率の改善、より強力な通信リンクを目指して努力する必要がある。したがって、ホストデバイスとクライアントデバイスの間のデータスループットを高めるために必要とされる新しい、あるいは改善された転送機構を開発する継続するニーズがある。
技術に存在する前記の欠点及び他は、新しいプロトコル及びデータ転送手段、方法及び機構が、高レートでホストデバイスと受取人クライアントデバイスの間でデータを転送するために開発された本発明の実施形態により対処される。
本発明の実施形態は、ホストデバイスとクライアントデバイス間のデジタル制御及びプレゼンテーションデータの事前に選択されたセットを通信するための通信プロトコルを形成するための複数の又は一連のパケット構造を利用する通信路上で、ホストデバイスとクライアントデバイス間で高レートでデジタルデータを転送するためのモバイルデータデジタルインターフェース(MDDI)を目的としている。信号通信プロトコル又はリンク層はホスト又はクライアントリンクコントローラー、受信機またはドライバーの物理層によって使用される。ホストデバイス内に常駐する少なくとも1台のコントローラーは通信路又はリンクを通してクライアントデバイスに結合され、通信プロトコルを形成するパケットを生成し、送信し、受信するように、及び1種類又は複数の種類のデータパケットにデジタルプレゼンテーションデータを形成するように構成される。インターフェースは、1つの共通した全体的なハウジング又はサポート構造内に常駐できる、ホストとクライアント間の情報の双方向転送を実現する。
インプリメンテーションは、一般的には、デジタルコンプリメンタリメタルオキサイドセミコンダクタ(CMOS)チップ上に容易に実現できる差動ドライバーと受信機を例外として本来すべてデジタルであり、6のように少ない信号を必要とし、システムデザイナにとって便宜的であるほとんどすべてのデータレートで動作する。簡略な物理層プロトコルとリンク層プロトコルにより統合は容易になり、ハイバネーション状態が加わったこの簡略さによりポータブルシステムは非常に低いシステム電力消費を有することができる。単純な物理的なリンクレイヤ・プロトコルは、統合することを簡単にする。また、ポータブルシステムはハイバネーションとこの単純性によって非常に低いシステム電源消費を持つことができる。
使用と受容に役立つために、インターフェースはデバイスのコストをほとんど増加せず、標準電池電圧を使用するインターフェースを通じてディスプレイに電力を供給できる一方、電力をほとんど消費しないで済むようにし、ポケットサイズのフォームファクタを有する装置に対処できる。インターフェースはHDTVを超える解像度をサポートするためにスケラブルであり、表示措置に対する同時ステレオビデオと7.1音声をサポートし、任意の画面領域への条件付更新を実行し、両方向での複数のデータタイプをサポートする。
本発明の実施形態の更なる態様では、少なくとも1台のリンクコントローラー、受信機、装置、またはドライバーがクライアントデバイス内に配置され、通信路又はリンクを通じてホストデバイスに結合される。クライアントリンクコントローラーも通信プロトコルを形成するパケットを生成し、送信し、受信するように、及び1種類又は複数の種類のデータパケットにデジタルプレゼンテーションデータを形成するようにも構成される。
一般的には、ホスト又はリンクコントローラーはコマンド又は特定の種類の信号作成及び照会処理で使用されるデータパケットを処理するための状態機械を利用するが、通信プロトコルで使用されるデータ及びあまり複雑ではないパケットのいくつかを操作するためにより低速の汎用プロセッサを使用できる。ホストコントローラーは、1台又は複数台の差動ラインドライバーを備える。一方クライアントレシーバは通信路に結合される1台又は複数台の差動ラインレシーバを備える。
パケットは、様々な可変長を有する所定数のパケットと共に所定の固定長を有するホストデバイスとクライアントデバイス間で通信されるメディアフレーム内で共にグループ化される。パケットはそれぞれパケット長フィールド、1つ又は複数のパケットデータフィールド、及びサイクリックリダンダンシーチェックフィールドを備える。サブフレームヘッダーパケットはホストリンクコントローラーからの他のパケットの転送の始めに転送される又は配置される。1つ又は複数のビデオストリーム型パケット及び音声ストリーム型パケットは、クライアントデバイスユーザへのプレゼンテーションのために、順方向リンクで、ホストからクライアントへそれぞれビデオタイプデータと音声タイプデータを転送するために通信プロトコルによって使用される。1つ又は複数の逆方向リンクカプセル化タイプのパケットはクライアントデバイスからホストリンクコントローラーにデータを転送するために通信プロトコルによって使用される。いくつかの実施形態におけるこれらの転送は、少なくとも1つのMDDIデバイスを有する内蔵コントローラーから内蔵ビデオ画面へのデータの転送を含む。他の実施形態は内部サウンドシステムへの転送及びジョイスティック及び複雑なキーボードを含む多様な入力装置から内蔵ホストデバイスへの転送を含む。
フィラー型パケットは、データを有さない順方向リンク伝送の期間を占有するために、ホストリンクコントローラーによって生成される。複数の他のパケットは、ビデオ情報を転送するために通信プロトコルによって使用される。このようなパケットは、カラーマップパケット、ビットブロック転送パケット、ビットマップ領域塗りつぶしパケット、ビットマップパターン塗りつぶし、及び透明カラーイネーブル型パケットを含む。ユーザ定義ストリーム型パケットは、インターフェースユーザ定義データを転送するために通信プロトコルによって使用される。キーボードデータと及びポインティングデバイスデータ型パケットは、前記クライアントデバイスと関連付けられるユーザ入力装置に、及びユーザ入力装置からデータを転送するために通信プロトコルによって使用される。リンクシャットダウン型パケットは、前記通信路上のどちらかの方向でのデータの転送を終了するため通信プロトコルによって使用される。
システム電力消費またはシステムリソース上のドレインを最小にするために、ディスプレイのようなクライアントが使用されていないときまたは現在の能動的使用にあるとき、特定のディスプレイコントローラーハードウェアを低電力状態にセットするための構造、手段、または方法を供給するためにディスプレイ電力状態パケットが発生される。一実施形態において、クライアントは、クライアント機能パケットのクライアントフューチャー機能インジケータフィールドのビット9を用いてディスプレイ電力状態パケットに応答する能力を示す。
ディスプレイ電力状態パケットの一実施形態のフォーマットにおいて、このタイプのパケットは、パケット長、パケットタイプ、hClientID、電力状態、および巡回冗長検査(CRC)フィールドを有するように構成される。このタイプのパケットは一般的に2バイトタイプフィールドにおけるタイプ75パケットとして識別される。2バイトhClientIDフィールドは、ClientIDのために予約される情報または値を含む。電力状態フィールドは、あるあらかじめ選択されたビットの値に従って、特定のディスプレイを特定の電力状態にセットするために使用される情報を特定する。2バイトCRCフィールドは、パケット長を含むパケット内のすべてのバイトのCRCを特定するまたは含む。
通信路は一般的に4つ以上のコンダクタおよびシールドのシリーズを有するケーブルを含むまたは採用する。さらに、フレキシブル基板上に存在するいくつかと共に、所望に応じて、印刷配線またはコンダクタを使用することができる。
ホストリンクコントローラーは、前記クライアントが前記インターフェースを通じてどのような種類のデータとデータタイプに対処できるのかを決定するためにクライアントデバイスから表示能力情報を要求する。クライアントリンクコントローラーは、少なくとも1つのクライアント機能型パケットを使用して表示能力又はプレゼンテーション機能をホストリンクコントローラーに伝達する。複数の転送モードが通信プロトコルによって使用され、それぞれは既定の期間で平行して異なる最大数のデータのビットの転送を可能にし、それぞれのモードはホストリンクコントローラーとクライアントリンクコントローラーの間の交渉によって選択可能である。これらの転送モードはデータの転送中に動的に調整可能であり、順方向リンクで使用されるのと同じモードが逆方向リンクで使用される必要はない。
本発明のいくつかの実施形態の他の態様では、ホストデバイスは、無線電話、無線PDA、又はその中に配置される無線モデムを有するポータブルコンピューター等の無線通信装置を備える。典型的なクライアントデバイスはマイクロディスプレイ装置及び/又は携帯型音声プレゼンテーションシステム等のポータブルビデオディスプレイを備える。さらに、ホストはクライアントデバイスユーザに提示されるために転送されるプレゼンテーションデータ又はマルチメディアデータを記憶するための記憶手段又は要素を使用してよい。
いくつかの実施形態のさらに他の実施形態では、ホストデバイスは、無線電話、無線PDA又はポータブルコンピューター等の無線通信装置などの携帯型電子装置内に常駐する、後述されるような、ドライバー付きのコントローラー又は通信リンク制御装置を備える。この構成の典型的なクライアントデバイスは、クライアント回路又は集積回路、あるいはホストに結合され、同装置内に常駐する、及び携帯電話用の高解像度画面等の内蔵ビデオディスプレイ、及び/又は携帯型音声プレゼンテーションシステムに結合される、代替の何らかの種類の入力システム又は装置の中のモジュールを備える。
この発明のさらなる特徴と利点並びに種々の実施形態の構造と動作は、添付図面を参照して以下に詳細に記載される。図面において、類似の参照番号は一般的に同一の、機能的に類似の、および/または構造的に類似のエレメントまたは処理ステップを示す。
I.概要
本発明の全般的な目的は、後述されるように、「シリアル」型のデータリンク又はチャネルを使用して、表示要素等のホストデバイスとクライアントデバイス間の短距離通信リンクでの高レート又は非常に高レートのデータ転送を可能にする、費用効果が高く、電力消費が低い転送機構をもたらすMDDIを提供することである。本機構は、特に、(ハウジング又はサポートフレーム内部の)ディスプレイまたは出力エレメントまたは装置、または中央コントローラーまたは通信エレメントまたは装置の入力装置に接続するのに特に有用な小型コネクタと薄い可撓ケーブルを用いて実施するのに適している。さらに、この接続機構は、ウェアラブルマイクロディスプレイ(ゴーグルまたはプロジェクター)のような外部ディスプレイエレメントまたは装置、または他のタイプの視覚の可聴の触知できる情報プレゼンテーション装置を、ポータブルコンピューター、無線通信装置またはエンターテイメント装置に接続するのに非常に有用である。
用語モバイルとディスプレイはプロトコルの命名に関連しているが、これがインターフェースとプロトコルを扱う仕事をする当業者により容易に理解される標準的な名称を有するという点でのみの便宜上であることが理解されなければならない。それは、ビデオエレクトロニクススタンダードアソシエーション(VESA)規格およびその規格の種々のアプリケーションに関連するであろう。しかしながら、以下の提示される実施形態を検討後、多くの移動性ではなく、ディスプレイに関係しない応用例がこのプロトコルの適用及び結果として生じるインターフェース構造から恩恵を受け、MDDIラベルが本発明の性質又は有効性、あるいは多様な実施形態に対する制限を暗示することを目的としないことが容易に理解されるであろう。
本発明の実施形態の利点とは、非常に柔軟でありながら、複雑度が低く、低コストで、信頼性が高く、使用環境によく適合し、非常に堅牢であるデータ転送のための技法が提供される点である。
本発明の実施形態は、様々な状況で使用することができ、大量のデータを通信または転送することができ、一般的には、オーディオ、ビデオまたはホストまたはソース装置からのマルチメディアアプリケーションのためのデータであり、そのようなデータは、特定の装置に転送したりそうでなければ処理されるように発生されて操作され、または、ビデオディスプレイまたはプロジェクションエレメント、オーディオスピーカーまたは他のプレゼンテーション装置のようなクライアントまたは受信装置に高レートで記憶される。後述される典型的な応用例は、ポータブルコンピューター又は無線電話又はモデムのどれかから、小型ビデオ画面あるいは小型投射レンズとスクリーンを含むゴーグル又はヘルメットの形を取る等のウェアラブルマイクロディスプレイ器具への、あるいはホストからこのような構成要素内のクライアントデバイスへのデータの転送である。すなわち、プロセッサまたはコントローラーから内部スクリーンまたは他のプレゼンテーションエレメントへ、並びにクライアントを採用する種々の内部のまたは外部の入力装置から内部的に位置する(同じ装置ハウジングまたはサポート構造に配置された)ホストに転送される、またはケーブルまたはコンダクタによりそれらに接続される。
MDDIの特性又は属性は、それらが特殊な表示技術又はプレゼンテーション技術と無関係であるほどである。これは、そのデータの内部構造に関わらず、あるいはそれが実現するデータ又はコマンドの機能上の態様に関係なく高レートでデータを転送するためのきわめて柔軟な機構である。これにより、例えば特定の装置の一意の表示要望等のある特定のクライアントデバイスの特異性に適応するように、あるいはいくつかのA−Vシステム用の結合された音声とビデオの、あるいはジョイスティック、タッチパッド等の特定の入力装置の要件を満たすように転送されているデータパケットのタイミングを調整できるようになる。選択されたプロトコルに従う限り、インターフェースは非常に表示要素又はクライアントデバイスに非常にとらわれない(agnostic)。加えて、集合シリアルリンクデータ、つまりデータレートは数桁変化することがあり、通信システム又はホストデバイス設計者がコスト、電力要件、クライアントデバイス複雑度、又はクライアントデバイス更新速度を最適化できるようにする。
データインターフェースは現在おもに「有線」信号リンク又は小型ケーブル上で大量の高レートデータを転送する際に使用するために提示される。しかしながら、いくつかの応用例では、インターフェースプロトコルのために開発された同じパケットとデータ構造を使用することが構成されるならば光ベースのリンクを含む無線リンクも利用してよく、十分に低い電力消費量又は実際的であり続ける複雑度での所望されるレベルの転送を持続できる。
II. 環境
典型的な応用例は、音声再生システム108と112と共に、それぞれ表示装置104と106とデータを通信しているポータブルコンピューター又はラップトップコンピューター100及び無線電話又はPDA装置102が示されている図1Aと図1Bに見られる。さらに、図1Aは、明確にするためだけに1つの図に示されているが、無線装置102にも接続可能である大型のディスプレイ又は画面114あるいは画像プロジェクター116への潜在的な接続を示す。無線装置は、現在データを受信できる、あるいは無線装置のエンドユーザによる表示及び/又は聴聞のための後のプレゼンテーション用に特定量のマルチメディアタイプデータを記憶素子又は記憶装置に過去に記憶した。典型的な無線装置は、大体の場合、音声及び単純なテキスト通信用に使用されるので、情報を装置102のユーザに通信するためにやや小型の表示画面と単純な音声システム(スピーカ)を有する。
コンピューター100は、はるかに大型の画面を有するが、依然として不適当な外部サウンドシステムを有し、高精細度テレビ又は映画のスクリーンなどの他のマルチメディアプレゼンテーション装置には及ばない。コンピューター100は図解の目的に使用され、他の種類のプロセッサ、対話型ビデオゲーム又は家庭用電子機器も本発明と共に使用できる。コンピューター100は無線通信のために無線モデル又は他の内蔵装置を利用できる、あるいは所望されるようにケーブル又は無線リンクを使用してこのような装置に接続できるが、これらに限定されない。
これにより、より複雑な、つまり「リッチな」データのプレゼンテーションが有効又は楽しい経験になる。したがって、業界はエンドユーザに情報を提示し、最小レベルの所望される楽しみ又は積極的な経験を提供するために他の機構及び装置を開発している。
前述されたように、装置100のエンドユーザに情報を提示するために複数の種類の表示装置が開発された又は開発されている。例えば、一社又は複数の企業が視覚的表示を提示するためにデバイスユーザの目の前で画像を投影するウェアラブルゴーグルのセットを開発した。正しく配置されると、このようなデバイスは、視覚的な出力を提供する要素よりはるかに大きい「仮想画像」を、ユーザの目によって知覚されるように効果的に「投射」する。つまり非常に小さい投射要素により、ユーザの目(複数の場合がある)は、典型的な液晶ディスプレイ(LCD)画面等で可能であるよりはるかに大規模に画像を「見る」ことができる。より大型の仮想画面画像を使用することにより、さらに限定されたLCD画面ディスプレイで可能となるよりはるかに高い解像度の画像の使用も可能になる。他の表示装置は、表面等の上に画像を映写するために、小型LCD画面又は多様なフラットパネルディスプレイ要素、映写レンズ及びディスプレイドライバーを含むことができるが、これらに限定されないであろう。
別のユーザに、又は代わりに信号を他のどこかに転送する又はそれらを記憶する別の装置に出力を提示するために無線装置102又はコンピューター100に接続されるあるいは無線装置102又はコンピューター100の使用に関連付けられる追加の要素もあってよい。例えば、データは、例えば書き込み可能CD媒体を使用して光学形式でフラッシュメモリに、あるいは後の使用のために磁気テープレコーダ及び類似する装置内等の磁気媒体に記憶されてよい。
加えて、多くの無線装置とコンピューターは現在、他の高度なサウンドデコーダとサウンドシステムだけではなく、内蔵MP3ミュージック復号機能も有している。ポータブルコンピューターは原則としてCDプレイバック機能とDVDプレイバック機能を活用し、いくつかは事前に記録された音声ファイル用を受信するための小型専用フラッシュメモリ読取装置も有する。このような機能を有することの問題点は、デジタルミュージックファイルが、復号とプレイバックプロセスが足並みを合わせることができる場合にだけであるが、きわめて強化されたフィーチャリッチ(feature rich)な経験を約束するという点である。同じことはデジタルビデオファイルにも当てはまる。
音声再生を支援するために、サブウーファー等の追加要素、あるいは前部と後部のサウンドプロジェクション用の「サラウンドサウンド」スピーカも加えることができるであろう外部スピーカ114が図1Aに示されている。同時に、スピーカ又はイヤホン108は、図1Bのマイクロディスプレイ装置のサポートフレーム又は機構にとって内蔵として示されている。知られているように、電力増幅装置又は音声整形装置を含む他の音声又はサウンド再生要素が使用できる。
いずれにせよ、前述されるように、データソースからエンドユーザに対して1つ又は複数の通信リンク110上で高品質又は高解像度の画像データ及び高品質の音声情報又はデータ信号を転送することを所望するときには高レートデータレートが必要とされる。すなわち転送リンク110は明らかに前述されたようなデータの通信では潜在的なボトルネックであり、現在の転送機構は通常所望されるような高レートデータレートを達成しないため、システム性能を制限している。例えば前述されたように、1024ピクセル×1024ピクセル等のさらに高解像度の場合、1ピクセルあたり24から32ビットのカラー階調と、30fpsというデータレートを用いると、データレートは755Mbps以上を凌ぐ速度に近づくことができる。加えて、このような画像は、音声データとおそらく対話型ゲーム又は通信に対処する追加の信号、あるいは多様なコマンド、制御又は信号を含むマルチメディアプレゼンテーションの一部として提示されてよく、量又はデータ及びデータレートをさらに増加する。
データリンクを確立するために必要なケーブル又は相互接続がより少ないということは、ディスプレイに関連付けられるモバイル機器がさらに使用しやすく、さらに大きなユーザベースに採用される可能性が高いことを意味することも明らかである。これは、特に、複数の装置が完全な視聴覚経験を確立するために一般的に使用される場合に、及びさらに特にディスプレイと出力装置の品質レベルが増加するにつれて当てはまる。
ビデオ画面及び他の出力装置や入力装置における前述の、及び他の改善に関する別の典型的な応用例は、音声再生システム136と146と共に、それぞれ「内蔵」表示装置134と144とデータを通信をしているポータブルコンピューター又はラップトップコンピューター130及び無線電話又はPDA装置140が示される図1Cと図1Dに見られる。
図2Aと図2Bでは、全体的な電子デバイス又は製品の小さな切取内部図が、今日のエレクトロニクス産業全体で使用されている何らかの公知のタイプの回転接続全体で、それらをビデオディスプレイエレメント又は対応するクライアントを有する画面に接続する汎用通信リンク、ここでは138と148を備えた装置の一部分の中の1つ又は複数の内部ホストとコントローラーの位置を示すために使用される。これらの転送に関与するデータ量が多数の導線がリンク138と148を構成することを必要とすることが分かる。このようなデータを転送するために使用可能な並行した、又は他の公知のインターフェース技法のタイプのために、このような装置上で高度なカラーインターフェースとグラフィックインターフェース、ディスプレイエレメントを活用する今日の増大する必要性を満たすためにこのような通信リンクは90以上の導線に近づいていると推定される。
残念なことに、該さらに高いデータレートは、単位時間あたりに転送される必要がある未処理のデータ量と信頼性のある費用効果の高い物理的な転送機構を製造するという両方の点において、データを転送するために現在使用可能な技術を超えている。
必要とされるのは、一貫して(さらに)低い電力、軽量、及び可能な限り簡略且つ経済的なケーブル布線構造を可能にする提示要素とデータソース間のデータ転送リンク又は通信路用のさらに高レートでデータを転送するための技法、構成、手段または方法である。出願人は、所望される低電力消費と複雑さを維持する一方で、モバイル機器、携帯機器又は固定位置の装置も所望されるディスプレイ、マイクロディスプレイ又は音声転送要素に非常に高レートでデータを転送できるようにするためにこれらの目標及び他の目標を達成するための新しい技法又は方法と装置を開発した。
III. 高レートデジタルデータインターフェースシステムアーキテクチャ
新しいデバイスインターフェースを作成し、効率的に活用するために、低電力信号で非常に高レートのデータ転送速度を提供する信号プロトコルとシステムアーキテクチャが考案された。該プロトコルはパケットと共通フレーム構造、つまりインターフェースに課されるコマンド又は操作構造と共にデータ又はデータタイプの事前に選択されたセットを通信するためのプロトコルを形成するために共にリンクされる構造に基づいている。
A. 概要
MDDIリンクによって接続される、あるいはMDDIリンク上で通信する装置はホストとクライアントと呼ばれ、他の出力装置と入力装置も意図されるが、クライアントは通常何らかのタイプの表示装置である。ホストからディスプレイへのデータは(順方向トラフィック又はリンクと呼ばれる)順方向で移動し、クライアントからホストへのデータは、ホストによりイネーブルされるように逆方向(逆方向トラフィック又はリンク)で移動する。これは図3に示される基本的な構成に描かれている。図3では、ホスト202は、順方向リンク208と逆方向リンク210を備えるとして描かれる双方向通信チャネル206を使用してクライアント204に接続される。しかしながら、これらのチャネルはそのデータ転送が順方向リンク動作と逆方向リンク動作の間で効果的に切り替えられる導線の1つの共通したセットにより形成されている。これにより、導線の数は大幅に削減され、モバイル電子デバイス向け等の低電力環境における現在の高レートデータ転送に対する手法が直面する多くの問題の1つに即座に対処できる。
他の箇所に説明されるように、ホストは、本発明を使用することから恩恵を受けることができる複数の種類の装置の内の1つを備える。例えば、ホスト202は携帯用デバイス、ラップトップ装置、又は類似するモバイル計算機器の形をしたポータブルコンピューターとなるであろう。それはPDA、ページング装置、又は多くの無線電話又はモデムの1つである場合もあるであろう。代わりに、ホスト202は携帯DVD又はCDプレーヤ、又はゲームプレイ装置等のポータブルエンターテインメント装置又は提示装置である場合もあるであろう。
さらに、ホストは、高レート通信リンクがクライアントと共に所望される、種々の他の広く使用されている、又は計画されている商品にホストデバイス又は制御要素として常駐できる。例えば、ホストは、ビデオ記録装置から応答の改善のために記憶装置ベースのクライアントに、あるいはプレゼンテーションのために高解像度大型画面に高レートでデータを転送するために使用できるであろう。インベントリーシステム又は計算システム、及び/又は他の家庭用装置に対するブルーツース(登録商標)接続を組み込んだ冷蔵庫等の電気製品は、インターネットモード又はブルーツース接続モードで動作しているときに改善された表示機能を有することができる、あるいは電子コンピューターシステム又は電子制御システム(ホスト)がキャビネット内のどこかに常駐する一方で、ドア内(in−the−door)ディスプレイ(クライアント)及びキーパッド又はスキャナ(クライアント)に対する配線のための書き込みニーズを削減した。一般的には、当業者は、新規の追加された又は既存のコネクタ又はケーブルのどちらかで使用可能な制限された数の導線を活用する情報のより高レートなデータレートトランスポートで旧い装置を改良する能力だけではなく、このインターフェースの使用から恩恵を受ける可能性のある種々の現代的な電子デバイスと家庭用製品を理解するであろう。
同時にクライアント204は、エンドユーザに情報を提示するため、あるいはユーザからホストに情報を提示するために有用な種々の装置を備えることができるであろう。例えばゴーグル又はめがねに組み込まれているマイクロディスプレイ、帽子又はヘルメットに内蔵されている映写装置、ウィンドウ又はフロントガラス等の車両に内蔵される小型画面又はホログラフィック素子、又は多様なスピーカ、ヘッドフォン、あるいは高品質のサウンド又は音楽を提示するためのサウンドシステム等である。他のプレゼンテーション装置は会議用、あるいは映画とテレビの画像用に情報を提示するために使用されるプロジェクター又は映写装置を含む。別の例は、実際にはユーザからの接触又はサウンド以外の「入力」はほとんどない装置又はシステムユーザから大量の情報を転送するように要求される可能性のあるタッチパッド又は敏感な装置、音声認識入力装置、セキュリティスキャナ等の使用であろう。加えて、コンピューター及びカーキット又はデスクキット、及び無線電話用のホルダのためのドッキングステーションは、エンドユーザ又は他のデバイスと装置に対するインターフェース装置として動作してよく、特に高レートネットワークが関係する場合にデータの転送を支援するためにクライアント(マウス等の出力装置又は入力装置)又はホストのどちらかを利用してよい。
しかしながら、当業者は、本発明がこれらの装置に限定されず、記憶とトランスポート、あるいはプレイバック時のプレゼンテーションのどちらかの点で高品質の画像とサウンドをエンドユーザに提供することを目的とした、市場には使用に提案される多くの他の装置があることを容易に認識するであろう。本発明は所望されるユーザ経験を実現するために必要とされる高データレートに対処するために多様な要素又は装置の間のデータスループットを増加するという点で有効である。
本発明のMDDインターフェース及び通信信号プロトコルは、コスト又は複雑度及び関連する電力と制御の要件又はこれらの接続の制約を削減するために、ホストプロセッサ、コントローラー、又は(例えば)回路構成要素及びデバイス又はデバイスハウジング又は構造内のディスプレイの間の相互接続を簡略化するために(内蔵モードと呼ばれる)、及び外部要素、デバイス又は機器に対する接続のため、又はそれらのためだけではなく信頼性を高めるため(外部モードと呼ばれる)に使用されてよい。
このインターフェース構造により利用される各信号ペアの集合シリアルリンクデータレートは、何桁も変化することがあり、システム又は装置設計者が、既定の用途又は目的のためにコスト、電力、インプリメンテーションの複雑度及び表示更新速度を容易に最適化できるようにする。MDDIの属性は表示又は他のプレゼンテーション装置(ターゲットクライアント)技術とは無関係である。インターフェースを通して転送されるデータパケットのタイミングは、表示装置、サウンドシステム、記憶素子と制御要素、又は視聴覚システムの結合されたタイミング要件等の特定のクライアントの特異性に適応するように容易に調整できる。これにより、電力消費が非常に小さいシステムを有することができる一方、少なくともなんらかのレベルでMDDIプロトコルを利用するためにフレームバッファを有することは多様なクライアントの要件ではない。
B. インターフェースタイプ
MDDIは、少なくとも4種類、おそらく5種類以上の通信業界及びコンピューター業界の何らかの異なる物理的な種類のインターフェースに対処するとして意図されている。それらが使用されている特定の用途あるいはそれらが関連している業界に応じて、他のラベル又は名称が当業者によって適用されてよいが、これらは単にタイプ1、タイプ2、タイプ3、及びタイプ4と名付けられている。例えば、単純な音声システムはより複雑なマルチメディアシステムより少ない接続を使用し、「チャネル」等の特徴を別に参照してよい等である。
このタイプ1インターフェースは6ワイヤ、又は他のタイプの導線又は導電素子、つまりそれを携帯電話又は無線電話、PDA、電子ゲーム、及びCDプレーヤ等のポータブル媒体プレーヤ、又はMP3プレーヤ、及び類似した装置又は類似したタイプの電子消費者技術で使用される装置にとって最適にするインターフェースとして構成される。一実施形態では、インターフェースはラップトップコンピューター、ノート型パソコン、又はデスクトップパソコン及び類似した装置又は用途により適し、迅速なデータの更新を必要とせず、内蔵MDDIリンクコントローラーを持たない8ワイヤ(導線)インターフェースとして構成できる。このインターフェースのタイプは、大部分のパソコンで見られる、既存のオペレーティングシステム又はソフトウェアサポートを適応させる上できわめて有効である追加の2線ユニバーサルシリアルバス(USB)インターフェースの使用によっても区別可能である。
タイプ2、タイプ3、およびタイプ4インターフェースは高性能クライアント又はデバイスに適切であり、データ信号に適切な遮蔽及び低損失転送を提供するために、追加のツイストペア型導線と共により大きくさらに複雑なケーブル布線を使用する。
タイプ1インターフェースは、ディスプレイ、音声、制御及び制限されたシグナリング情報を備えることができる信号を送出し、通常、高解像度全速度ビデオデータを必要としないモバイルクライアント又はクライアントデバイスのために使用される。タイプ1インターフェースは5.1チャネル音声が加えられた30fpsでスーパービデオグラフィックスアレイ(SVGA)解像度を容易にサポートでき、最小の構成で2組をデータ伝送用、1組を電力伝送用とする合計3組のワイヤ組だけを使用する可能性がある。この種のインターフェースはおもに、USBホストは信号の接続と転送のためのこのような装置内では使用できないモバイル無線機器等の装置向けである。この構成では、モバイル無線装置はMDDIホストデバイスであり、通常は、プレゼンテーション、表示又はプレイバックのためにクライアントに(順方向トラフィック又はリンク)データを送信するホストからの通信リンクを制御する「マスタ」として働く。
このインターフェースでは、ホストは、指定された期間それがバス(リンク)を占有し、逆方向パケットとしてデータをホストに送信できるようにするクライアントに特殊なコマンド又はパケットタイプを送信することによってクライアントからの通信データのホストでの受信(逆方向トラフィック又はリンク)を可能にする。これは、(後述される)カプセル化パケットと呼ばれる種類のパケットが転送リンク上での逆方向パケットの転送に対処し、逆方向リンクを生じさせるために使用される図4に描かれている。ホストがデータのためにクライアントをポーリングするために割り当てられた時間間隔がホストによって予定され、それぞれの指定された用途の要件に基づいている。この種の半二重双方向データ転送は、USBポートがクライアントからの情報又はデータの転送に使用できない場合に、特に有利である。
HDTV型又は類似した高解像度を可能にする高性能ディスプレイは、フルモーションビデオをサポートするために約1.5Gbpsレートのデータストリームを必要とする。このタイプ2インターフェースは並列で2ビットを送信することによって、このタイプ3は並列で4ビットを送信することによって高レートデータレートをサポートし、このタイプ4インターフェースは8ビットを並列で転送する。タイプ2とタイプ3インターフェースはタイプ1と同じケーブルとコネクタを使用するが、ポータブルデバイスでさらに高性能のビデオアプリケーションをサポートするためのデータレートの2倍及び4倍で動作できる。タイプ4インターフェースは、非常に高性能のクライアント又はディスプレイに適しており、追加のツイストペアデータ信号を備えるわずかに大きなケーブルを必要とする。
MDDIによって使用されるプロトコルは、各タイプ1、タイプ2、タイプ3又はタイプ4のホストが、通常、何が使用できる最高のデータレートなのかを交渉することによってタイプ1、タイプ2、タイプ3、またはタイプ4のクライアントと通信できるようにする。最も低機能の装置と呼ばれるものの能力又は使用可能な機能はリンクの性能を設定するために使用される。概して、ホストとクライアントが両方ともタイプ2、タイプ3、又はタイプ4のインターフェースを使用しているシステムの場合にも、両方ともタイプ1インターフェースとして動作を開始する。ホストは、次に、ターゲットクライアントの機能を決定し、特定の用途に適切なタイプ2、タイプ3、又はタイプ4のモードのどれかに応じてハンドオフ動作又は再構成動作を交渉する。
一般的には、ホストが(さらに後述される)適切なリンク層プロトコルを使用し、省電力のためにより低速なモードに通常どんなときでも下げる、つまり再び動作を設定し直す、あるいは高解像度表示コンテンツなどのより高レートな転送をサポートするためにより高レートなモードに上げることが可能である。例えば、ホストは、システムが電池等の電源からAC電力に切り替わるとき、あるいは表示媒体のソースがさらに低い解像度フォーマット又は高い解像度フォーマットに切り替わるときに、あるいはこれらの組み合わせ又は他の条件又は事象がインターフェースタイプ、つまり転送モードを変更する根拠とみなされてよいときにインターフェースタイプを変更してよい。
システムが一方向で1つのモードを使用し、別方向で別のモードを使用してデータを通信することも可能である。例えば、タイプ1モードがキーボード又はポインティングデバイス等の周辺装置からホストデバイスにデータを転送するときに使用され、タイプ4インターフェースモードは高レートでディスプレイにデータを転送するために使用できるであろう。ホストとクライアントが様々な速度で発信データを通信してよいことは当業者によって理解されるであろう。
多くの場合、MDDIプロトコルのユーザは「外部」モードと「内部モード」とを区別してよい。外部モードは、ある装置内のホストを、ホストから最高約2メートルくらいであるその装置の外部にあるクライアントに接続するためのプロトコルとインターフェースの使用を説明する。この状況では、ホストは、両方の装置がモバイル環境で容易に動作できるように外部クライアントに電力を送信してもよい。内部モードは、ホストが、共通ハウジング又はサポートフレームあるいは何らかの種類の構造内等、同じ装置の内部に含まれるクライアントにいつ接続されるのかを記述する。一例は、無線電話又は他の無線装置内、あるいはクライアントがディスプレイ又はディスプレイドライバー、あるいはキーパッド又はタッチパッド等の入力装置、又はサウンドシステムであり、ホストが中央コントローラー、グラフィックエンジン又はCPU要素であるポータブルコンピューター又はゲーム装置の応用例であろう。クライアントが外部モード応用例と対照的に内部モード応用例でのホストにはるかに近く位置するので、通常、このような構成ではクライアントに対する電力接続について説明される要件はない。
C. 物理インターフェース構造
ホストデバイスとクライアントデバイスの間で通信を確立するためのデバイス又はリンクコントローラーの一般的な配置が図5と図6に示されている。図5と図6では、MDDIリンクコントローラー402と502がホストデバイス202内に取り付けられて示され、MDDIリンクコントローラー404と504がクライアントデバイス204内に取り付けられて示される。前述されたように、ホスト202は、一連の導線を備える双方向通信チャネル406を使用してクライアント204に接続される。後述されるように、ホストコントローラーとリンクコントローラーの両方とも、ホストコントローラー(ドライバー)又はクライアントコントローラー(受信機)のどちらかとして対応するように設定、調整又はプログラミングできる単一の回路設計を使用して集積回路として製造できる。これは、単一回路デバイスのより大規模な製造のためのさらに低いコストを可能にする。
図6では、MDDIリンクコントローラー502はホストデバイス202'に取り付けられ、MDDIリンクコントローラー504はクライアントデバイス204'に取り付けられて示されている。前述されたように、ホスト202'は一連の導線を備える双方向通信チャネル506を使用してクライアント204'に接続される。前述されたように、ホストコントローラーとクライアントリンクコントローラーの両方とも単一回路設計を使用して製造できる。
MDDIリンク上で、あるいは使用されている物理的な導線の間でホストと表示装置等のクライアントの間で受け渡される信号も図5と図6に示されている。図5と図6で分かるように、MDDIを通してデータを転送するための一次的な経路又は機構はMDDI_Data0+/−MDI_Stb+/−と呼ばれるデータ信号を使用する。これらのそれぞれは、ケーブル内の差動組のワイヤで転送される低圧データ信号である。インターフェース上で送信されるビットごとにMDDI_Data0組又はMDDI_Stb組のどちらかで1つの遷移しかない。これは電流ベースではなく、電圧ベースの転送機構であるため、静的な電流消費はほぼゼロである。ホストはクライアントディスプレイにMDDI_Stb信号を駆動する。
データはMDDI_Data組上で順方向と逆方向の両方で流れることができる、つまりそれは双方向転送経路であるが、ホストはデータリンクのマスタ又はコントローラーである。MDDI_Data0とMDDI−Stb信号経路は雑音排除性を最大限にするために差動モードで操作される。これらの線路での信号のためのデータレートは、ホストによって送信されるクロックのレートで決定され、約1kbpsから400Mbps以上の範囲で可変である。
このタイプ2インターフェースは、MDDI_Data11+/−と呼ばれるこのタイプ1のそれを超える1つの追加データ組又は導線又は経路を含む。このタイプ3インターフェースはMDDI_Data2+/−及びMDDI_Data3+/−と呼ばれるタイプ2インターフェースのそれを超える2つの追加のデータ組又は信号経路を含む。このタイプ4インターフェースは、それぞれMDDI_data4+/−、MDDI_Data5+/−、MDDI_Data6+/−、及びMDDI_Data7+/−と呼ばれるこのタイプ3インターフェースのそれを超える4つのさらに多くのデータ組又は信号経路を含む。前記インターフェース構成のそれぞれでは、ホストはHOST_PwrとHOST_Gndと表されるワイヤ組又は信号を使用してクライアント又はディスプレイに電力を送ることができる。さらに後述されるように、電力伝達は、使用可能であるあるいは他のモードのために存在するよりさらに少ない導体を利用するインターフェース「タイプ」が使用されているとき、所望される場合、MDDI_Data4+/1、MDDI_Data+/−5、MDDI_Data6+/−、又はMDDI_Data7+/−の導線の上のいくつかの構成で対処できる。電力伝達は、通常外部モードに利用され、いくつかの応用例は異なってよいが、通常内部モードの必要性はない。
多様なモードについてMDDIリンク上でホストとクライアント(ディスプレイ)の間で受け渡される信号の要約は、インターフェースタイプに従って以下の表Iに描かれている。
Figure 2014053920
ホストからの転送のためのHOST_Pwr/Gnd接続が通常外部モードに提供されることにも注意する。内部応用例又は運転モードは、当業者に明らかであるように、通常、他の内部リソースから直接電力を引き出し、電力分配を制御するためにMDDIを使用しないクライアントを有するため、このような分配はここではさらに詳細に説明されない。
しかしながら、当業者によって理解されるように、例えば何らかの種類の電力制御、同期又は相互接続の便利さを可能にするために、MDDIを通して電力を配分できるようにすることは確かに可能である。通常、前記構造及び動作を実現するために使用されるケーブル布線の長さは約1.5メートル、通常2メートル以下であり、それぞれが同様にマルチストランドワイヤであり、公称的に32アメリカワイヤゲージ(AWG)と28AWGとの間である3本のツイストペアの導線を含む。ワイヤサイズはこのレンジに制限されないけれども、当業者が理解するように、電気的仕様または制約は、最大の合計のエンドツーエンド抵抗、1フィートあたりの最大容量、各ペアのインピーダンスおよびクロストークを満足しなければならない。
フォイルシールド被覆は、全体の、ここでは3つのツイストペア上でおよびさらなるドレインワイヤとしてドレインワイヤ上で覆われ、そうでなければ形成される。ツイストペアとシールドドレイン導線は、技術で周知であるように、シールドがクライアント用のシールドに接続されるクライアントコネクタで終端し、ケーブル全体を覆う絶縁層がある。該ワイヤは、HOST_GndとHOST_Pwr、MDDI_Stb+MDDI_Stb−、MDDI_Data0とMDDI_Data0−、MDDI_Data+とMDDI_Data1−等のように組にされる。しかしながら、特定の応用に基づき本発明の実施形態を実施するために様々な導電体及びケーブルが利用可能であることはこの技術分野において理解されるであろう。例えば、ある応用例ではケーブルを保護するために外側を充分に被覆するかまたは金属層でさえ使用することができ、一方他の応用では、薄く平らな導電リボンタイプの構造が良く適合するかも知れない。
D. データタイプおよびレート
一連のユーザ経験と応用例にとって有効なインターフェースを達成するために、モバイルデジタルデータインターフェース(MDDI)は、制御情報、及びその組み合わせと共に種々のクライアントと表示情報、音声トランスデューサ、キーボード、ポインティングデバイス及びモバイル表示装置に統合される、又はモバイル通信装置、計算装置または表示装置に合わせて作動する可能性のある他の多くの入力装置又は出力装置にサポートを提供する。MDDIは、最小数のケーブル又は導線を使用して、順方向又は逆方向のどちらかでホストとクライアント間で行き来するデータの種々の潜在的な種類のストリームに対処できるように設計される。等時性ストリームと非同期ストリーム(更新)の両方ともサポートされる。集合データレートが、最大シリアルレートと利用されるデータペア数により制限される最大所望MDDIリンクレート以下である限り、データ型の多くの組み合わせが考えられる。これらは、以下の表IIと表IIIに一覧表示されるそれらのアイテムを含むことがあるが、これらに限定されない。
Figure 2014053920
Figure 2014053920
インターフェースは固定されていないが、将来のシステム柔軟性のためにユーザにより定義されるデータを含む種々の情報「タイプ」の転送をサポートできるように拡張可能である。対処されるデータの特定の例は、全画面又は部分画面ビットマップフィールド又は圧縮ビデオのどちらかの形式のフルモーションビデオ、電力を節約し、インプリメンテーション費用を削減するための低速の静的ビットマップ、種々の解像度又は速度でのPCM又は圧縮音声データ、ポインティングデバイス位置と選択、ならびにまだ定義されなければならないユーザ定義可能なデータである。このようなデータは、装置の機能を検出する、あるいは操作パラメーターを検出するために制御情報又はステータス情報と共に転送されてもよい。
本発明の実施形態は、映画(ビデオディスプレイ及び音声)を見ること、個人表示が制限されたパソコン(グラフィックディスプレイ、ビデオと音声と結合されることもある)使用すること、ビデオゲームをPC、コンソール、又はパーソナルデバイス(動画グラフィックスディスプレイ又は同期ビデオと音声)でプレイすること、ビデオ電話(双方向低速ビデオと音声)、静止デジタル写真用カメラ、又はデジタルビデオ画像を捕捉するためのカムコーダの形でデバイスを使用してインターネットを「サーフィンすること」、電話、コンピューター又はプレゼンテーションを行うためにプロジェクターにドッキングされるか、ビデオモニタ、キーボード及びマウスに接続されるデスクトップドッキングステーションにドッキングされるPDAを使用すること、及び無線ポインティングデバイスとキーボードデータを含む携帯電話、スマートフォン、又はPDAによる生産性の強化又はエンターテインメントの用途を含むが、これらに制限されないデータ転送での使用のための技術を進展させる。
後述されるような高レートデータインターフェースは、大量のA−V型データを、通常はワイヤライン又はケーブル型リンクとして構成される通信リンク又は転送リンク上で提供するという点で提示される。しかしながら、信号構造、プロトコル、タイミング、又は転送機構が、それが所望されるレベルのデータ転送を持続できる場合に、光媒体又は無線媒体の形をとるリンクを提供するように調整できるであろうことは容易に明らかになる。
MDDI信号は、基本的な信号プロトコル又は構造用の共通フレームレート(CFR)として公知である概念を使用する。共通フレームレートを使用する背景にある考え方は、複数のストリームに対してクロックまたはフレームタイミングを導き出すために使用することができるレートでサブフレームヘッダーパケットを送信することにより、同時等時性データストリームに同期パルスを与えることである。サブフレームパケットが送信されるレートは、共通フレームレートである。クライアントデバイスはこの共通フレームレートを時間基準として使用できる。低CFレートは、サブフレームヘッダを送信するためにオーバヘッドを減少させることによりチャネル効率を高める。他方、高CFレートは待ち時間を減少させ、音声サンプル用にさらに小さく、融通の利くデータバッファを可能にする。本発明のCFRは動的にプログラム可能であり、特定の用途で使用される等時性ストリームに適切である多くの値の内の1つとして設定されてよい。つまり、CF値は、所望されるように、既定のクライアントとホスト構成に最も適するように選択される。
ビデオ又はミクロディスプレイ用等の用途と使用される可能性の高い等時性データストリーム用の調整可能又はプログラム可能であるサブフレームごとに通常必要とされるバイト数が表IVに示される。
Figure 2014053920
サブフレームあたりのバイトの部分的なカウントは、簡略なプログラム可能M/Nカウンタ構造を使用して容易に得られる。例えば、サブフレームあたり26−2/3バイトのカウントは、それぞれ26バイトの1つのサブフレームが後に続く27バイトを含む2つのサブフレームを転送することによって実現される。さらに小さいCFRは、サブフレームあたりのバイトの整数を生じさせるために選択されてよい。しかしながら、一般的にはハードウェア内で単純なM/Nカウンタを実現するためには、本発明の実施形態の一部又はすべてを実現するために使用される集積回路チップ又は電子モジュール内では、大型の音声サンプルFIFOバッファに必要とされる面積より少ない面積を必要とするはずである。
様々なデータ転送速度とデータ型の影響を描く例示的な応用例がカラオケシステムである。カラオケの場合、一人又は複数人のエンドユーザがミュージックビデオプログラムに沿って歌うシステム。歌の歌詞は、ユーザが歌われる歌詞と、大体歌のタイミングとを分かるように画面上のどこか、通常は最下部に表示される。この用途はグラフィック更新が不定期なビデオディスプレイ、及びユーザの1つの又は複数の声をステレオ音声ストリームと混合することを必要とする。
300Hzという共通フレームレートを想定する場合には、各サブフレームはクライアント表示装置に対する順方向リンク上での(ステレオの147個の16ビットのサンプルに基づき)92,160バイトのビデオコンテンツと588バイトの音声コンテンツからなり、平均26.67(26−2/3)バイトの音声がマイクから移動性カラオケ機械に送り返される。非同期パケットがホストとクライアント、おそらくヘッドマウント式のディスプレイの間で送信される。これは、底部に1/4スクリーンの高さを含み1秒の1/30の間隔または期間で歌詞テキストが更新され、他の種々雑多な制御およびステータスコマンドは、歌詞テキストが更新されないときにサブフレームで送信される。
表Vは、カラオケ例のサブフレーム内でデータがどのように割り当てられるのかを示す。
使用されている合計速度は約279Mbpsであるように選択される。280Mbpsというわずかに高いレートは、サブフレームあたり別の約400バイトのデータを転送できるようにし、臨時の制御メッセージとステータスメッセージの使用を可能にする。
Figure 2014053920
III.(続き)高レートデジタルデータインターフェースシステムアーキテクチャ
E.リンク層
MDDI高レートシリアルデータ信号を使用して転送されるデータは、次々にリンクされる時分割パケットのストリームからなる。たとえ送信側装置に送信するデータがなくても、MDDIリンクコントローラーは通常自動的にフィラーパケットを送信し、このようにしてパケットのストリームを維持する。単純なパケット構造の使用は、ビデオ信号又は音声信号あるいはデータストリームのための信頼性の高い等時性タイミングを確実にする。
パケットのグループは、サブフレームと呼ばれる信号要素又は構造の中に含まれ、サブフレームのグループはメディアフレームと呼ばれる信号要素又は構造の中に含まれる。サブフレームは、そのそれぞれのサイズとデータ転送用途に応じて1つ又は複数のパケットを含み、メディアフレームはもう1つのサブフレームを含む。ここに提示される実施形態により利用されるプロトコルによって提供される最大サブフレームは約232−1、つまり4,294,967,295バイトであり、最大メディアフレームサイズは約216−1、つまり65,535サブフレームとなる。
特殊なサブフレームヘッダーパケットは後述されるように各サブフレームの始まりに表示される一意の識別子を含む。その識別子は、ホストとクライアント間の通信が開始されるとクライアントデバイスでフレームタイミングを獲得するためにも使用される。リンクタイミング獲得は以下にさらに詳細に説明される。
通常、表示画面は、フルモーションビデオが表示されている間にメディアフレームあたりに一度更新される。該表示フレームレートは該メディアフレームレートと同じである。リンクプロトコルは、所望される応用例に応じて、ディスプレイ全体、あるいは静的画像によって囲まれるフルモーションビデオコンテンツの小さな領域だけでフルモーションビデオをサポートする。ウェブページ又はeメールを表示する等いくつかの低電力のモバイル応用例では、表示画面はときおりしか更新される必要がない場合がある。それらの状況では、単一のサブフレームを送信してから、電力消費を最小限にするためにリンクをシャットダウンする、又は非アクティブ化することが有利である。インターフェースはステレオビジョン等の効果もサポートし、グラフィックスプリミティブを処理する。
サブフレームは、システムが周期的に優先順位が高いパケットの伝送をイネーブルできるようにする。これにより、同時等時性ストリームは最小量のデータバッファリングと共存できる。これは、実施形態が表示プロセスに提供する1つの利点であり、複数のデータストリーム(ビデオ、音声、制御、ステータス、ポインティングデバイスデータ等の高レート通信)が本質的に1つの共通したチャネルを共用できるようにする。それは、比較的に少ない信号を使用して情報を転送する。また、それはCRTモニタの、あるいは他のクライアント技術に特殊な作用のための水平同期パルス及びブランキング間隔等の表示技術に特殊な作用が存在できるようにもする。
F. リンクコントローラー
図5と図6に示されているMDDIリンクコントローラーは、MDDIデータとストローブ信号を受信するために使用される差動ラインレシーバを例外として完全にデジタルなインプリメンテーションとなるように製造又は組み立てられる。しかしながら、差動ラインドライバーと差動ラインレシーバは、CMOS型ICを作成するとき等、リンクコントローラー付きの同じデジタル集積回路内でも実現できる。アナログ機能又は位相ロックループ(PLL)はビット回復のために、あるいはリンクコントローラー用のハードウェアを実現するために必要とされない。ホストコントローラーとクライアントリンクコントローラーは、リンク同期のために状態機械を含むクライアントインターフェースを例外として、非常に類似した機能を含む。したがって、本発明の実施形態は、ホスト又はクライアントのどちらかとして構成できる単一のコントローラー設計又は回路を作成できるという実用的な利点を可能にし、リンクコントローラーの製造コストを全体として削減できる。
IV.インターフェースリンクプロトコル
A.フレーム構造
パケット転送のために順方向リンク通信を実現するために使用される信号プロトコル又はフレーム構造が図7に描かれている。図6に示されているように、情報又はデジタルデータはパケットとして知られる要素にグループ化される。複数のパケットは同様に共にグループ化され、「サブフレーム」と呼ばれるものを形成し、複数のサブフレームが同様に共にグループ化され、「メディア」フレームを形成する。フレームの形成及びサブフレームの転送を制御するために、各サブフレームは、特にサブフレームヘッダーパケット(SHP)と呼ばれる所定のパケットで開始する。
ホストデバイスは既定の転送に使用されるデータレートを選択する。この速度は、ホストの最大転送機能、つまりホストによりソースから取り出されるデータ、及びクライアントの最大機能、つまりデータが転送されている先の他の装置の両方に基づいてホストデバイスによって動的に変更できる。
MDDI又は本発明の信号プロトコルと共に作業するために設計される、あるいは本MDDI又は本発明の信号プロトコルを扱うことができる受取人クライアントデバイスは、それが使用できる最大又は現在の最大データ転送速度を決定するためにホストにより照会できる、あるいは使用可能なデータ型とサポートされている特徴だけではなく、デフォルトのより低速な最小速度も使用されてよい。この情報は、さらに後述されるようにクライアント機能パケット(DCP)を使用して転送できるであろう。クライアント表示装置は、事前に選択された最小データレートで又は最小データレート範囲内でインターフェースを使用してデータを転送する、あるいは他の装置と通信することができ、ホストはクライアントデバイスの完全な機能を突き止めるためにこの範囲内のデータレートを使用して照会を実行する。
ビットマップ及びクライアントのビデオフレームレート機能の性質を定義する他のステータス情報は、ホストがインターフェースを実用的と同程度に効率的又は最適に構成できるようにステータスパケットでホストに転送できる、あるいは任意のシステム制約の中で所望される。
ホストは、現在のサブフレームの中に転送される(それ以上の)データがないときに、あるいはホストが順方向リンクに選ばれるデータ伝送速度に後れを取らないほど十分な速度で転送できないときにはフィラーパケットを送信する。各サブフレームはサブフレームヘッダーパケットで始まるため、前のサブフレームの最後は正確に前のサブフレームを充填するパケット(十中八九フィラーパケット)を含む。パケットにデータ本来を運ぶデータのための余地が欠如している場合、フィラーパケットはサブフレーム内の最後のパケットとなる、あるいは次の以前のサブフレームの終わりでおよびサブフレームヘッダーパケットの前に最後のパケットになる可能性が高い。サブフレーム内に、各パケットがそのサブフレーム内で送信されるための残りの十分な空間があることを保証することはホストデバイス内の制御動作のタスクである。同時に、いったんホストデバイスがデータパケットの送信を開始すると、ホストはデータアンダーラン状況を生じさせずにフレーム内でそのサイズのパケットを無事に完了できなければならない。
実施形態の一態様においては、サブフレーム伝送は2つのモードを有する。1つのモードは周期的なサブフレームモード、つまりライブビデオと音声ストリームを送信するために使用される周期的なタイミングエポックである。このモードでは、サブフレーム長は非ゼロであると定義されている。第2のモードは、新しい情報が入手可能であるときだけフレームがクライアントにビットマップデータを提供するために使用される非同期つまり非周期モードである。このモードはサブフレームヘッダーパケット内でサブフレーム長をゼロに設定することによって定義される。周期モード使用時、サブフレームパケット受信は、クライアントが順方向リンクフレーム構造に同期したときに開始してよい。これは、図49又は図63を参照して後述されている状態図に従って定義された「同期中」状態に相当する。非同期非周期サブフレームモードでは、第1のサブヘッダパケットが受信された後に受信が開始する。
B. 全体的なパケット構造
本実施形態において実行される通信または信号プロトコル、またはデータ伝送のための方法または手段を実行するために使用されるパケットのフォーマットまたは構造が以下で提示され、インターフェースは拡張性があり、そして追加のパケット構造が所望されるとおりに追加できることが留意される。パケットはインターフェースにおけるそれらの機能の用語でラベル付され、または異なった"パケットタイプに"分割され、これは伝送されまたは組み合わされるコマンド、情報、値、またはデータである。したがって、各パケットタイプは転送されているパケットとデータを操作する上で使用される規定のパケットの所定のパケット構造を示す。容易に明らかとなるように、パケットは事前に選択された長さを有するか、あるいはそれらのそれぞれの機能に応じた可変又は動的に変更可能な長さを有してよい。プロトコルが標準に受け入れられる間に変更されるときに発生するように、同じ機能が依然として実現されるとしても、パケットには異なる名称も付けることができるであろう。多様なパケットで使用されるバイト又はバイト値はマルチビット(8ビット又は16ビット)の符号なし整数として構成されている。タイプ順で一覧表示されるその「タイプ」名称と共に、利用されているパケットのまとめは、表VI−1からVI−4に図示される。
各表は、説明及び理解を容易にするために全体的なパケット構造の中のパケットの一般的な「タイプ」を表す。これらのグループ分けによって本発明について暗示される又は表される制限又は他の影響はなく、パケットは所望されるとおりに多くの他の様式で編成できる。パケットの転送が有効であると見なされる方向も注記される。
Figure 2014053920
Figure 2014053920
Figure 2014053920
Figure 2014053920
本文の他の説明から明らかである何かとは、サブフレームヘッダー、フィラー、リバースカプセル化、リンクシャットダウン、クライアント能力、およびクライアント要求およびステータスパケットがおのおの、外部モード動作の通信インターフェースの多くの実施例において非常に重要であると考えられており、必要でさえある。しかしながら、リバースカプセル化、リンクシャットダウン、クライアント能力、クライアント要求とステータスパケットは、内部動作モードの場合、オプショナルであると考えることができまたは考える可能性が高い。このことから、通信パケットの縮小セットを用いた非常に高レートのデータ通信、及び対応する制御とタイミングの簡略化を可能にするさらに別のタイプのMDDIインターフェースプロトコルが生じる。
パケットは、図8に描かれている、パケット長フィールド、パケットタイプフィールド、データバイトフィールド(複数の場合がある)、及びCRCフィールドを備える最小のフィールドの共通の基本的な構造又は全体的な集合を有する。図8に示されるように、パケット長フィールドは、パケットの中のビット総数、つまりパケット長フィールドとCRCフィールドの間のその長さを指定するマルチビット値又はマルチバイト値の形をした情報を含む。一実施形態では、パケット長フィールドは、パケット長を指定する16ビットつまり2バイト幅の符号なし整数を含む。パケットタイプフィールドは、パケットの中に含まれる情報のタイプを指定する別のマルチビットフィールドである。例示的な実施形態では、これは、16ビットの符号なし整数の形を取る16ビットつまり2バイト幅の値であり、表示機能、ハンドオフ、ビデオストリーム又は音声ストリーム、ステータス等のようなデータ型を指定する。
第3のフィールドは、ホストデバイスとクライアントデバイスの間でそのパケットの一部として転送又は送信されているビット又はデータを含むデータバイトフィールドである。データのフォーマットは、転送されているデータ特定のタイプに従ってパケットタイプごとに特に指定され、それぞれがそれ自体のフォーマット要件を備える一連の追加のフィールドに分離されてよい。つまり、各パケットタイプはこの部分又はフィールドの所定のフォーマットを有するであろう。最後のフィールドは、パケット内で情報の完全性を確認するために使用される、データバイトフィールド、パケットタイプフィールド、及びパケット長フィールド上で計算される16ビットサイクリックリダンダンシーチェックの結果を含むCRCフィールドである。言い換えるとCRCフィールド自体を除きパケット全体で計算される。クライアントは通常、検出されたCRCエラーの総カウントを保存し、このカウントをクライアント要求及びステータスパケット(以下を参照)でホストに報告する。
一般的には、これらのフィールド幅と編成は2バイトフィールドを偶数バイト境界で位置合わせされた状態に、及び4バイトフィールドを4バイト境界で位置合わせされた状態に保つように作られている。これにより、大部分の、又は通常使用されるプロセッサ又は制御回路について遭遇されるデータタイプ位置合わせ規則に違反することなく、ホストとクライアントのメインメモリ空間内にパケット構造を容易に構築できるようにする、あるいはパケット構造をホストとクライアントに関連付けることができるようにする。
パケットの転送中、フィールドは最初に最下位ビット(LSB)で開始し、最後に送信される最上位ビット(MSB)で終了する。長さが1バイトを超えるパラメーターは、最下位ビットを最初に使用して送信され、その結果、LSBが最初に送信されるより短いパラメーターに使用されるように、同じビット伝送パターンが長さ8ビットを上回るパラメーターに使用されることになる。各パケットのデータフィールドは通常、それらが以下の後の項で定められる順序で送信され、一覧表示されている最初のフィールドが最初に送信され、記述されている最後のフィールドが最後に送信される。MDDI_Data0信号経路上のデータは、モードタイプ1、タイプ2、タイプ3又はタイプ4のどれかでインターフェース上で送信されるバイトのビット「0」と位置合わせされる。
ディスプレイ用にデータを操作するとき、ピクセルのアレイのためのデータは、エレクトロニクス技術で従来行われるように最初に行、次に列単位で送信される。言い換えるとビットマップの中の同じ行に表示されるすべてのピクセルは、最も左のピクセルが最初に送信され、最も右のピクセルが最後に送信される順序で送信される。行の最も右のピクセルが送信された後、シーケンスの中の次のピクセルは、続く行の最も左のピクセルである。他の構成に必要に応じて対処できるが、ピクセルの行は通常、大部分のディスプレイの場合上から下への順で送信される。さらに、ビットマップを処理する上で、ここで従われる従来の手法は、ビットマップの左上角をロケーション又はオフセット「0、0」と名付けることによって基準点を定めることである。ビットマップの中で位置を定める又は突き止めるために使用されるX座標とY座標は、それぞれビットマップの右と下部に近づくにつれて値を増加させる。第1の行と第1の列(画像の左上角)はゼロというインデックス値で開始する。X座標の規模は、ディスプレイのユーザによって見られるときに画像の右側に向かって大きくなり、Y座標の規模は画像の下部に向かって大きくなる。
ディスプレイウィンドウはビットマップの可視部分、つまり物理的な表示媒体上でユーザが見ることができるビットマップのピクセルの部分である。ディスプレイウィンドウ及びビットマップが同じサイズである場合が多い。ディスプレイウィンドウの左上角は常にビットマップピクセルロケーション0、0を表示する。ディスプレイウィンドウの幅はビットマップのX軸に相当し、この実施形態ではディスプレイウィンドウ幅は対応するビットマップの幅以下となる。ウィンドウの高さはビットマップのY軸に相当し、この実施形態ではディスプレイウィンドウの高さは対応するビットマップの高さ以下となる。
ディスプレイウィンドウ自体は、それはビットマップの可視部分として定義されるに過ぎないためプロトコル内でアドレス指定可能ではない。
ビットマップとディスプレイウィンドウの関係性はコンピューター、電子技術、インターネット通信、及び他のエレクトロニクス関連の技術で周知である。したがって、これらの原理についての追加の説明又は図解はここでは提供されない。
C. パケット定義
1.サブフレームヘッダーパケット
サブフレームヘッダーパケットはあらゆるサブフレームの最初のパケットであり、図9に描かれているような基本的な構造を有する。サブフレームヘッダーパケットはホスト−クライアント同期に使用され、あらゆるクライアントがこのパケットを受信し、解釈できなければならない一方であらゆるホストはこのパケットを作成できなければならない。図9の一実施形態で分かるように、この種のパケットはパケット長フィールド、パケットタイプフィールド、一意のワードフィールド、予約1フィールド、サブフレーム長フィールド、プロトコルバージョンフィールド、サブフレームカウントフィールド及びメディアフレームカウントフィールドを、通常その順序で有するように構造化されている。一実施形態では、この種のパケットは通常タイプ15359(0x3bff 16進)パケットとして識別され、パケット長フィールドを含まずに20バイトという事前に選択された固定長を使用する。
パケットタイプフィールドと一意のワードフィールドはそれぞれ2バイト値(16ビットの符号なし整数)を使用する。これらの2つのフィールドの4バイトの組み合わせは共に、優れた自己相関のある32ビットの一意のワードを形成する。一実施形態では、実際の一意のワードは0x005a3bffであり、ここでは下位の16ビットはパケットタイプとして最初に送信され、最上位の16ビットが後に送信される。
予約1フィールドは将来の使用のために予約される2バイトを含み、通常この点で構成され、すべてのビットがゼロに設定される。このフィールドの1つの目的は、以後の2バイトのフィールドを16ビットのワードアドレスに位置合わせさせ、4バイトのフィールドを32ビットのワードアドレスに位置合わせさせる。最下位バイトは、ホストが複数のクライアントデバイスをアドレス指定できるかどうかを示すために予約される。このバイトに関しゼロという値は、ホストが単一のクライアントデバイスと共にのみ動作できることを示すために予約される。
サブフレーム長フィールドは、4バイトの情報又はサブフレームあたりのバイト数を指定する値を含む。一実施形態では、このフィールド長は、リンクがシャットダウンされアイドル状態になる前に、サブフレームだけがホストによって送信されることを示すためにゼロに設定されてよい。このフィールドの値は、あるサブフレームから次のサブフレームに遷移するときに「オンザフライで」動的に変更できる。この機能は等時性データストリームに対処するために同期パルスで軽微なタイミング調整を行うために有効である。サブフレームヘッダーパケットのCRCが有効ではない場合は、リンクコントローラーは現在のサブフレームの長さを推定するために過去の公知の良好なサブフレームヘッダーパケットのサブフレーム長を使用する必要がある。
プロトコルバージョンフィールドは、ホストによって使用されるプロトコルバージョンを指定する2バイトを含む。プロトコルバージョンフィールドは、プロトコルの第1のバージョン又はカレントバージョンを使用されているとして指定するために「0」に設定される。この値は新しいバージョンが作成されると経時的に変化し、そしてこの値はいくつかのバージョンフィールドにおいてすでに「1」の値にアップグレードされつつある。バージョンの値は、多分または通常、周知のようにMDDIのようなインターフェースをカバーする認可された標準文書に関するカレントバージョン数に続く。
サブフレームカウントフィールドは、メディアフレームの開始後に送信されたサブフレーム数を示すシーケンス番号を指定する2バイトを含む。メディアフレームの第1のサブフレームはゼロというサブフレームカウントを有する。メディアフレームの最後のサブフレームはn−1という値を有し、この場合nはメディアフレームあたりのサブフレーム数である。サブ−フレームカウントフィールドの値は、ゼロのカウントを有するであろうメディア−フレームの最初のサブ−フレームを除き、前のサブ−フレームパケットプラス1において送信されたサブ−フレームカウントに等しい。サブフレーム長が(非周期サブフレームを示す)ゼロに設定される場合に、サブフレームカウントもゼロに等しく設定されなければならないことに注意する。
メディアフレームカウントフィールドは、転送されている本メディアアイテム又はデータの開始後に送信されたメディアフレーム数を示すシーケンス番号を指定する4バイト(32ビットの符号なし整数)を含む。メディアアイテムの第1のメディアフレームはゼロというメディアフレームカウントを有する。メディアフレームカウントは、各メディアフレームの第1のサブフレームの直前に増分し、最大メディアフレームカウント(例えば、メディアフレーム数23−1=4,294,967,295)が使用された後に完了して戻る(wraps back)。メディアフレームカウント値は、通常、最終用途のニーズに合うようにホストによっていつでもリセットされてよい。
2.フィラーパケット
フィラーパケットは、順方向リンク又は逆方向リンクのどちらかで送信するために使用可能な他の情報がないときにクライアントデバイスに、又はクライアントデバイスから転送されるパケットである。必要時に他のパケットを送信する上で最大の柔軟性を可能にするためにフィラーパケットが最小長を有することが勧められる。サブフレーム又は逆方向リンクカプセル化パケット(以下を参照されたい)のまさに最後に、リンクコントローラーはパケット完全性を維持するために残りの空間を充填するためのフィラーパケットのサイズを設定する。フィラーパケットは、ホスト又はクライアントに送信又は交換する情報がないときに、リンク上でタイミングを維持するために有効である。あらゆるホストとクライアントは、インターフェースを効果的に使用するためにこのパケットを送受できる必要がある。
フィラーパケットのフォーマットとコンテンツの具体的な実施の形態が図10に示されている。図10に示されるように、この種のパケットはパケット長フィールド、パケットタイプフィールド、フィラーバイトパケット、及びCRCフィールドを有するように構造化されている。一実施形態では、この種のパケットは通常、2バイトタイプのフィールドで示されるタイプ0として識別される。フィラーバイトフィールドの中のビット又はバイトは、フィラーパケットが所望される長さとなることができるようにするために可変数の全ゼロビット値を備える。最小のフィラーパケットはこのフィールドにバイトを含まない。すなわち、パケットはパケット長、パケットタイプ、及びCRCだけからなり、一実施形態では、6バイトという事前に選択された固定長又は4というパケット長を使用する。CRC値は、何らかの他のパケットタイプでは排除されてよい、パケット長を含むパケットの中のすべてのバイトについて求められる。
3.ビデオストリームパケット
ビデオストリームパケットは、表示装置の通常は矩形領域を更新するためにビデオデータを搬送する。この領域のサイズは、単一のピクセルと同程度に小さいか、ディスプレイ全体と同じ程度大きくてよい。ストリームを表示するために必要とされるすべてのコンテクストはビデオストリームパケット内に含まれるために、同時に表示され、システムリソースによって制限されるほぼ無制限な数のストリームがあってよい。
ビデオストリームパケット(ビデオデータフォーマットディスクリプタ)の一実施形態のフォーマットは図11に示される。図11で見られるように、一実施形態では、この種のパケットはパケット長(2バイト)フィールド、パケットタイプフィールド、bClient IDフィールド、ビデオデータディスクリプタフィールド、ピクセル表示属性フィールド、X左端縁フィールド、Y上部端縁フィールド、X右端縁フィールド、Y下部端縁フィールド、X開始フィールドとY開始フィールド、ピクセルカウントフィールド、パラメーターCRCフィールド、ピクセルデータフィールド及びピクセルデータCRCフィールドを有するように構造化されている。この種のパケットは、通常、2バイトタイプフィールドに示されるタイプ16として識別される。一実施形態では、クライアントはクライアント機能パケットの赤−緑−青(RGB)フィールド、白黒フィールド、及びY Cr Cb機能フィールドを使用してビデオストリームパケットを受信する能力を示す。
一実施形態では、bClient IDフィールドは、クライアントIDに予約される2バイトの情報を含む。これは新規に開発された通信プロトコルであるので、実際のクライアントIDはまだ公知ではないあるいは十分に通信可能ではない。したがって、このフィールドの中のビットは、このようなID値が公知になるまで通常ゼロに等しく設定され、その時点でID値は、当業者に明らかであるように挿入又は使用できる。一般的には同じプロセスが、後述されるクライアントIDフィールドに当てはまる。
前述されたように、例示的なビデオデータディスクリプタフィールドの動作を実現するために利用されるフォーマット及びコンテンツは、図12Aから図12Eに示される。図12Aから図12Eでは、ビデオデータフォーマットディスクリプタフィールドは、本パケットの本ストリームのピクセルデータの中の各ピクセルのフォーマットを指定する16ビットの符号なし整数の形の2バイトを含む。様々なビデオストリームパケットが様々なピクセルデータフォーマットを使用してよい、つまりビデオデータフォーマットディスクリプタで違う値を使用してよく、同様にストリーム(表示の領域)がそのデータフォーマットをオンザフライで変更してよいことが考えられる。ピクセルデータフォーマットはクライアント機能パケットで定義されるようにクライアントの有効なフォーマットの内の少なくとも1つに従わなければならない。ビデオデータフォーマットディスクリプタは、一定のフォーマットがある特定のビデオストリームの存続期間中使用し続けられることを暗示しない本パケットだけのピクセルフォーマットを定義する。
図12Aから図12Dは、ビデオデータフォーマットディスクリプタがどのようにしてコード化されるのかを描く。これらの図で使用されるように、及びこの実施形態では、ビット[15:13]が図12Aに示されるように「000」に等しいときには、ビデオデータはピクセルあたりのビット数がビデオデータフォーマットディスクリプタワードのビット3から0で定義される、白黒ピクセルのアレイからなる。ビット11から4は通常将来の使用又は用途のために予約され、この状況ではゼロに設定される。代わりにビット[15:13]が図12Bに示されるように「001」に等しいときには、ビデオデータはカラーマップ(パレット)を通してそれぞれが色を指定するカラーピクセルのアレイからなる。この状況では、ビデオデータフォーマットディスクリプタワードのビット5から0はピクセルあたりのビット数を定義し、ビット11から6は通常将来の使用又は用途のために予約され、ゼロに等しく設定される。ビット[15:13]が図12Cに示されるように代わりに「010」に等しいときには、ビデオデータは、赤のピクセルあたりのビット数がビット11から8によって定められ、緑のピクセルあたりビット数がビット7から4によって定められ、青のピクセルあたりビット数がビット3から0によって定められるカラーピクセルのアレイからなる。この状況では、各ピクセルのビット総数は赤、緑及び青に使用されるビット数の合計である。
しかしながら、ビット[15:13]が、図12Dに示されるように代わりに「011」に等しいときには、ビデオデータは、輝度とクロミナンス情報を含む4:2:2YCbCrフォーマットのビデオデータのアレイからなり、ルミナンス(Y)のピクセルあたりビット数はビット11から8によって定義され、Cb成分のビット数はビット7から4によって定義され、Cr成分のビット数はビット3から0によって定義される。各ピクセルの中のビット総数は、赤、緑及び青に使用されるビット数の合計である。Cb成分とCr成分はYの速度の半分で送信される。加えて、このパケットのピクセルデータ部分の中のビデオサンプルは以下の通りに編成される。つまりCbn、Yn、Crn、Yn+1、Cbn+2、Yn+2、Crn+2、Yn+3,...であり、ここではCbnとCrnはYnとYn+1と関連付けられ、Cbn+2とCrn+2はYn+2とYn+3に関連付けられる等である。
Yn、Yn+1、Yn+2、及びYn+3は、左から右へ単一行の中の4つの連続ピクセルの輝度値である。ビデオストリームパケットにより参照されるウィンドウの中の1行に奇数のピクセルがある場合(X右端縁−Y左端縁+1)、各行の最後のピクセルに対応するY値の後には次の行の第1のピクセルのCb値が続き、Cr値は行の中の最後のピクセルのために送信されない。Y Cb Crフォーマットを使用するウィンドウが偶数のピクセルである幅を有することが勧められる。パケットの中のピクセルデータは偶数のピクセルを含まなければならない。それは、ピクセルデータの最後のピクセルがビデオストリームパケットヘッダに指定されるウィンドウの中の行の最後のピクセルに相当する場合、つまりピクセルデータの最後のピクセルのXロケーションがX右端縁に等しいときに奇数又は偶数のピクセルを含んでよい。
ビット[15:13]が代わりに「100」に等しいときには、ビデオデータはピクセルあたりビット数がビデオデータフォーマットディスクリプタワードのビット3から0で定義される、Bayerピクセルのアレイからなる。ピクセルグループパターンは、図12Eに示されるように、ビット5と4によって定義される。ピクセルデータの順序は水平又は垂直であってよく、行又は列の中のピクセルは順方向順又は逆方向順で送信されてよく、ビット8から6によって定義される。ビット11から9はゼロに設定されなければならない。Bayerフォーマットを取るピクセルグループの中の4個のピクセルのグループは、多くの場合、いくつかの表示技術において単一ピクセルと呼ばれるものに似ている。しかしながらBayerフォーマットの1ピクセルはピクセルグループモザイクパターンの4個の色つきピクセルの内の1つに過ぎない。
図に示される5つすべてのフォーマットについて、「P」として示されるビット12が、ピクセルデータサンプルがパックされるのか、あるいはバイト位置合わせピクセルデータであるのかを指定する。このフィールドの「0」という値は、ピクセルデータフィールドの各ピクセルがMDDインターフェースバイト境界とバイト位置合わせされていることを示す。「1」という値は、各ピクセルと、ピクセルデータの各ピクセル内の各色がピクセル内の過去のピクセル又は色と対照してパックされ、未使用のビットを残さないことを示している。バイト位置合わせされたデータフォーマットとパックされたピクセルデータフォーマットの相違点は図13にさらに詳しく示され、バイト位置合わせされたデータが、未使用の部分を残さないパックされたピクセルフォーマットと対照的に、データサブフレームの未使用の部分を残していることが明確に分かる。
4.音声ストリームパケット
音声ストリームパケットは、クライアントの音声システムを通して、あるいはスタンドアロン音声プレゼンテーション装置用に再生される音声データを搬送する。様々な音声データストリームが、使用されている音声システムに応じて、例えば左前、右前、中央、左後ろ、及び右後ろ等サウンドシステムの別々の音声チャネルに割り当てられてよい。音声チャネルの完全な補完物は機能強化された空間−音響信号処理を含むヘッドセットに提供される。クライアントは、クライアント機能パケットの音声チャネル機能フィールドと音声サンプルレートフィールドを使用して音声ストリームパケットを受信する能力を示す。音声ストリームパケットのフォーマットは図14に示されている。
図14に示されるように、この種のパケットは、一実施形態においてパケット長フィールド、パケットタイプフィールド、bClient IDフィールド、音声チャネルIDフィールド、予約1フィールド、音声サンプルカウントフィールド、サンプルあたりビット及びパッキングフィールド、音声サンプルレートフィールド、パラメーターCRCフィールド、デジタル音声データフィールド及び音声データCRCフィールドを有するように構造化されている。一実施形態では、この種のパケットは通常タイプ32パケットとして識別される。
bClient IDフィールドは、過去に使用されたようにクライアントIDに予約される2バイトの情報を含む。予約1フィールドは将来の使用のために予約される2バイトを含み、すべてのビットがゼロに設定され、通常この点で構成される。
サンプルあたりビット及びパッキングフィールドは、音声データのパッキングフォーマットを指定する8ビットの符号なし整数の形を取る1バイトを含む。通常利用されているフォーマットは、PCM音声サンプルあたりのビット数を定めるためのビット4から0用である。次にビット5は、デジタル音声データサンプルがパックされるかどうかを指定する。パックされた音声サンプルと、ここでは10ビットのサンプルを使用するバイト位置合わせされた音声サンプルの相違点は、図15に示されている。「0」という値は、デジタル音声データフィールドの中の各PCM音声サンプルがMDDIインターフェースバイト境界とバイト位置合わせされていることを示し、「1」という値は、各連続PCM音声サンプルが過去の音声サンプルに対照してパックされることを示す。このビットは通常、ビット4から0で定義される値(PCM音声サンプルあたりのビット数)が8の倍数ではないときにだけ有効である。ビット7から6は将来の使用に予約され、通常、ゼロという値で設定される。
5.予約ストリームパケット
一実施形態では、パケットタイプ1から15、18から31、及び33から55が、遭遇される多様な応用例について所望されるようにパケットプロトコルの将来のバージョン又は変形での使用のために定義されるストリームパケットに予約される。この場合も先と同様に、これは、他の技法に比較して千変万化の技術及びシステム設計に直面してMDDインターフェースをより柔軟且つ有効にすることの一部である。
6.ユーザ定義ストリームパケット
タイプ56からタイプ63として知られている8つのデータストリームタイプは、MDDIリンクと使用するために装置製造メーカによって定義されてよい独自仕様の応用例で使用するために予約されている。これらはユーザ定義ストリームパケットとして知られている。
このようなパケットは任意の目的で使用されてよいが、ホストとクライアントはこのような使用の結果が非常によく理解されている、又は知られている状況だけでこのようなパケットを使用しなければならない。ストリームパラメーター及びこれらのパケットタイプのためのデータの特定の定義は、このようなパケットタイプを実現する、又はその使用を求める特定の装置製造メーカまたはインターフェース設計者に委ねられる。ユーザ定義ストリームパケットのいくつかの例示的な用途は、試験パラメーターと試験結果、工場校正データ、及び独自仕様の特殊使用データを伝達することである。一実施形態で使用されるようなユーザ定義ストリームパケットのフォーマットは図16に示されている。図16に示されるように、この種のタイプのパケットはパケット長(2バイト)フィールド、パケットタイプフィールド、bClient ID番号フィールド、ストリームパラメーターフィールド、パラメーターCRCフィールド、ストリームデータフィールド及びストリームデータCRCフィールドを有するように構造化されている。
7.カラーマップパケット
カラーマップパケットは、クライアントのために色を提示するために使用されるカラーマップルックアップテーブルのコンテンツを指定する。いくつかの応用例は、単一のパケットで送信できるデータ量より大きいカラーマップを必要とすることがある。これらの場合、後述されるオフセットフィールドと長さフィールドを使用することによってそれぞれがカラーマップの異なる部分集合を含む、複数のカラーマップパケットが転送されてよい。一実施形態でのカラーマップパケットのフォーマットは、図17に示されている。図17に示されるように、この種のパケットはパケット長フィールド、パケットタイプフィールド、hClient IDフィールド、カラーマップアイテムカウントフィールド、カラーマップオフセットフィールド、パラメーターCRCフィールド、カラーマップデータフィールド、及びデータCRCフィールドを有するように構造化されている。一実施形態では、この種のパケットは通常、パケットタイプフィールド(2バイト)に指定されるようなタイプ64パケット(ビデオデータフォーマット及びカラーマップパケット)として識別される。クライアントは、クライアント機能パケットのカラーマップサイズフィールドとカラーマップ幅フィールドを使用してカラーマップパケットを受信する能力を示す。
8.逆方向リンクカプセル化パケット
例示的な実施形態では、データは逆方向リンクカプセル化パケットを使用して逆方向で転送される。順方向リンクパケットは送信され、MDDIリンク動作(転送方向)は、パケットが逆方向で送信できるようにこのパケットの真中のあたりで変更又は方向転換される。一実施形態での逆方向リンクカプセル化パケットのフォーマットは図18に示されている。図18に示されるように、この種のパケットは、パケット長フィールド、パケットタイプフィールド、hCLient IDフィールド、逆方向リンクフラグフィールド、逆方向レート除数フィールド、方向転換1長フィールド、方向転換2長フィールド、パラメーターCRCフィールド、全ゼロフィールド、方向転換1フィールド、逆方向データパケットフィールド、方向転換2フィールド、及び全ゼロ2フィールドとを有するように構造化されている。一実施形態では、この種のパケットは通常タイプ65パケットとして識別される。外部モードの場合、所望のプロトコルおよび結果として生ずるスピードを適切に使用するために、あらゆるホストがこのパケットを生成し、データを受信することができなければならず、あらゆるクライアントはデータを受信し、ホストに送信できなければならない。このパケットのインプリメンテーションは内部モードの場合オプションであるが、逆方向リンクカプセル化パケットがホストがクライアントからのデータを受信するために使用される。
MDDIリンクコントローラーは、逆方向リンクカプセル化パケットの送信中特別に動作する。MDDIは、通常リンクのコントローラーとしてホストによって常に駆動されるストローブ信号を有する。ホストは、それが逆方向リンクカプセル化パケットの方向転換部分と逆方向データパケット部分の各ビットについてゼロを送信しているかのように動作する。ホストは、2回の方向転換の間、及び逆方向データパケットに割り当てられる時間中、各ビット境界でMDDI_Strobe信号をトグルする。すなわち、ホストは、オールゼロ1フィールドの始めからオールゼロ2フィールドの終わりまでMDDI Stbをトグルする。(これは、それがあたかも全ゼロデータを送信しているのと同じ動作である。)。
ホストはそのMDDIデータ信号ラインドライバーをディスエーブルし、一般的に、それらのラインドライバーが、方向転換1フィールドの最後のビットの前に完全にディスエーブルされ、次に方向転換2フィールドの期間にラインドライバーを再イネーブルすることを保証し、および一般的に、ドライバーは、方向転換2フィールドの最後のビットの前に再イネーブルされることを保証する。クライアントは方向転換長パラメーターを読み取り、方向転換1フィールドの最後のビットの直後にホストに向かってデータ信号を起動する。すなわち、クライアントは、パケットコンテンツの以下の説明、及びそれ以外の箇所に指定されるようにMDDIストローブの特定の立ち上がりでリンクの中に新しいデータの時間を記録する(clocks)。クライアントは、それがホストにパケットを送信するために有する利用可能な時間の長さを知るためにパケット長と方向転換長のパラメーターを使用する。クライアントは、ホストに送信するデータがないときには、フィラーパケットを送信する、あるいはデータラインをゼロ状態に駆動してよい。データラインがゼロに駆動されると、ホストはこれをゼロ長(有効長ではない)パケットとして解釈し、ホストは現在の逆方向リンクカプセル化パケットの期間中、クライアントからそれ以上のパケットを受け入れない。
一実施形態では、クライアント要求及びステータスパケットの逆方向リンク要求フィールドは、クライアントがデータをホストに送り返すために逆方向リンクカプセル化パケットの中で必要とするバイト数をホストに知らせるために使用されてよい。ホストは、逆方向リンクカプセル化パケットで少なくともそのバイト数を割り当てることによって要求を許可しようとする。ホストは1サブフレームで複数の逆方向リンクカプセル化パケットを送信してよい。クライアントはほぼ常にクライアント要求及びステータスパケットを送信してよく、ホストは1サブフレームで要求される総バイト数として逆方向リンク要求パラメーターを解釈する。
9.クライアント機能パケット
ホストは、通常最適な又は所望される方法でホストからクライアントへのリンクを構成するためにそれが通信しているクライアント(ディスプレイ)の機能を知る必要がある。ディスプレイは、順方向リンク同期が取得された後にホストにクライアント機能パケットを送信することが薦められる。このようなパケットの伝送は、逆方向リンクカプセル化パケットで逆方向リンクフラグを使用してホストによって要求されるときに必須と見なされる。クライアント機能パケットは、ホストにクライアントの機能を知らせるために使用される。外部モードの場合、あらゆるホストはこのパケットを受信できなければならず、あらゆるクライアントはこのインターフェースとプロトコルを完全に活用するためにこのパケットを送信できなければならない。この状況におけるディスプレイ、キーボード又は他の入/出力装置等のクライアントの機能は、製造又はなんらかのタイプの単一の構成部品又は装置への組み込みの時点ですでに明確でなければならず、ホストに知られていなければならないので、このパケットの実施は内部モードに対してはオプションである。
一実施形態でのクライアント機能パケットのフォーマットは図19に描かれている。この実施例に関し図18に示されているように、この種のパケットはパケット長フィールド、パケットタイプフィールド、予約としてのcClientIDフィールド、プロトコルバージョンフィールド、最小プロトコルバージョンフィールド、データレート機能フィールド、インターフェースタイプ機能フィールド、代替(Alt)ディスプレイ数フィールド、予約1フィールド、ビットマップ幅フィールド、ビットマップ高さフィールド、ディスプレイウィンドウ幅フィールド、ディスプレイウィンドウ高さフィールド、カラーマップサイズフィールド、カラーマップRGB幅フィールド、RGB機能フィールド、白黒機能フィールド、予約2フィールド、Y Cr Cb機能フィールド、Bayer機能フィールド、アルファ−カーソル画像平面フィールド、クライアント特徴機能フィールド、最大ビデオフレームレートフィールド、最小ビデオフレームレートフィールド、最小サブフレームレートフィールド、音声バッファ深さフィールド、音声チャネル機能フィールド、音声サンプルレート機能フィールド、音声サンプル解像度フィールド、マイクサンプル解像度フィールド、マイクオーディオサンプル解像度フィールド、マイクサンプルレート機能フィールド、キーボードデータフォーマットフィールド、ポインティングデバイスデータフォーマットフィールド、コンテンツ保護タイプフィールド、製造メーカ名フィールド、製品コードフィールド、予約3フィールド、シリアル番号フィールド、製造週フィールド、製造年フィールド及びCRCフィールドを有するように構造化されている。例示的な実施形態では、この種のパケットは通常、タイプ66として認識される。
10.キーボードデータパケット
キーボードデータパケットは、クライアントデバイスからホストにキーボードデータを送信するために使用される。無線(又は有線)キーボードは、ヘッドマウントビデオディスプレイ/音声プレゼンテーション装置を含むが、これに限定されない多様なディスプレイ又は音声装置と共に使用されてよい。また、このパケットは、データをキーボードに送信するために順方向リンク上で使用することができる。クライアントは、クライアント機能パケットのキーボードデータフィールドを使用してキーボードデータパケットを送受する能力を示す。
キーボードデータパケットのフォーマットは図20に示され、キーボードからの、又はキーボード用の可変数のバイトの情報を含んでいる。図19に示されているように、このパケットは、パケット長フィールド、パケットタイプフィールド、bClient IDフィールド、キーボードデータフォーマットフィールド、キーボードデータフィールド、及びCRCフィールドを有するように構造化されている。ここでは、この種のパケットは通常タイプ67パケットとして識別される。
bClient IDは前述されたように予約されたフィールドであり、CRCはパケットの全バイトで実行される。キーボードデータフォーマットフィールドは、キーボードデータフォーマットを記述する2バイト値を含む。ビット6から0は、クライアント機能パケットのキーボードデータフォーマットと同一でなければならない。この値は127に等しくない。ビット15から7は、将来の使用のために予約されているため、現在はゼロに設定されている。
11.ポインティングデバイスデータパケット
ポインティングデバイスデータパケットは、クライアントからホストへ、無線マウス又は他のポインティングデバイスからの位置情報を送信するための方法、構成、または手段として使用される。データはこのパケットを使用して順方向リンクでポインティングデバイスに送信することもできる。ポインティングデバイスデータパケットの例示的なフォーマットは図21に示され、ポインティングデバイスから、又はポインティングデバイス用の可変数のバイトの情報を含む。図21に示されているように、この種のパケットはパケット長フィールド、パケットタイプフィールド、bClient IDフィールド、ポインティングデバイスフォーマットフィールド、ポインティングデバイスデータフィールド、及びCRCフィールドを有するように構造化されている。例示的な実施形態では、この種のパケットは通常1バイトタイプフィールドにおけるタイプ68パケットとして識別される。
12.リンクシャットダウンパケット
リンクシャットダウンパケットは、MDDIデータとストローブがシャットダウンされ、低電力消費「ハイバネーション」状態に入ることを示すための方法または手段として、ホストからクライアントに送信される。このパケットはリンクをシャットダウンし、静的ビットマップが移動通信装置からディスプレイに送信された後、あるいはホストからクライアントに当面転送する追加の情報がないときに電力を節約するために有効である。ホストがパケットを再び送信すると通常の動作が再開される。ハイバネーション後に送信される最初のパケットはサブフレームヘッダーパケットである。クライアントステータスパケットのフォーマットは図22に示されている。1つの実施形態として図22に示されているように、この種のパケットはパケット長フィールド、パケットタイプフィールド、CRC及び全ゼロフィールドを有するように構造化される。一実施形態では、この種のパケットは、通常1バイトタイプフィールドでタイプ69パケットとして識別され、3バイトという事前に選択された固定長を使用する。
パケット長フィールドはパケット長フィールドを含まないパケット中のバイトの全数を特定するために2バイトを使用する。1実施形態において、このパケットのパケット長は、事実上リンクシャットダウンパケットが送信される時のインターフェースの型式またはリンクモードに従う。それ故に典型的なパケット長は、タイプ1モードについて20バイトパケット中に合計22バイト)に、タイプ2モードについて36バイト(パケット中に合計38バイト)に、タイプ3モードリンクについて68バイト(パケット中に合計70バイト)、そしてタイプ4モードについて132バイト(パケット中に合計134バイト)になる。
全ゼロフィールドは、ホストのラインドライバーを使用不能にする前に、MDDI_データ信号がクライアントがMDDI_Stbのみを使用してリカバリングクロックを開始するのを可能にするのに充分な時間ロジックゼロレベルにあることを確実にするために変化可能なバイト数を使用する。全ゼロフィールドの長さは実質的にリンクシャットダウンパケットが送信される時のインターフェースタイプまたはリンク動作モードに従う。全ゼロフィールドの長さはいかなるインターフェースタイプの設定に関してもMDDI_Stbに64パルスを生成することを意図する。それ故に、各インターフェースタイプに関する全ゼロの長さは、タイプ1については16バイトに、タイプ2について32バイトに、タイプ3については64バイトに、タイプ4について128バイトになる。
CRCフィールドは、パケットタイプに関するパケット長からの16−ビットCRCのバイトを含む2バイトを使用する。
低電力ハイバネーション状態では、MDDI_Data0ドライバーは、全ゼロフィールドの最後のビットの後で16番目〜48番目のMDDI_Stbサイクルまたはパルスの後に開始する、高インピーダンス状態にディスエーブルされる。タイプ−2、タイプ−3、またはタイプ−4リンクに関し、MDDI_DataPwr7信号を介するMDDI_Data1もまた、MDDI_Data0ドライバーがディスエーブルされるのと同じ時に、高インピーダンス状態に置かれる。ホストまたはクライアントのいずれかはMDDIリンクを他の箇所に説明されるようハイバネーション状態から「目覚め(wake up)」させることができる。それが本発明のための重要な進展であり、本発明の利点である。
全ゼロフィールドの定義において記載されるように、MDDI_Stbは、クライアントの制御器における系統的なシャットダウンを容易にするために、リンクシャットダウンパケットのCRCフィールドのMSBの次に続く64サイクルについてトグルする。1つのサイクルは、高から低への転移が続く低から高への転移、または低から高への転移が続く高から低への転移である。全ゼロフィールドが送信された後、ホストにおけるMDDI_Stbドライバーはディスエーブルされる。
13.クライアント要求及びステータスパケット
ホストは、それが通常最適にホストからクライアントへのリンクを構成できるように、クライアントから少量の情報を必要とする。クライアントがクライアント要求及びステータスパケットをサブフレームごとにホストに送信することが勧められる。クライアントは、それが確実にホストに配信されることを保証するために逆方向リンクカプセル化パケット内で最初のパケットとしてこのパケットを送信する必要がある。また、このパケットの転送は、逆方向リンクカプセル化パケット内で逆方向リンクフラグを使用してホストによって要求されるときに達成される。クライアント要求及びステータスパケットは、ホストにエラーとステータスを報告するために使用される。外部モード動作において、あらゆるホストはこのパケットを受信できなければならず、あらゆるクライアントはMDDIプロトコルを適切に又は最適に利用するためにこのパケットを送信できなければならない。一方内部動作においては、これは内部ホストおよび内部クライアントについてである、このパケットに関しそれが要求されないサポートが存在すべきであることが推奨される。
クライアント要求及びステータスパケットのフォーマットは図23に示されている。図23に示されるように、この種のパケットは、パケット長フィールド、パケットタイプフィールド、cClient IDフィールド、逆方向リンク要求フィールド、機能変更フィールド、クライアントビジーフィールド、CRCエラーカウントフィールド、及びCRCフィールドを有するように構造化されている。この種のパケットは、通常、1バイトタイプフィールドのタイプ70パケットとして識別され、通常は12バイトという事前に選択された固定長を使用する。
逆方向リンク要求フィールドは、ホストのデータを送り返すために逆方向カプセル化パケットでクライアントが必要とするバイト数をホストに知らせるために使用されてよい。ホストは逆方向リンクカプセル化パケット内で少なくともその数のバイトを割り当てることによって要求を許可しようとしなければならない。ホストはデータに対処するためにサブフレーム内で複数の逆方向リンクカプセル化パケットを送信してよい。クライアントはいつでもクライアント要求及びステータスパケットを送信してよく、ホストは逆方向リンク要求パラメーターを1つのサブフレームで要求されるバイトの総数として解釈する。逆方向リンクデータがどのようにしてホストに送り返されるのかの追加の詳細及び特定の例が後述される。
14.ビットマップブロック転送パケット
ビットマップブロック転送パケットは、任意の方向で、一般的には、1つの矩形領域から他の矩形領域にピクセルのブロックをコピーすることにより、ディスプレイの領域をスクロールするための手段、構造または方法を提供する。この能力を有するクライアントは、クライアント機能パケットのディスプレイフィーチャー能力インジケータのビット0でその能力を報告するであろう。ビットマップブロック転送パケットの1つの実施形態におけるフォーマットは図24に示されている。図24に示されているように、この種のパケットはパケット長フィールド、パケットタイプフィールド、hClientIDフィールド、データ属性フィールド、ラスター演算フィールド、左X値フィールド、左上Y値フィールド、ウィンドウ幅フィールド、ウィンドウ高さフィールド、ウィンドウX移動フィールド、ウィンドウY移動フィールド、及びCRCフィールドを有するように構造化されている。この種のパケットは通常タイプ71パケットとして識別され、1つの実施形態においては15バイトという事前に選択された固定長を使用する。2バイトhClientIDフィールドは、どこかに記述されているように、Client IDのために予約される情報または値を含む。一般的にこのフィールドは、将来の使用のために予約されているので、現在の値は、ビットをロジックゼロレベルに設定することにより、典型的にゼロに設定される。しかしながら、それは他の値に設定することができるし、または当業者によって所望の情報を転送するように使用される。
一実施形態において、2バイトピクセルデータ属性フィールドは、ピクセルデータが更新される場所を指定する値を有する。ビット1および0は、ピクセルデータが更新されるディスプレイを選択する。クライアント内の一次ディスプレイがステレオイメージをサポートしないなら、クライアントは、ビットの組み合わせ01、10、または11の1つに対して一次ディスプレイ内のピクセルデータに影響を及ぼすことができる。値11は、ステレオディスプレイ能力をサポートしないクライアント内の一次ディスプレイをアドレスするために使用されることが推奨される。ビット[1:0]が値11(ダブルロジック1)を有するとき、左目と右目の両方のフレームバッファ内でピクセルデータが更新され、ビット[1:0]が値10(ロジック1、ロジック0)を有するなら、ピクセルデータは、左目だけのフレームバッファ内で更新される。ビット[1:0]が値01(ロジック0、ロジック1)を有するとき、ピクセルデータは、右目だけのフレームバッファ内で更新される。ビット[1:0]が値00(ダブルロジックゼロ)を有するとき、ピクセルデータは、以下のビット8乃至11により指定される代替ディスプレイのフレームバッファ内で更新される。
一実施形態において、ピクセルデータ属性フィールドのビット2は、左目または右目のバッファがこの動作のための画像のソースであるか否かを指定する。ビット[1:0]が00に等しくないときビット2のみが適用する。これは、一般的に画像のデスティネーションが代替ディスプレイの1つであるときメイン画像バッファからのソースデータをサポートしないことを意味するために実施される。ビット2は、データソースとして、左目フレームバッファまたは右目フレームバッファの間を識別するまたは指定するために使用される。ビット2が0に等しいとき、左目フレームバッファは、データソースであるが、ビット2が1に等しいとき、右目フレームバッファがデータソースである。
ピクセルデータ属性フィールドのビット3は、ディスプレイまたはオフライン画像バッファをリフレッシュするために使用されるバッファは、この動作のための画像のソースとなる。代替ディスプレイがオフライン画像バッファならビット3はまた代替ディスプレイに適用してもよい。しかしながら、これは、画像の指定が代替ディスプレイであるとき、逆もまた同様のとき、メイン画像バッファからのソースデータをサポートしない。ビット3が0の値またはロジックゼロレベルであるとき、ディスプレイをリフレッシュするために使用される画像バッファはデータソースである。ビット3が1の値またはロジック1レベルに等しいとき、オフライン画像バッファはデータソースである。
ピクセルデータ属性フィールドのビット7および6は、フレームバッファを指定するディスプレイ更新ビットとして動作する。この場合、ピクセルデータは、更新されるかまたは書かれることになる。フレーム更新ビットの効果、以下に詳述する。ビット[7:6]が「01」(ロジックゼロ、ロジック1)であるとき、ピクセルデータは、オフライン画像バッファに書かれる。ビット[7:6]が「00」(ダブルロジックゼロ)であるとき、ピクセルデータは、ディスプレイをリフレッシュするために使用される画像バッファに書かれる。ビット[7:6]が「11」(ダブルロジック1)であるとき、ピクセルデータは、すべての画像バッファに書かれる。ビット[7:6]が「10」であるとき、これは、無効値として取り扱われる。これらのビットは、現在は、将来の使用のために予約されている。この状況において、全体のコマンドは無視され、フレームバッファは更新されない。
ピクセルデータ属性フィールドのビット11乃至8は、代替ディスプレイまたは代替クライアントロケーションを指定する4ビットの符号なしの整数を形成する。この場合、ピクセルデータが更新される。クライアントがビット11乃至8を代替ディスプレイ番号として解釈するように、ビット0および1は、00の値(ダブルロジックゼロ)に等しく設定される。ビット1および0が00に等しくないなら、ビット8乃至11は、一般的にロジックゼロ値またはレベルに等しく設定される。ビット4乃至5およびビット12乃至15は、将来の使用のために予約され、一般的にロジックゼロレベルまたは値に設定される。
一実施形態において、2バイトラスタ演算フィールドは、どのようにしてソースおよびデスティネーションロケーション内のピクセルを結合して、デスティネーション画像ロケーションに書かれる新しいピクセル値を形成するかを指定する。ラスタ演算は、どのようにして、等しいサイズの2つの異なる矩形領域が一緒にマージされるかを定義する。また、デスティネーション画像エリアは、一緒にマージされる2つの画像の1つである。2つの画像の2番目はソース画像と呼ばれる。クライアントが、クライアント機能パケット内で指定されるラスタ演算フィールドをサポートしないなら、ホストは一般的に3に等しいビット3乃至0を有するパケットを送信し、クライアントは、ビット3乃至0を無視する。
一実施形態において、ビット3乃至0が使用され、以下に示す表VIIに示される値を用いてまたはその値の1つに等しくなるようにビット3乃至0を設定することにより実際のラスタ演算を指定し、その値の次に示される対応する動作を選択する。すなわち、第1列にリストアップされた各指定されたビット[3:0]は、第2列で指定される動作を生じ、さらに、第3列に説明のためにさらなる定義がなされる。
Figure 2014053920
ビット5乃至4は、デスティネーションピクセルが、透明色に関連するデスティネーションロケーションに書かれるか否かを指定する。ビット5乃至4により指定される演算は、ラスタ演算がクライアント装置によりサポートされるか否かに適用する。クライアントがラスタ演算をサポートしないなら、ビット5乃至4により定義される動作に対して考慮すべき結果として生じるデスティネーションピクセル値は、ソースピクセル値のみに等しい。
ビット[5:4]の値が00であるとき、透明色は使用されない。結果として生じるデスティネーションピクセルは、透明色カラーイネーブルパケットにより定義される透明色の値を考慮せずにデスティネーションピクセルロケーションに書かれる。01に等しいビット[5:4]の値は現在、将来の使用のために予約されており、典型的に使用されない。しかし、当業者が関連する使用を確立するために利用可能である。ビット[5:4]の値が10に等しいとき、ラスタ演算により計算された結果として生じるデスティネーションピクセルが透明色に等しいなら結果として生じるピクセルは、デスティネーションピクセルロケーションに書かれない。そうでなければ、それは、デスティネーションピクセルロケーションに書かれる。ビット[5:4]の値が11に等しいとき、ラスタ演算により計算された結果として生じるデスティネーションピクセルが透明色に等しいなら結果として生じるピクセルは、デスティネーションピクセルロケーションに書かれない。そうでなければ、結果として生じるピクセルは、デスティネーションピクセルロケーションに書かれる。
ビット15乃至6は、将来の使用のために予約され、それゆえ、一般的にロジックゼロ値またはレベルに等しく設定される。
残りのフィールドを用いて移動すべきウィンドウの左上隅の座標のXおよびYの値、移動すべきウィンドウの幅と高さ、およびそれぞれ水平および垂直にウィンドウが移動するピクセルの数を指定する。後者の2つのフィールドの肯定的な値は、ウィンドウを右にそして下に移動させ、否定的な値は、移動を左そして上に、それぞれ移動させる。CRCフィールド(ここでは、2バイト)は、パケット長を含むパケット内のすべてのバイトの16ビットCRCを含む。
15.ビットマップ領域塗りつぶしパケット
ビットマップ領域塗りつぶしパケットはディスプレイの領域を単一の色に容易に初期化する手段を提供する。この機能を有するディスプレイは、クライアント機能パケットのクライアント特徴機能インジケータフィールドのビット1でこの機能を報告する。ビットマップ領域塗りつぶしパケットのフォーマットは図25に示されている。図25に示されているように、この種のパケットはパケット長フィールド、パケットタイプフィールド、hClientIDフィールド、ビデオデータフォーマットディスクリプタフィールド、ピクセルデータ属性フィールド、ラスタ演算フィールド、ピクセルエリア塗りつぶし値フィールド、左上X値フィールド、左上Y値フィールド、ウィンドウ幅フィールド、ウィンドウ高さフィールド、及びCRCフィールドを有するように構造化されている。この種のパケットは通常2バイトタイプフィールドでタイプ72パケットとして識別され、24バイトという事前に選択された固定長を使用する。
2バイトhClient IDフィールドは、どこかに記述したように、ClientIDのために予約される情報または値を含む。このフィールドは、一般的に将来の使用のために予約されるので、現在の値は典型的にゼロに設定される。この設定は、ビットをロジックゼロレベルに設定することにより行われる。しかし、所望の情報を転送するために当業者により他の値に設定することができまたは使用することができる。
2バイトを使用するこの実施形態におけるビデオデータフォーマットディスクリプタは、ピクセル塗りつぶし値のフォーマットを指定する。このフォーマットは、ビデオストリームパケット内のフィールドと同じフィールドであり、これは、上に説明し図解した。ピクセルエリア塗りつぶし値フィールド(4バイト)は、上述したフィールドにより指定されたウィンドウに塗りつぶされるピクセル値を含む。このピクセルのフォーマットは、ビデオデータフォーマットディスクリプタフィールドで指定される。
ピクセルデータ属性およびラスタ演算フィールドは、上述したビットマップブロック転送パケット内の同じフィールドに類似して機能し、以下にさらに詳細に提示される。
残りのフィールドは、移動すべきウィンドウの左上隅の座標のXおよびY値を指定するために使用される。ウィンドウ左上座標X値およびY値フィールドは2バイトを使用し、各バイトは、塗りつぶすウィンドウの左上隅の座標のXおよびY値を指定する。
ウィンドウ幅および高さフィールド(各々2バイト)は、塗りつぶすウィンドウの幅および高さを指定する。CRCフィールド(ここでは2バイト)は、パケット長を含むパケット内のすべてのバイトの16ビットCRCを含む。
16.ビットマップパターン塗りつぶしパケット
ビットマップパターン塗りつぶしパケットは、事前に選択されたパターンに表示の領域を容易に初期化する手段または構造を提供する。この機能を有するクライアントはクライアント機能パケットのクライアント特徴機能フィールドのビット2でこの機能を報告する。水平または垂直パターンオフセットがノン−ゼロ(non-zero)でなければ、塗りつぶしパターンの左上角は塗りつぶされるウィンドウの左上角と位置合わせされている。塗りつぶされるウィンドウが塗りつぶしパターンより幅広い、又は背が高い場合には、パターンはウィンドウを塗りつぶすために何回も水平に又は垂直に繰り返されてよい。最後に繰り返されるパターンの右又は下部は必要に応じて切り捨てられる。ウィンドウが塗りつぶしパターンより小さい場合には、塗りつぶしパターンの右上又は右下がウィンドウに適合するために切り捨てられてよい。
水平パターンオフセットがノン−ゼロの場合、続いてウィンドウの左側及び左側プラス水平パターンオフセットの間のピクセルはパターンの最も右側のピクセル(right-most pixel)で満たされる。水平パターンオフセットはパターン幅よりも小さくすべきである。同様に垂直パターンオフセットがノン−ゼロの場合、続いてウィンドウの上側及び側部の上部プラス垂直パターンオフセットの間のピクセルはパターンの最下位ピクセル(lower-most pixel)で満たされる。垂直パターンオフセットはパターンの高さよりも小さくすべきである。
ビットマップ塗りつぶしパケットのフォーマットに関する一実施形態が図26に示されている。図26に示されているように、この種のパケットは、パケット長フィールド、パケットタイプフィールド、hClient IDフィールド、ビデオデータフォーマットディスクリプタフィールド、ピクセルデータ属性フィールド、ラスタ演算フィールド、左上X値フィールド、左上Y値フィールド、ウィンドウ幅フィールド、ウィンドウ高さフィールド、水平パターンオフセットフィールド、垂直パターンオフセットフィールド、パラメーターCRCフィールド、パターンピクセルデータフィールド及びピクセルデータCRCフィールドを有するように構造化されている。ある実施形態においては、この種のパケットは通常1バイトタイプフィールドでタイプ73パケットとして識別される。
2バイトhClientIDフィールドは、どこかに記載したように、ClientIDのために予約される情報または値を含む。このフィールドは一般的に将来の使用のために予約されるので、現在の値は、ビットをロジックゼロレベルに設定することにより典型的にゼロに設定される。
2バイトビデオデータフォーマットディスクリプタフィールドは、ピクセルエリア塗りつぶし値のフォーマットを指定する。図11は、どのようにしてビデオデータフォーマットディスクリプタがコード化されるかを図解する。そのフォーマットは、ビデオストリームパケット内の同じフィールドと同じである。
ピクセルデータ属性およびラスタ演算フィールドは、上述したビットマップブロック転送パケット内の同じフィールドに類似して機能し、以下にさらに詳細に提示される。
ビットマップパターン塗りつぶしパケットの残りのフィールドは、それぞれ、塗りつぶすウィンドウの左上隅の座標のX値およびY値、塗りつぶすウィンドウの幅と高さ、塗りつぶしパターンとして使用されるパターン幅と高さ、左上の端からのピクセルデータパターンの水平および垂直オフセットを指定するために使用される。パターンCRCフィールド(ここでは2バイト)は、パケット長からビデオフォーマットディスクリプタまでのすべてのバイトの16ビットCRCを含む。このCRCがチェックに失敗したなら、全体のパケットが破棄されなければならない。パターンピクセルデータCRCフィールドは、パターンピクセルデータのみの16ビットCRCを含む。このCRCがチェックに失敗したなら、パターンピクセルデータは依然として使用してもよいが、CRCエラーカウントがインクリメントされる。パターンピクセルデータフィールドは、ビデオフォーマットディスクリプタにより指定されるフォーマット内の塗りつぶしパターンを指定する生のビデオ情報を含む。
17. リードフレームバッファパケット
リードフレームバッファは、逆方向リンクを介してホストに返送されるクライアント内のフレームバッファの矩形領域を選択し、決定し、指定するための構造、手段および方法を提供する。返送されたピクセルデータのフォーマットは、ディスプレイのネイティブフォーマット内にあり、そのフォーマットは、一般的に、逆方向リンクを介してホストに送信されたビデオストリームパケットのデータフォーマットディスクリプタフィールドで指定される。ホストに戻されるピクセルデータは、現在表示されている画像バッファからのものである。クライアントは、一般的に、リードフレームバッファパケットにより指定された表示領域に戻すために必要な多くの逆方向リンクカプセル化パケット内の多くのビデオストリームパケットを使用する。この能力を有するクライアントはそのように示すことができまたはクライアント機能パケットのクライアントフィーチャー能力インジケータのビット3を用いて能力を報告することができる。
リードフレームバッファパケットのための一実施形態のフォーマットは図27に示される。図27で示されるように、このタイプのパケットは、パケット長フィールド、パケットタイプフィールド、hClientIDフィールド、ディスプレイデータ属性フィールド、X左端フィールド、Y上部端フィールド、X右端フィールド、Y底部端フィールド、およびCRCフィールドを有するように構造化されている。一実施形態において、このタイプのパケットは、タイプフィールドにおけるタイプ74パケットとして一般的に識別される。
2バイトパケット長フィールドは、パケット長フィールドを含まないパケット内の合計バイト数を指定する。一実施形態において、このパケット長は16で固定される。以前に使用されたように、2バイトhClientIDフィールドは、ClientIDのために予約される情報または値を含む。このフィールドは一般的に将来の使用のために予約されるので、ビットを「0」(ロジックゼロレベルまたは状態)に設定することにより、現在の値はゼロに設定される。しかし、それは、当業者により所望の情報を転送するために使用することができる。
一実施形態において、2バイトディスプレイデータ属性フィールドは、どこで、ピクセルデータが読まれるかを指定する値を有する。ビット0は、ピクセルデータが読まれるフレームバッファを選択する。ビット0が0(ロジックゼロ)の値に等しいとき、ピクセルデータは、以下のビット8乃至11により指定される代替ディスプレイのフレームバッファから読まれる。ビット0が1(ロジック1)の値と等しいとき、ピクセルデータは、一次ディスプレイのフレームバッファから読まれる。
一実施形態において、ディスプレイデータ属性フィールドのビット2は、左目または右目フレームバッファのためのバッファが読むべきデータのソースであるか否かを指定する。一般に、ビット2は、一次ディスプレイがステレオ画像をサポートするときに適用することができるのみである。ビット2が0(ロジックゼロレベル)に等しいとき、左目フレームバッファはデータソースであるが、ビット2が1(ロジック1レベル)に等しいとき、右目バッファはデータソースである。
ディスプレイデータ属性フィールドのビット3は、ディスプレイをリフレッシュするために使用されるバッファまたはオフライン画像バッファがこの演算のための画像のソースになるかどうかを指定する。代替ディスプレイがオフライン画像バッファを利用するなら、ビット3はまた代替ディスプレイに適用してもよい。しかしながら、画像のデスティネーション先が代替ディスプレイまたは逆の場合も同様であるとき、これは、メイン画像バッファからのソースデータをサポートしない。ビット3が0の値またはロジックゼロレベルに等しいとき、ディスプレイをリフレッシュするために使用される画像バッファはデータソースである。ビット3が1またはロジック1レベルの値に等しいとき、オフライン画像バッファはデータソースである。
ディスプレイデータ属性フィールドのビット11乃至8は、ピクセルデータが読まれるディスプレイまたは代替クライアントロケーションを指定する。ビット0は、クライアントがビット11乃至8を代替ディスプレイ番号として解釈するために0(ロジックゼロ)の値に等しく設定される。ビット0が0に等しくないなら、ビット8乃至11は一般的にロジックゼロ値またはレベルに等しく設定される。ビット1、4乃至7、および12乃至15は、将来の使用のために予約され、一般的にロジックゼロレベルまたはゼロ値に設定される。
一実施形態において、2バイトX左端フィールドおよびY上端フィールドは、ピクセルデータフィールドにより塗りつぶされるスクリーンウィンドウの左端のX座標および上端のY座標を指定し、X右端フィールドおよびY底縁フィールドは、右端のX座標と、更新されるウィンドウの底縁のY座標を指定する。
一実施形態において、2バイトCRCフィールドは、パケット長を含むパケット内のすべてのバイトのCRCを指定するかまたは含む。
18. ディスプレイ電力状態パケット
システム電力消費またはシステムリソース上のドレインを最小にするために、ディスプレイのようなクライアントが使用されていないときまたは現在アクティブな使用でないとき、特定のクライアント制御されたまたはクライアント関連された、クライアント接続された、またはコントローラーハードウェアを低電力状態にセットするための構造、手段または方法をディスプレイ電力状態パケットは提供する。このタイプのパケットは、インターフェースまたはインターフェース構造およびプロトコルを外部モード構成または動作に適用するのにもっとも有用である。そのような適用において、外部装置がバッテリのような限られた電力リソース上で動作している、または他の電力制約および懸案事項を有している可能性がより高い。例えば、最小電力条件が期間のためにまたは不動作のためにまたは不使用のために所望されるように限られた空間内のオーバーヒートその他である。一実施形態において、クライアントは、クライアント機能パケットのクライアント特徴能力インジケータフィールドのビット9を用いてディスプレイ電力状態パケットに応答するための能力を示す。
ディスプレイ電力状態パケットのための一実施形態のフォーマットは図28に示される。図28に示されるように、このタイプのパケットは、パケット長フィールド、パケットタイプフィールド、hClientIDフィールド、電力状態フィールドおよびCRCフィールドを有するように構造化されている。このタイプのパケットは一般的に2バイトタイプフィールドのタイプ75パケットとして識別され、あらかじめ選択された8バイトの固定長を使用する。以前に使用されたように、2バイトhClientIDフィールドはClientIDのために予約される情報または値を含む。このフィールドは一般的には、将来の使用のために予約されるので、ビットを「0」(ロジックゼロレベルまたは状態)に設定することにより、現在の値はゼロに設定される。だけれども、当業者により、所望の情報を転送するように使用することができる。
電力状態フィールド、ここでは2バイトは、特定の装置、ハードウェアの一部、ディスプレイのようなクライアントに関連する機器を特定の電力状態にセットするために使用される情報を指定する。ディスプレイのために使用されるとき、このフィールドのビット0は、パケットがメインディスプレイまたは代替ディスプレイに適用するか否かを指定する。ビット0が1に等しいなら、パケットは、メインディスプレイに適用する。ビット0が0に等しいなら、パケットは、ビット11乃至8により指定される代替ディスプレイに適用する。ビット1は、将来の使用のために予約され、一般的にゼロにセットされる。
電力状態フィールドのビット3乃至2は、ビット11乃至8およびビット0により選択されたディスプレイの電力状態を指定する。ビット[3:2]が「00」の値を有するとき、選択されたディスプレイは、照射されず、最小の電力量を消費しなければならない。そして、フレームバッファの内容は、この状態の期間中に保持されるようには保証されない。ビット[3:2]が「01」の値を有するとき、選択されたディスプレイは照射されず、相対的な最小の電力量を消費しており、フレームバッファの内容は、この状態の期間中に保持されるように保証される。ディスプレイは、状態00におけるよりもこの状態でより多くの電力を消費してもよい。クライアントは、クライアント機能パケットのクライアント特徴能力インジケータフィールドのビット10を使用して、状態01を支援する能力を示すことができる。電力状態フィールドのビット[3:2]が「10」の値を有するとき、選択されたディスプレイは照射され、その関連するフレームバッファからの画像を表示している。ビット「3:2」のための「11」の値は、予約された値または将来の使用のための状態であり使用されない。
当業者は、ディスプレイアプリケーションに対してもっとも有用であるけれども、このパケットの使用はこの発明によりディスプレイに限定されず、他のアプリケーション、構成、または状況があってもよいことを認識するであろう。この場合、MDDIが使用されている、またはクライアントが制御しているまたは通信している他のハードウェアエレメントに関連して電力制御が必要となるかもしれないまたは所望されるかもしれない。これらの状況において、上に開示されたビットは、類似した機能を有してもよいが、理解されるように、そのようなエレメントのメインエレメントおよび二次エレメントをアクティブにすることができるまたは電力レベル等を設定することができる。
一実施形態において、電力状態フィールドのビット11乃至8は、電力状態が適用される代替ディスプレイを指定する4ビットの符号なしの整数を形成する。ビット0は、クライアントがビット11乃至8を代替ディスプレイ番号として解釈するためにロジックゼロ値に設定される。ビット0が1に等しいなら、ビット11乃至8はゼロである。
ビット7乃至4およびビット15乃至12は、将来の使用のために予約され、現在のアプリケーションまたは設計のために一般的にロジックゼロレベルまたは値に設定される。
2バイトCRCフィールドは、パケット長を含むパケット内のすべてのバイトのCRCを指定するまたは含む。
ディスプレイ電力状態の要約は、一般的にインターフェース構造によりサポートされるかまたはプロトコルは下記の表VIIIに提示される。表VIIIに示すように、クライアント特徴能力ビット10および9の種々の組み合わせは、所望の電力状態の種々の状態を確立し、セットアップし、またはトリガするために使用される。与えられた行および列位置に提示されたマークは、その列の一番上で指定されたディスプレイ電力状態がクライアント特徴能力インジケータの規定された組み合わせに対してサポートされることを示す。表VIIIの第1行および第3行は、クライアントがディスプレイ電力状態パケットをサポートするための能力を有さないとき、電力状態「10」のみが許可されることを示すことがわかる。たとえ、ディスプレイにディスプレイ電力状態が送信することができなくても、単一のマークは、ディスプレイが「常にオン状態」にあることを示しており、このビットのセットを使用して低電力状態にセットすることはできない。
Figure 2014053920
19.実行型ハンドオフパケット
実行型ハンドオフパケットは、ホストがこのパケットで指定されるモードにハンドオフするようにクライアントに命令するために使用する手段、構造、または方法である。これは、クライアント機能パケットで記載したように、クライアントによりサポートされるインターフェースタイプ設定の1つとなるべきである。ホストとクライアントは、このパケットが送信された直後に指定された順方向および逆方向リンクインターフェースに切り替わらなければならない。実行型ハンドオフパケットに関する一つの実施形態のフォーマットが図29に示されている。タイプ1以外のインターフェースタイプをサポートするホストおよびクライアントは、このパケットに対してサポートを提供しなければならない。クライアントがホストと同期していることを確認するために、ホストが実行型ハンドオフパケットを送信する直前にクライアント要求およびステータスパケットを読むことが典型的に推奨される。
図29に示すように、一実施形態において、このタイプのパケットは、パケット長フィールド、パケットタイプフィールド、インターフェースタイプフィールド、リザーブ1フィールド、ディレイフィラー(Delay Filler)フィールドおよびCRCフィールドを有するように構成されている。このタイプのパケットは一般的に2バイトタイプフィールドにおけるタイプ77パケットとして識別され、6バイトのあらかじめ選択された固定長を使用する。なぜなら、ディレイフィラーフィールドの長さは、パケット長フィールド内の値に影響を及ぼさないからである。
一実施形態において、インターフェースタイプフィールドは、1バイト値を使用して、使用されるまたはリンクのために採用される新しいインターフェースタイプを確認する。このフィールドにおける値は、以下の方法でインターフェースタイプを指定するまたは表す。ビット2乃至0は、順方向リンク上で使用されるインターフェースタイプを定義し、1の値は、タイプ1モードへのハンドオフを示すまたは指定する。2の値はタイプ2モードへのハンドオフを、3の値はタイプ3モードへのハンドオフを、4の値は、タイプ4モードへのハンドオフを示すまたは指定する。ビット5乃至3は、逆方向リンク上で使用されるインターフェースタイプを定義する。1の値は、タイプ1モードへのハンドオフを、2の値はタイプ2へのハンドオフを、3の値はタイプ3へのハンドオフを、および4の値はタイプ4モードへのハンドオフを示すまたは指定する。0、5乃至7の値は、将来の使用のために現在予約される。
ディレイフィラーフィールドは、実行インターフェースタイプハンドオフパケットの直後のパケットの始まりにおいて新しいインターフェースタイプ設定を使用するためにまたは設定するためにクライアントが切り替わるように作るまたは構成されるためにシステムの一部に十分な時間を許容するための手段、構造、または方法として作られた。このフィールドはロジックゼロレベルまたは値にすべて設定されるまたは等しいバイトまたは8ビット値のグループを含む。このフィールドで使用されるバイトの数は、64MDDI_Stbサイクルに等価な長さであるフィールドを生ぜしめるように選択される。ディレイフィラーフィールドの長さは、タイプ1順方向リンクインターフェースタイプの場合には16バイト、タイプ2インターフェースタイプの場合には32バイト、タイプ3インターフェースタイプの場合には64バイト、およびタイプ4順方向リンクインターフェースを指定するまたは使用するとき128バイトである順方向リンクのインターフェースタイプ設定にもとづいている。
予約された1フィールド(ここでは1バイト)は情報を知らせる際に将来の使用のために予約される。このフィールドにおけるすべてのビットは一般的にロジックゼロレベルに設定される。そのようなフィールドの目的は現在、すべての次の2バイトフィールドを16ビットワードアドレスに合わさせ、4バイトフィールドを32ビットワードアドレスに合わさせることである。CRCフィールド(ここでは2バイト)は、パケット長を含むパケット内のすべてのバイトの16ビットCRCを含む。
20.順方向音声チャネルイネーブルパケット
このパケットは、ホストがクライアントの音声チャネルをイネーブル又はディスエーブルできるようにする構造、方法、または手段を提供する。この機能は、クライアント(例えばディスプレイ)が、ホストによって出力される音声がないときに節電するために音声増幅器又は類似する回路要素の電源を切ることができるように有用である。これは、単にインジケータとして音声ストリームの存在又は不在を使用して暗示的に実現するのはかなり困難である。クライアントシステムの電源投入時のデフォルト状態は、すべての音声チャネルがイネーブルされることである。順方向音声チャネルイネーブルパケットに関する一つの実施形態のフォーマットは図30に示されている。図30に示されているように、この種のパケットはパケット長フィールド、パケットタイプフィールド、hClientIDフィールド、音声チャネルイネーブルマスクフィールド、及びCRCフィールドを有するように構造化されている。この種のパケットは、通常、1バイトタイプフィールドでタイプ78パケットとして識別され、4バイトという事前に選択された固定長を使用する。
22.逆方向音声サンプルレートパケット
このタイプのパケットは、クライアント内の音声チャネルをホストがイネーブルまたはディスエーブルできる構造、方法、または手段を提供する。この機能は有用であり、従って、ホストにより出力すべき音声がないとき、クライアントは電力を節約するために音声増幅器をパワーオフすることができる。音声ストリームの有無を用いて暗黙のうちに実施することは極めて困難である。クライアントシステムがパワーアップされるとき、またはホストに接続されるとき、デフォルト状態は、すべての音声チャネルがイネーブルである。ゼロから1の状態または値への遷移を行わせた音声チャネルイネーブルマスクフィールド内のビットの最下位ビットを有する順方向音声チャネルイネーブルパケットをクライアントが受信した後で、ホストおよびクライアントに接続された音声システムは、約100msec未満以内に意図された方法または所望の方法で音声信号を出力する準備をしなければならないまたは出力できなければならない。クライアントは、クライアント機能パケットの音声チャネル能力フィールドのビット15のための値セットを用いて順方向音声チャネルイネーブルパケットに応答する能力を示す。
このパケットは、ホストが逆方向リンク音声チャネルをイネーブルまたはディスエーブルすることを可能にし、このストリームの音声データサンプルレートを設定することを可能にする。ホストは、クライアント機能パケット内で有効であると定義されるサンプルレートを選択する。ホストが無効なサンプルレートを選択するなら、クライアントはホストへの音声ストリームを送信しないであろう。そして、適切なエラー、エラー値、またはエラー信号をクライアントエラー報告パケットでホストに送信してもよい。ホストは、サンプルレートを255の値に設定することにより逆方向リンク音声ストリームをディスエーブルにしてもよい。クライアントシステムが最初にパワーアップされるときまたは接続されるときに仮定されるデフォルト状態は、逆方向リンク音声ストリームがディスエーブルされることである。逆方向オーディオサンプルレートパケットのための一実施形態のフォーマットは図31に示される。図31に示すように、このタイプのパケットは、パケット長フィールド、パケットタイプフィールド、hClientIDフィールド、音声サンプルレートフィールド、予約1フィールドおよびCRCフィールドを有するように構造化される。このタイプのパケットは一般的にタイプ79パケットとして識別され、あらかじめ選択された4バイトの固定長を使用する。
23.デジタルコンテンツ保護オーバヘッドパケット
このパケットは、ホストとクライアントが使用されているデジタルコンテンツ保護方法に関してメッセージを交換できるようにする構造、方法、または手段を提供する。現在、デジタル伝送コンテンツ保護(DTCP)又は高帯域幅デジタルコンテンツ保護(HDCP)システムという、将来の代替保護方式名称のために空間が予約される、二種類のコンテンツ保護が熟考されている。使用されている方法はこのパケットのコンテンツ保護タイプパラメーターによって指定される。デジタルコンテンツ保護オーバヘッドパケットに関する一つの実施形態のフォーマットは図32に示されている。図32に示されているように、この種のパケットはパケット長フィールド、パケットタイプフィールド、bClientIDフィールド、コンテンツ保護タイプフィールド、コンテンツ保護オーバヘッドメッセージフィールド、及びCRCフィールドを有するように構造化されている。この種のパケットは通常タイプ80パケットとして識別されている。
24.透明色イネーブルパケット
透明色イネーブルパケットは、どの色がディスプレイで透明であるのかを指定するため、及び画像を表示するために透明色の使用をディスエーブルするために使用される構造、方法、または手段を提供する。一実施形態において、この能力を有するクライアントまたはディスプレイは、クライアント機能パケットのクライアント特徴能力フィールドのビット4内のその能力を報告するであろう。透明色のための値を有するピクセルがビットマップに書かれるとき、色は、以前の値から変わらない。透明色イネーブルパケットのフォーマットは図33に示される。図33に示すように、一実施形態において、このタイプのパケットは、パケット長フィールド、パケットタイプフィールド、hClientIDフィールド、ディスプレイデータ属性フィールド、予約1フィールド、データフォーマットディスクリプタフィールド、透明ピクセル値フィールドおよびCRCフィールドを有するように構造化される。このタイプのパケットは一般的に1バイトタイプフィールド内のタイプ81パケットとして識別され、あらかじめ選択された16バイトの固定長を使用する。
クライアントIDフィールドは、将来の実施において、クライアントIDとして使用するために予約され、典型的には、ゼロ値(ロジックゼロビット)に設定される。
一実施形態において、2バイトディスプレイデータ属性フィールドは、どこに透明ピクセル色が適用されるかを指定する値を有する。ビット0は透明ピクセル色が適用されるディスプレイを選択する。ビット0が0(ロジックゼロ)の値に等しいとき、透明ピクセル色は、下記のビット8乃至11により指定される代替ディスプレイに適用される。ビット0が1(ロジック1)の値に等しいとき、透明ピクセル色が一次ディスプレイに適用される。
ディスプレイデータ属性フィールドのビット11乃至8は、透明ピクセル色が適用されるディスプレイまたは代替クライアントロケーションを指定する。ビット0は、クライアントがビット11乃至8を代替ディスプレイ番号として解釈するように0(ロジックゼロ)の値に等しく設定される。ビット0が0に等しくないなら、ビット8乃至11は一般的にロジックゼロ値またはレベルに等しく設定され、無視される。
ディスプレイデータ属性フィールドのビット1乃至7およびビット4乃至12乃至14は将来の使用のために予約され、一般的には、ロジックゼロレベルまたはゼロ値に設定される。
ディスプレイデータ属性フィールドのビット15が0に等しいなら、透明色モードはディスエーブルされる。他方、ビット15が1に等しいなら、透明色モードはイネーブルになり、透明色は以下の2つのパラメーターにより指定される。
2バイトの予約された1フィールドは将来の使用のために予約される。このフィールドにおけるすべてのビットは、一般的にゼロ(ロジックゼロレベルまたは状態)に設定される。一実施形態において、このフィールドの1つの目的は、すべての次の2バイトフィールドを16ビットワードアドレスに合わせ、4バイトフィールドを32ビットワードアドレスに合わせることである。
一実施形態において、透明色イネーブルパケットのビデオデータフォーマットディスクリプタフィールドは、2バイトを用いて、ピクセルエリア塗りつぶし値のフォーマットを指定する。図11は、ビデオデータフォーマットディスクリプタがどのようにコード化されるかを図解する。そのフォーマットは一般的にビデオストリームパケット内の同じフィールドと同じである。
一実施形態において、透明ピクセル値フィールドは、透明色の値として使用されるピクセル値に対して4バイトを使用するまたは割り当てる。このピクセルのフォーマットは、ビデオデータフォーマットディスクリプタフィールドで指定される。
CRCフィールドは2バイトを用いてパケット長を含むパケット内のすべてのバイトのCRCを含むまたは表現する。
24.往復遅延測定パケット
往復遅延測定パケットは、クライアント(ディスプレイ)からホストへ戻る遅延を加えた、ホストからクライアント(ディスプレイ)への伝搬遅延を測定するために使用される構造、方法、または手段を提供する。この測定は、本来、ラインドライバーとラインレシーバ、及び相互接続サブシステムに存在する遅延を含む。測定は、方向転換遅延と逆方向リンク速度除数パラメーターを、通常前記に説明される逆方向リンクカプセル化パケットに設定するために使用される。このパケットは、MDDIリンクが特定の応用例に意図された最大速度で運転しているときに最も有効である。パケットは、往復遅延測定の範囲を増加させるために、タイプ1および低データレートで送信することができる。MDDI_Stb信号は、あたかも全ゼロデータが以下のフィールドの間に送信されているかのように動作する。つまり両方のガード時間、全ゼロ、及び測定期間である。これによりMDDI_Stbは、それが測定期間中にクライアント内の周期クロックとして使用できるようにデータレートの半分でトグルする。
一実施形態では、クライアントは、通常、クライアント機能パケットのクライアント特徴機能インジケータフィールドのビット18を使用することにより往復遅延測定パケットをサポートする能力を示す。すべてのクライアントが往復遅延測定をサポートすることが薦められるが、ホストは最大ケーブル遅延に基づいて、及び最大ドライバーと受信機遅延に基づいて最悪のケースの往復遅延を知ることが可能である。これはインターフェースが使用されている装置の公知の設計要素(導体長、回路網種類、及び特徴等)の一態様であるため、ホストは、内部モードで使用されるMDDIリンクに先行して往復遅延を知る可能性もある。
往復遅延測定パケットのフォーマットは図34に示されている。図34に示されているように、一実施形態では、この種のパケットはパケット長フィールド、パケットタイプフィールド、hClient IDフィールド、パラメーターCRCフィールド、ガード時間1フィールド、測定期間フィールド、全ゼロフィールド、及びガード時間2フィールドを有するように構成されている。この種のパケットは、通常タイプ82パケットとして識別され、159ビットという事前に選択された固定長を使用する。
往復遅延測定パケットの期間に発生するイベントのタイミングは図35に示されている。図35において、ホストは、その後に全ゼロ1フィールドおよびガード時間1フィールドが続くパラメーターCRCフィールドおよびストローブアライメントフィールドの存在により示される、往復遅延測定パケットを送信する。パケットがクライアントディスプレイ装置又は処理回路網に達する前に遅延3502が発生する。クライアントがパケットを受信すると、それはクライアントにより決定されるような測定期間の始まりにできる限り正確に、0xff、0xff及び0x0パターンの30バイトを送信する。クライアントがこのシーケンスの送信を開始する実際の時間は、ホストの観点では測定期間の始まりから遅延している。この遅延の量が実質的に、パケットがラインドライバーとレシーバを通して伝搬し、サブシステム(ケーブル、導線)を相互接続するために要する時間である。類似する遅延の量3504が、パターンがクライアントからホストに伝搬して戻るパターンについて発生する。
クライアントに、及びクライアントから行き来する信号のために往復遅延時間を正確に決定するために、ホストは、測定期間の開始後、0xff、0xff、及び30バイトの0x0シーケンスの始まりが到着時に検出されるまでに発生する順方向リンクビット時間期間の数をカウントする。この情報は、往復遅延信号がホストからクライアント、及び再び逆に通過する時間量を求めるために使用される。したがって、この量の約2分の1はクライアントへの信号の一方向の通過のために生じる遅延を原因とする。
ホストとクライアントの両方とも、MDDI_DATAラインを定められた状態に保つために、両方のガード時間中にラインをロジックゼロレベルに駆動する。ホストとクライアントの両方のガード時間が経過する期間のエネーブルおよびディスエーブル時間は、いずれかの適正な往復遅延時間における、MDDI_データ信号が適正な低レベルにある時間である。
26.順方向リンクスキュー校正パケット
順方向リンクスキュー校正パケットは、クライアント又はディスプレイがMDDI_Stb信号に関してMDDI_Data信号の伝搬遅延での差異がないかそれ自体を校正できるようにする。遅延スキュー補償を行わないと、最大データレートは通常これらの遅延の潜在的な最悪のケースの変動を考慮に入れるために制限される。通常、このパケットは、順方向リンクデータが約50Mbps以下の速度に構成されるときにだけ送信される。ディスプレイを校正するためにこのパケットを送信した後に、データレートは50Mbpsを超えて強化される。データレートがスキュー補償プロセスの間に高く設定しすぎると、ディスプレイは、遅延スキュー補償設定値を1ビットを超える時間オフにし、その結果誤ったデータクロッキングを生じさせる結果となる、ビット期間のエイリアスに同期する可能性がある。最高データレートタイプのインターフェース又は最大可能インターフェースタイプは、すべての既存のデータビットが校正されるように、順方向リンクスキュー校正パケットを送信する前に選択される。
順方向リンクスキュー校正パケットのフォーマットの一実施例は図56に示されている。図56に示されているように、この種のパケットはパケット長(2バイト)フィールド、パケットタイプフィールド、hClient IDフィールド、パラメーターCRCフィールド、全ゼロ1フィールド、校正データシーケンスフィールド及び全ゼロ2フィールドを有するように構造化されている。この種のパケットは通常、タイプフィールドでタイプ83パケットとして識別され、一実施の形態において519という事前に選択された長さを有する。
仮想制御パネル
VCPを使用すると、ホストはクライアントで特定のユーザ制御を設定できる。これらのパラメーターをホストにより調整できるようにすることによって、クライアントのユーザインターフェースは、ユーザが音声音量又はディスプレイ明度等のパラメーターを調整できるようにする画面がクライアント内の1台又は複数台のマイクロプロセッサによってよりむしろホストソフトウェアによって生成できるために簡略化できる。ホストは、クライアントのパラメーター設定値を読み取り、制御ごとの有効値の範囲を求める能力を有する。クライアントは、一般にどの制御パラメーターを調整できるのかをホストに報告する能力を有する。
制御コード(VCPコード)及び一般的に指定される関連データ値は、クライアントの制御と設定値を指定するために活用される。MDDI指定のVCPコードはパケット定義における適切なデータフィールド位置合わせを保存するために、及び将来、このインターフェースに、又は将来の機能強化に一意である補足値をサポートするために16ビットに拡大される。
26.VCP特徴要求パケット法。
VCP特徴要求パケットは、ホストが特定の制御パラメーター又はすべての有効な制御パラメーターの現在の設定値を要求するための手段、機構又は方法を提供する。一般的には、クライアントはVCP特徴応答パケットで適切な情報でVCPパケットに応答する。一実施形態では、クライアントはクライアント機能パケットのクライアント特徴機能インジケータのビット13を使用してVCP特徴要求パケットをサポートする能力を示す。
一実施形態におけるVCP特徴要求パケットのフォーマットは図69に示されている。
図69で見られるように、この種のパケットは、パケット長フィールド、パケットタイプフィールド、hClient IDフィールド、ディスプレイセレクタフィールド、モニタ制御コマンドセット(MCCS)VCPコードフィールド及びCRCフィールドを有するように構造化されている。この種のパケットは、通常、2バイトタイプフィールドに示されているタイプ128として一実施形態で識別される。パケット長フィールドを含まないパケット内のビットの総数を指定するパケット長は、通常、10バイトという長さでこの種のパケットに固定されている。
hClient IDフィールドは将来の実行においてクライアントIDとして使用するために予約され、そして一般的にはゼロに設定される。
一実施形態において、VCP特徴応答パケット内の2バイトディスプレイ選択フィールドは、VCPパケットを適用するディスプレイを指定する。ディスプレイセレクタフィールドのビット0は、VCPパケットが適用されるディスプレイを選択する。ビット0が0に等しいとき、VCPパケットは、下記のビット11乃至8により指定される代替ディスプレイに適用する。他方、ビット0が1、ロジック1レベルに等しいなら、VCPパケットは一次ディスプレイに適用する。現在、ディスプレイセレクタフィールドのビット7乃至1は、将来の使用のために予約され、一般的にゼロ値に等しく設定され、またはビットはロジックゼロレベルに設定される。
ディスプレイセレクタフィールドのビット11乃至8は、VCPパケットが適用されるであろう代替ディスプレイを指定するために4ビットに符号なしの整数値を使用する。ディスプレイセレクタフィールドのビット0が0(ロジックゼロレベル)に等しいとき、クライアントは、ビット11乃至8を代替ディスプレイ番号として解釈する。ビット0が0に等しくないなら、ビット11乃至8はゼロに設定され無視されるであろう。ビット15乃至12は、将来の使用のために予約され、一般的にゼロに設定され、または各ビットはロジックゼロレベルに設定される。
一実施形態において、MCCS VCPコードフィールドは、MCCS VCPコードパラメーターを指定する2バイトの情報を含む。0乃至255の範囲の値は、指定されたMCCSコードに対応するVCP特徴応答リスト内の単一アイテムを用いてVCP特徴応答パケットを戻させる。65535(Oxffff)のMCCS VCP コードは、クライアントにサポートされた各制御のための特徴応答リストを含むVCP特徴応答リストを有したVCP特徴応答パケットを要求する。このフィールドのための256乃至65534の値は、将来の使用のために予約され、現在使用されていない。
2バイトCRCフィールドは、パケット長を含むパケット内のすべてのバイトのCRCを含む。
27.VCP特徴応答パケット
VCP特徴応答パケットは、クライアントが特定の制御パラメーター又はすべての制御パラメーターの現在の設定値でホスト要求に応えるための手段、機構又は方法を提供する。一般的には、クライアントはVCP特徴要求パケットに応えてVCP特徴応答パケットを送信する。このパケットは、特定のパラメーターの現在設定値を突き止め、特定の制御のための有効な範囲を決定し、特定の制御がクライアントによってサポートされているかどうかを判断し、あるいはクライアントによってサポートされている制御のセットを決定するために有効である。クライアント内で実現されない特定の制御を参照するVCP特徴要求が送信される場合、VCP特徴応答パケットは適切なエラーコードを含む実現されていない制御に対応する単一VCP特徴応答リストアイテムと共に返される。一実施形態では、クライアントは、クライアント機能パケットのクライアント特徴機能フィールドのビット13を使用してVCP特徴応答パケットをサポートする能力を示す。
一実施形態でのVCP特徴応答パケットのフォーマットは図70に示されている。図70で分かるように、この種のパケットは、パケット長フィールド、パケットタイプフィールド、cClient IDフィールド、ディスプレイセレクタフィールド、MCCSバージョンフィールド、応答シーケンス番号フィールド、VCP特徴応答リストフィールド、及びCRCフィールドを有するように構造化されている。通常一実施形態では、この種のパケットは、2バイトタイプフィールドに示されるようにタイプ129として識別される。
cClient IDフィールドはクライアントIDに予約される情報を含む。このフィールドは将来の使用のために予約され、通常はゼロに設定されている。
一実施形態において、VCP特徴応答パケット内の2バイトディスプレイセレクタフィールドは、VCPパケットを適用するディスプレイを指定する。ディスプレイセレクタフィールドのビット0は、VCPパケットを適用するディスプレイを選択する。ビット0が0に等しいとき、VCPパケットは、下記のビット11乃至8により指定される代替ディスプレイに適用する。他方、ビット0が1、ロジック1レベルに等しいなら、VCPパケットは一次ディスプレイに適用する。現在ディスプレイセレクタフィールドのビット7乃至1は将来の使用のために予約されており、一般的にゼロ値に等しく設定され、またはビットはロジックゼロレベルに設定される。
ディスプレイセレクタフィールドのビット11乃至8は、4ビットの符号なしの整数値を用いてVCPパケットが適用される代替ディスプレイを指定する。ディスプレイセレクタフィールドのビット0が0(ロジックゼロレベル)に等しいとき、クライアントは、代替ディスプレイ番号としてビット11乃至8を解釈する。ビット0が0に等しくなければ、ビット11乃至8はゼロに設定され、無視されるであろう。ビット15乃至12は将来の使用のために予約され、一般的にゼロ値に設定されるかまたは各ビットはロジックゼロレベルに設定される。
MCCSバージョンフィールドは、クライアントによって実現されるVESA MCCS仕様のバージョンを指定する2バイトの情報を含む。
VCP特徴応答パケット内の2バイト応答シーケンス番号フィールドは、クライアントにより返送されたVCP特徴応答パケットのシーケンス番号を指定する情報またはデータを含む。クライアントは65535というMCCS制御コード値と共に、VCP特徴要求パケットに応えて1つ又は複数のVCP特徴応答パケットを返す。クライアントは複数のVCP特徴応答パケット上で特徴応答リストを広げるかまたは転送してもよい。この場合、クライアントは各連続パケットにシーケンス番号または識別子を割り当てなければならず、単一のVCP特徴要求パケットに応えて送信されるVCP特徴応答パケットのシーケンス番号はゼロで開始し、1だけ増加する。最後のVCP特徴応答パケット内のVCP特徴応答リストアイテムはパケットが最後のパケットであることを識別するために0xffffに等しいMCCS VCP制御コード値を含まなければならず、返されるパケットのグループの最高のシーケンス番号を含む。VCP特徴要求パケットに応答して唯一のVCP特徴応答パケットが送信されるなら、その単一パケット内の応答シーケンス番号は一般的にゼロに設定され、VCP特徴応答リストは、0xffffに等しいVCP特徴リストアイテム内のMCCS VCPコードを有するリストアイテムを含む。VCP特徴応答リストアイテムパケット内の最大の値および現在の値(図71)は、MCCS VCP制御コードが0xffffに等しいときゼロに設定される。
リストフィールド内の特徴の数は、このパケット内のVCP特徴応答リスト内にあるVCP特徴応答リストアイテムの数を指定する2バイトを含み、一方VCP特徴応答リストフィールドは、1つ以上のVCP特徴応答リストアイテムを含むバイトのグループである。一実施形態での単一のVCP特徴応答リストアイテムのフォーマットは図71に示される。
図71に示されているように、各VCP特徴応答リストアイテムは長さが正確に12バイトであり、MCCS VCPコードフィールド、結果コードフィールド、最大値フィールド及び現在値フィールドを備える。2バイトのMCCS VCP制御フィールドはこのリストアイテムと関連付けられるMCCS VCP制御コードパラメーターを指定するデータ又は情報を含む。この実施形態に関し、VESA MCCS仕様書バージョン2以降に定められる制御コード値だけが有効と見なされる。2バイト結果コードフィールドは指定されたMCCS VCP制御に関して情報の要求に関係するエラーコードを指定する情報を含む。「1」という値が、指定された制御がクライアントで実現されないことを意味する一方、このフィールドの「0」という値はエラーがないことを意味する。2から65535のこのフィールドの追加の値は、将来の使用及び技術によって考慮される他の応用例の実施のために現在予約されているが、当面使用されることはない。
4バイトの最大値フィールドは、指定されたMCCS制御を設定することができる最大の可能な値を指定する。要求される制御がクライアントの中で実現されない場合、この値はゼロに設定される。返された値の長さが32ビット(4バイト)未満である場合は、値は32ビット整数の中に入れられ、最上位(未使用)バイトをゼロに設定されたままにする。4バイトの現在値提示フィールドは、指定されたMCCS VCP連続(C)又は非連続(NC)制御の現在値を指定する情報を含む。要求された制御がクライアントで実現されない場合、あるいは制御が実現されるが、テーブル(T)データタイプである場合には、この値はゼロに設定される。返される値の長さがVESA MCCS仕様を通じた32ビット(4バイト)未満である場合には、値は32ビット整数の中に入れられ、最上位(未使用)バイトをゼロに設定されたままにする。指定されたMCCS VCPコードが非連続制御またはテーブルデータタイプに相当するなら、最大値フィールドはゼロになるように設定されるかまたは選択される。
28.VCP特徴設定パケット
VCP特徴設定パケットは、ホストがクライアント内での連続制御と非連続制御の両方にVCP制御値を設定するための手段、機構又は方法を提供する。一実施形態では、クライアントはクライアント機能パケットのクライアント特徴機能フィールドのビット13を使用してVCP特徴設定パケットをサポートする能力を示す。
一実施形態におけるVCP特徴設定パケットのフォーマットは図72に示されている。図72で分かるように、この種のパケットはパケット長フィールド、パケットタイプフィールド、hClient IDフィールド、ディスプレイセレクタフィールド、MCCSVCPコードフィールド、リスト中の値数フィールド、制御値リストフィールド、及びCRCフィールドを有するように構造化されている。この種のパケットは、通常、2バイトタイプフィールドで示されるようにタイプ130として識別され、パケット長フィールドを除き20バイトの長さである。
一実施形態において、hClient IDフィールドは再びクライアントIDとして指定するために、あるいはClient IDとして働くために2バイト値を使用する。このフィールドは将来の仕様のために予約され、現在はゼロ値に設定されている。
一実施形態において、セットVCP特徴パケット内の2バイトディスプレイセレクタフィールドは、VCPパケットをどこに適用するかを指定する。ディスプレイセレクタフィールドのビット0は、VCPパケットが適用されるディスプレイを選択する。ビット0が0に等しいとき、VCPパケットは下記のビット11乃至8により指定される代替ディスプレイに適用される。他方、ビット0が1、ロジック1レベルに等しいなら、VCPパケットは一次ディスプレイに適用される。現在、ディスプレイセレクタフィールドのビット7乃至1は、将来の使用のために予約され、一般的にゼロ値に等しく設定されるかまたはビットは、ロジックゼロレベルに設定される。
ディスプレイセレクタフィールドのビット11乃至8は、VCPパケットが適用されるであろう代替ディスプレイを指定する。ディスプレイセレクタフィールドのビット0が0(ロジックゼロレベル)に等しいとき、クライアントは、ビット11乃至8を代替ディスプレイ番号として解釈する。ビット0が0に等しくないなら、ビット11乃至8は、ゼロに設定され、無視されるであろう。ビット15乃至12は将来の使用のために予約され、一般的にゼロ値に設定されるかまたは各ビットはロジックゼロレベルに設定される。
セットVCP特徴パケットのためのMCCS VCPコードは、2バイトの情報または値を用いて、調整されるMCCS VCP制御コードパラメーターを指定する。2バイトのリスト中の値数フィールドは、制御値リストに存在する16ビット値の数を指定する情報又は値を含む。制御値リストは、MCCS制御コードがクライアント内のテーブルに関連しない限り通常1つのアイテムを含む。非テーブル関連制御の場合、制御値リストはMCCS VCPコードフィールドにより指定される制御パラメーターに書き込まれる新しい値を指定する値を含むであろう。テーブル関連制御の場合、制御値リスト中のデータのフォーマットは指定されたMCCS VCPコードのパラメーター説明によって指定される。
リストが1バイトより大きい値を含む場合には、どこか他の箇所に定義される方法に一貫して最下位ビットが最初に送信される。最後に2バイトのCRCフィールドが、パケット長を含むパケット内のすべてのバイトの16ビットCRCを含む。
29.有効パラメーター要求パケット
有効パラメーター要求パケットは、クライアントが指定されたNC又は表(T)制御によってサポートされているパラメーターのリストを含む有効パラメーター応答パケットを返すことを要求するために有用な手段又は構造として使用される。このパケットは、非連続(NC)制御又はクライアントの表に関連する制御だけを指定しなければならず、すべての制御を指定するために65535(0xffff)というMCCS VCPコード値を指定してはならない。サポートされていない、又は無効のMCCS VCPコードが指定される場合には、適切なエラー値が有効パラメーター応答パケットで返される。一実施形態では、クライアントは表示機能パケットのクライアント特徴機能フィールドのビット13を使用して有効パラメーター要求パケットをサポートする能力を示す。
一実施形態における有効パラメーター要求パケットのフォーマットは図73に示されている。図73に示されているように、この種のパケットはパケット長フィールド、パケットタイプフィールド、hClient IDフィールド、ディスプレイセレクタフィールド、MCCS VCPコードフィールド及びCRCフィールドを有するように構造化されている。この種のパケットは、2バイトタイプフィールドに示されているように、通常タイプ131として1つの実施形態で識別されている。
2バイトのパケット長フィールドに示されているようにパケット長は、通常、8というパケット長フィールドを含まずにパケット内のバイトの総数を有するために設定される。hClient IDは先の場合と同様にクライアントIDを指定するが、当業者に明らかとなるように現在は将来の使用のために予約されており、ゼロ値またはロジックゼロレベルに設定されている。
一実施形態において、有効パラメーター要求パケット内の2バイトディスプレイセレクタフィールドは、VCPパケットをどこに適用するかを指定する。ディスプレイセレクタフィールドのビット0は、VCPパケットが適用されるディスプレイを選択する。ビット0が0に等しいとき、VCPパケットは、下記のビット11乃至8により指定される代替ディスプレイに適用される。他方、ビット0が1、ロジック1レベルに等しいなら、VCPパケットは一次ディスプレイに適用される。現在、ディスプレイセレクタフィールドのビット7乃至1は将来の使用のために予約され、一般的にゼロ値に設定されるかまたはビットはロジックゼロレベルに設定される。
ディスプレイセレクタフィールドのビット11乃至8は、VCPパケットが適用されるであろう代替ディスプレイを指定する。ディスプレイセレクタフィールドのビット0が0(ロジックゼロレベル)に等しいとき、クライアントは、ビット11乃至8を代替ディスプレイ番号として解釈する。ビット0が0に等しくないなら、ビット11乃至8はゼロに設定され、無視されるであろう。ビット15乃至12は将来の使用のために予約され、一般的にゼロ値に設定されるかまたは各ビットはロジックゼロレベルに設定される。
有効パラメーター要求パケットのための2バイトのMCCS VCPコードフィールドは、照会される非連続MCCS VCP制御コードパラメーターを指定する値を含む。このフィールドの値はクライアントで実現される非連続制御に相当する。値256から65535(0xffff)は通常、予約されるか、あるいは有効と見なされ、エラー応答の中で実現される制御として見なされている。CRCフィールド、ここでは2バイトは、パケット長を含むパケット内のすべてのバイトのCRCを含む。
30.有効パラメーター応答パケット
有効パラメーター応答パケットは、有効パラメーター要求パケットに応答して送信される。それは、非連続MCCS VCP制御又は表のコンテンツを返す制御のための有効な設定値を識別するための手段、方法又は構造として使用される。制御がクライアント内の表に関する場合、VCPパラメーター応答リストは単に要求された順次表値の特定なリストを含むだけである。表のコンテンツが単一の有効パラメーター応答パケットに適合しない場合、順次応答シーケンス番号の付いた複数のパケットがクライアントによって送信できる。一実施形態では、クライアントはクライアント機能パケットのクライアント特徴機能フィールドのビット13を使用して有効パラメーター応答パケットをサポートする能力を示す。
ホストは、次のようにテーブルのコンテンツを要求してよい。ホストは、読み取り/書き込みパラメーター、ルックアップテーブル(LUT)オフセット、及びRGB選択等の必要な又は所望されるパラメーターを含むVCP特徴設定パケット設定を送信する。それから所望される制御を指定する有効パラメーター要求パケットがホストによって送信され、次にクライアントが、表データを含む1つ又は複数の有効パラメーター応答パケットを返す。動作のこのシーケンスがMCCS動作モデルに説明される表読み取り機能として類似する機能を実行する。
特定のクライアントパラメーターがクライアントによってサポートされていない場合には、一実施形態においてこのパケットの対応するフィールドは255という値を含むであろう。クライアントで使用されるパラメーターの場合、対応するフィールドはクライアント内にパラメーターの値を含む必要がある。
一実施形態の有効パラメーター応答パケットのフォーマットは図74に示されている。図74で分かるように、この種のパケットはパケット長フィールド、パケットタイプフィールド、cClient IDフィールド、ディスプレイセレクタフィールド、MCCSVCPコードフィールド、応答コードフィールド、シーケンス番号応答フィールド、リスト中の番号値フィールド、VCPパラメーター応答リストフィールド及びCRCフィールドを有するように構造化されている。この種のパケットは、通常、2バイトタイプフィールドに示されているようにタイプ132として一実施形態について識別される。
cClient IDフィールドは、上述の記載から周知のように将来のClientIDのために予約される。
一実施形態において、2バイトのディスプレイセレクタフィールドは、VCPパケットをどこに適用するかに関しての情報を含む。ディスプレイセレクタフィールドのビット0は、VCPパケットが適用されるディスプレイを選択する。ビット0が0に等しいなら、VCPパケットは、下記のビット11乃至8により指定される代替ディスプレイに適用される。他方、ビット0が1、ロジック1レベルに等しいなら、VCPパケットは一次ディスプレイに適用される。現在、ディスプレイセレクタフィールドのビット7乃至1は、将来の使用のために予約され、一般的にゼロ値に等しく設定されるかまたはビットはロジックゼロレベルに設定される。
ディスプレイセレクタフィールドのビット11乃至8は、VCPパケットが適用されるであろう代替ディスプレイを指定する。ビット0が0(ロジックゼロレベル)に等しいなら、クライアントは、ビット11乃至8を代替ディスプレイ番号として解釈する。ビット0が0に等しくないならば、ビット11乃至8はゼロに設定され無視されるであろう。ビット15乃至12は将来の使用のために予約され、一般的にゼロ値に設定されるかまたは各ビットは、ロジックゼロレベルに設定される。
一実施形態において、3バイトMCCS VCPコードパケットは、このパケットにより記載される非連続的なMCCS VCP制御コードパラメーターを指定する値を含む。無効のMCCS VCP制御コードが有効パラメーター要求パケットにより指定されるなら、同じ無効パラメーター値がこのフィールドにおいて、応答コードフィールド内の適切な値とともに指定されるであろう。MCCS制御コードが無効ならVCPパラメーター応答リストはゼロレングスを有するであろう。
応答コードフィールドは、指定されたMCCS VCP制御に関する情報に対する要求に関連する応答の性質を指定する2バイトの情報又は値を含む。このフィールドの値が0に等しい場合には、エラーはこのデータタイプに存在するとは見なされず、シーケンスの中の最後の有効パラメーター応答パケットが送信され、それは最高の応答シーケンス番号を有する。このフィールドの値が1に等しい場合には、エラーは存在すると見なされないが、さらに高いシーケンス番号を有する他の有効パラメーター応答パケットが送信される。このフィールドの値が2に等しい場合には、指定された制御はクライアントで実現されると見なされない。このフィールドidの値が3に等しい場合には、指定された制御は非連続制御ではない(ゼロからその最大値まですべての値の有効な集合を常に有するのは連続制御である)。4から65535に等しいこのフィールドの値は将来の使用のために予約され、通常は使用されるべきではない。
2バイト応答シーケンス番号フィールドは、クライアントによって返される有効パラメーター応答パケットのシーケンス番号を指定する。クライアントは、有効パラメーター要求パケットに応えて1つ又は複数の有効なパラメーター応答パケットを返す。クライアントは複数の有効パラメーター応答パケット上でVCPパラメーター応答リストを広げてよい。この後者のケースでは、クライアントが各連続パケットにシーケンス番号を割り当て、シーケンス内の最後のパケットを除くすべてで応答コードを1に設定する。シーケンス内の最後の有効パラメーター応答パケットは最高の応答シーケンス番号を有し、応答コードは0という値を含む。
2バイトのリスト中の値の数フィールドは、VCPパラメーター応答リストに存在する16ビット値という数を指定する。応答コードがゼロに等しくない場合には、リスト中の値の数パラメーターはゼロである。VCPパラメーター応答リストフィールドはMCCS制御コードフィールドにより指定される非連続制御の有効な値の集合を示す0から32760の2バイト値のリストを含む。非連続制御コードの定義はVESA MCCS仕様で指定される。最後に本実施形態では、CRCフィールドはパケット長を含むパケット内のすべてのバイトの16ビットCRCを含む。
スケーリングされたビデオストリーム画像MDDI又はプロトコル機構、構造、手段又は方法は、ホストが元の画像より大きく又は小さく拡大縮小されるクライアントに画像を送信できるようにするスケーリングされたビデオストリーム画像に対するサポートを提供し、スケーリングされた画像はメイン画像バッファにコピーされる。スケーリングされたビデオストリーム機能性と関連プロトコルサポートの概要は他の箇所で示される。スケーリングされたビデオストリームをサポートする能力は、特殊ステータス要求パケットに応えて送信されるスケーリングされたビデオストリーム機能によって、あるいは中で定義される。
以下に記載されるスケーリングされたビデオストリームパケットのヘッダーは、ヘッダーが画像を表示するのに必要な全体のコンテクストを含むより簡単なビデオストリームパケットとわずかに異なる。スケーリングされたビデオストリームパケットはセットアップパケットを使用して、ソースおよびデスティネーションウィンドウサイズおよび位置のパラメーター、およびピクセルデータを送信するために別個のスケーリングされたビデオストリームパケットを定義する。クライアントは、セットアップパケットからのストリームパラメーターおよび各ストリームに関連するピクセルデータの一部を記憶するために各ストリームに関連する内部記録を割り当てる。各ストリームが変化するのに必要な記憶量は、ソース画像およびデスティネーション画像のサイズおよびセットアップパケットにおいて指定された値に依存する。従って、プロトコルは、クライアントが、各スケーリングされたビデオストリームに関連する記憶装置の割り当てのためのダイナミックなメモリアロケーションを実施可能にするように設計される。
プログラムソースに固有のサイズを有するディスプレイにビデオストリームを送り、特定のエンドアプリケーションに適切な方法で画像の表示スケールおよび位置を有することは有用である。複数のビデオ画像のリアルタイムスケーリングのための実施は、この特徴のサポートをクライアントにおいてオプションにさせるために十分複雑である。
31.スケーリングビデオストリーム機能パケット
スケーリングビデオストリーム機能パケットはクライアントの中の、あるいはクライアントによって使用されるスケーリングビデオストリームソース画像の特性を定義する。スケーリングされたビデオストリーム機能パケットのフォーマットは一般的に図75に示される。図75で分かるように、一実施形態では、スケーリングビデオストリーム機能パケットはパケット長フィールド、パケットタイプフィールド、cClient IDフィールド、最大ストリーム数フィールド、ソース最大Xサイズフィールド、ソース最大Yサイズフィールド、RGB機能フィールド、白黒機能フィールド、予約1フィールド、Y Cr Cb機能フィールド、予約2フィールド及びCRCフィールドを有するように構造化されている。一実施形態において、パケット長は、長さフィールドに示されているように、クライアントIDの使用のために予約され、それ以外の場合ゼロに設定される2バイトのcClient IDフィールド、及びCRCフィールドを含む固定された20バイトとなるように選択されている。一実施形態では、クライアントは、有効ステータス応答リストパケットの有効パラメーター応答リストの中で143というパラメーター値を使用してスケーリングビデオストリーム機能パケットをサポートする能力を示す。
2バイトの最大ストリーム数フィールドは、一度に割り当てられてよい同時スケーリングされたビデオストリームの最大数を識別するための値を含む。一実施形態では、クライアントは、最大数のスケーリングされたビデオストリームがすでに割り当てられている場合、スケーリングされたビデオストリームを割り当てる要求を拒絶しなければならない。最大数未満のスケーリングされたビデオストリームが割り当てられている場合は、クライアントはクライアントにおける他のリソース制限に基づいて割り当て要求を拒絶してもよい。
ソース最大XサイズフィールドとYサイズフィールド(2バイト)は、多くのピクセルとして表されるスケーリングされたビデオストリームソース画像の、それぞれ最大幅と高さの値を指定する。
RGB機能フィールドは、RGBフォーマットで表示できる解像度のビット数を指定するために値を使用する。スケーリングされたビデオストリームがRGBフォーマットを使用できない場合、この値はゼロに等しく設定される。ビット5から12は将来の機能定義で将来使用するために予約され、通常はゼロに設定されているが、RGB機能ワードは、各ピクセルの青の最大ビット数(青輝度)を定義するビット3から0、各ピクセルの緑の最大ビット数(緑輝度)を定義するビット7から4、及び各ピクセルの赤の最大ビット数(赤輝度)を定義するビット11から8の3つの別々の符号なし値から構成されている。
1バイトの白黒機能フィールドは、白黒フォーマットで表示できる解像度のビット数を指定する値を含む。スケーリングされたビデオストリームが白黒フォーマットを使用できない場合、この値はゼロに設定される。ビット7から4は将来の使用のために予約されているため、当業者によって理解されるように、これは経時的に変化する可能性はあるが現在の応用例についてはゼロ(「0」)に設定されなければならない。ビット3から0は各ピクセルに存在できるグレイスケールの最大ビット数を定義する。これらの4個のビットは、各ピクセルが1から15ビットからなることを指定できるようにする。値がゼロである場合には、白黒フォーマットはスケーリングされたビデオストリームによってサポートされていない。
予約1フィールド(ここでは1バイト)は、スケーリングビデオストリームパケット情報又はデータに関係する値を提供する際に将来使用するために予約されている。したがって、現在このフィールドのすべてのビットはロジック「0」に設定されている。このフィールドの1つの目的は、すべての以後の2バイトフィールドを16ビットワードアドレスに位置合わせさせ、4バイトフィールドを32ビットワードアドレスに位置合わせさせることである。
2バイトのY Cb Cr機能フィールドは、Y Cb Crフォーマットで表示できる解像度のビット数を指定する値を含む。スケーリングされたビデオストリームがY Cb Crフォーマットを使用できない場合には、この値はゼロである。
1バイトの機能ビットフィールドは、スケーリングされたビデオストリームと関連する機能を指定するフラグのセットを含む。フラグは以下のとおりに定義される。ビット0はスケーリングビデオストリームパケットのピクセルデータをカバーし、パックフォーマットとなることができる。パックされ、バイト位置合わせされたデータは図13に前記に示されている。ビット1は将来の使用のために予約され、ゼロに設定されるものとする。ビット2は将来の使用のために予約され、一般にゼロに設定される。ビット3は、カラーマップデータフォーマットで指定できるスケーリングビデオストリームをカバーする。同じカラーマップテーブルが、メイン画像バッファ及びアルファ−カーソル画像平面に使用されるようにスケーリングされたビデオストリームに使用される。カラーマップは、他の箇所で説明されるカラーマップパケットを使用して構成されている。そしてビット7から4は将来の使用のために予約され、通常はゼロに設定されている。
予約2フィールド(ここでは1バイト)は、スケーリングビデオストリームパケット情報又はデータに関係する値を提供する上で将来の使用に予約されている。したがって、現在、このフィールドのすべての値はロジック「0」に設定されている。このフィールドの1つの目的は、すべての以後の2バイトフィールドを16ビットワードアドレスに位置合わせさせ、4バイトフィールドを32ビットワードアドレスに位置合わせさせることである。
32.スケーリングされたビデオストリームセットアップパケット
スケーリングされたビデオストリームセットアップパケットは、スケーリングされたビデオストリームのパラメーターを定義するために使用される手段、構造または方法を提供し、クライアントは、画像のバッファリングおよびスケーリングのための内部記憶装置を割り当てるためにこの情報を使用する。ストリームは、X画像サイズフィールドとY画像サイズフィールドがゼロに等しい状態で、このパケットを送信することによって割り当て解除されてよい。割り当て解除されたスケーリングビデオストリームは、後で、同じストリームパラメーター又は異なるストリームパラメーターを用いて割り当てし直されてよい。一実施形態では、クライアントは有効ステータス応答リストパケットの有効パラメーター応答リストの143というパラメーター値を使用して、及びスケーリングビデオストリーム機能パケットの最大ストリーム数フィールドで非ゼロ値を使用することによってスケーリングビデオストリームセットアップパケットをサポートする能力を示す。
スケーリングされたビデオストリームセットアップパケットのフォーマットは概して図76に示されている。図76で分かるように、一実施形態では、スケーリングビデオストリームセットアップパケットは、パケット長フィールド、パケットタイプフィールド、hClientフィールド、ストリームIDフィールド、ビデオデータフォーマットディスクリプタフィールド、ピクセルデータ属性フィールド、X左端縁フィールド、Y上部端縁フィールド、X右端縁フィールド、Y下部端縁フィールド、X画像サイズフィールド、Y画像サイズフィールド、及びCRCフィールドを有するように構造化されている。
2バイトのパケット長フィールドは、パケット長フィールドを含まないパケットの中のバイト総数を指定する。一実施形態では、このパケット長は24で固定されている。2バイトのパケットタイプフィールドはパケットをスケーリングビデオストリームセットアップパケットとして識別するために136という値を利用する。2バイトのhClientIDフィールドはクライアントIDとしての将来の使用のために予約されており、通常は当面、あるいはプロトコルユーザが、公知であるように、どのID値を使用しなければならないのか判断するまで、全てのビットがロジック−ゼロ値に設定されている。
ストリームIDフィールドは、ストリームIDの一意の識別子を指定するために2バイトを使用する。この値はホストにより割り当てられ、ゼロから、クライアント機能パケットに指定される最大ストリームID値となるものとする。ホストは、各アクティブストリームに一意の値が割り当てられ、もはやアクティブではないストリームが割り当て解除される、あるいは再配分されることを保証するために注意深くストリームID値の使用を管理しなければならない。
一実施形態では、ビデオデータフォーマットディスクリプタフィールドは、本パケットの本ストリームのピクセルデータの各ピクセルのフォーマットを指定するために2バイトを使用する。ピクセルデータフォーマットは、アルファカーソル画像機能パケットに定められるようにアルファ−カーソル画像平面の有効なフォーマットの少なくとも1つと、または一般的に上述した他のパケット内に定義されるように他の予め定義された画像パターンに準拠する必要がある。ビデオデータフォーマットディスクリプタは、現在のパケット専用のピクセルフォーマットを定義し、一定のフォーマットがある特定のビデオストリームの存続期間中に使用し続けられることを暗示していない。図11は、ビデオデータフォーマットディスクリプタがどのようにコード化されるのか、他のパケットについて前述されたように実施形態を示す。
例えば、図12A乃至12Dに見られるように、および一実施形態で使用するように、ビット[15:13]が「000」に等しいとき、ビデオデータは白黒ピクセルのアレイで構成される。この場合、ピクセルあたりのビット数は、ビデオデータフォーマットディスクリプタワードのビット3乃至0により定義される。ビット11乃至4は一般的に将来の使用またはアプリケーションのために予約され、この状況においてゼロに設定される。その代わりに、ビット[15:13]が「001」に等しいとき、ビデオデータは、各々がカラーマップ(パレット)を介して色を指定するカラーピクセルのアレイを構成する。この状況において、ビデオデータフォーマットディスクリプタワードのビット5乃至0はピクセルあたりのビット数を定義し、ビット11乃至6は一般的に将来の使用またはアプリケーションのために予約され、ゼロに等しく設定される。その代わりにビット「15:13」が値「010」に等しいとき、ビデオデータはカラーピクセルのアレイで構成され、赤のピクセルあたりのビット数は、ビット11乃至8により定義され、緑のピクセルあたりのビット数は、ビット7乃至4により定義され、青のピクセルあたりのビット数は、ビット3乃至0により定義される。この状況において、各ピクセル内のビットの合計数は、赤、緑、青に使用されるビット数の和である。
しかしながら、その代わりに、図12Dに示すようにビット「15:13」が値またはストリング「011」に等しいとき、ビデオデータは、輝度情報とクロミナンス情報を有した4:2:2YCbCrフォーマットのビデオデータのアレイで構成され、輝度(Y)のピクセルあたりのビット数は、ビット11乃至8により定義され、Cb成分のビット数は、ビット7乃至4により定義され、Cr成分のビット数は、ビット3乃至0により定義される。各ピクセルにおけるビットの合計数は、赤、緑、青のビット数の和である。CbおよびCr成分は、Yとして半分のレートで送信される。さらに、このパケットのピクセルデータ部分におけるビデオサンプルは、以下のように組織される。Cbn、Yn、Crn、Yn+1、Cbn+2、Yn+2、Crn+2、Yn+3...この場合CbnとCmがYnとYn+1に関連づけられ、Cbn+2とCrn+2はYn+2およびYn+3と関連づけられる等である。Yn、Yn+1、Yn+2およびYn+3は、上に議論された単一行において左から右に4つの連続するピクセルの輝度値である。上述したすべての4つのフォーマットの場合、図では、「P」として指定されるビット12は、ピクセルデータサンプルがパックされているか否かまたはバイト合わせされたピクセルデータか否かを指定する。このフィールドにおける「0」の値は、ピクセルデータフィールドの各ピクセルがMDDIバイト境界とバイト合わせされることを示す。「1」の値は、各ピクセルおよびピクセルデータ内の各ピクセル内の各色は、以前のピクセルまたは未使用ビットを残さないピクセル内の色に対してパックされる。
一実施形態において、2バイトピクセルデータ属性フィールドは、以下のように解釈される値を有する。ビット1および0は、将来の使用のために予約され、現在一般的には、ロジックゼロに設定され、ビット2は、ピクセルデータがインタレースフォーマットであるか否かを示す。ビット2が0であるとき、ピクセルデータは標準の進歩的なフォーマットにある。1つの行から次の行に進むとき行数(ピクセルY座標)は1だけインクリメントされる。ビット2が1であるとき、ピクセルデータはインタレースフォーマットにある。1つの行から次の行に進むとき行数(ピクセルY座標)は2だけインクリメントされる。
一実施形態において、ビット3は、ピクセルデータが代替ピクセルフォーマットにあるか否かを示す。これは、ビット2によりイネーブルにされる標準インタレースモードに類似するが、インタレースは水平よりもむしろ垂直である。ビット3が0であるとき、ピクセルデータは発生されるかまたは標準の進歩的なフォーマットに配置される。各連続するピクセルを受信するごとに、列番号(ピクセルX座標)は1だけインクリメントされる。ビット3が1であるとき、ピクセルデータは発生されるかまたは代替ピクセルフォーマットに配置される。各ピクセルが受信されるごとに列番号(ピクセルX座標)は2だけインクリメントされる。
また、ビット4乃至15は将来の使用のために予約され、一般的にロジックゼロレベルまたは現在のアプリケーションまたは設計のための値に設定される。
33.スケーリングビデオストリームアクノレジメントパケット
スケーリングされたビデオストリームアクノレジメントパケットにより、クライアントはスケーリングされたビデオストリームセットアップパケットの受信を確認できる。クライアントは有効ステータス応答リストパケットの有効パラメーター応答リストの中の143というパラメーター値を介して、及びスケーリングされたビデオストリーム機能パケットの最大ストリーム数フィールドの非ゼロ値を介してスケーリングされたビデオストリームアクノレジメントパケットをサポートするその能力を示すことができる。
スケーリングされたビデオストリームアクノレジメントパケットのフォーマットは概して図77に示されている。図77で分かるように、一実施形態では、スケーリングされたビデオストリームアクノレジメントパケットはパケット長フィールド、パケットタイプフィールド、cClientフィールド、ストリームIDフィールド、ACKコードフィールド及びCRCフィールドを有するように構造化されている。2バイトのパケット長フィールドは、137というパケットタイプがスケーリングされたビデオストリームアクノレジメントパケットとしてパケットを識別する一方で、このパケットタイプの10という値で、パケット長フィールドを除き、バイト総数を指定するために使用される。
2バイトのcClient IDフィールドは、クライアントIDのための将来の使用のために予約されており、通常はゼロに設定されている。2バイトのストリームIDフィールドはストリームIDの一意の識別子を指定する。これはスケーリングビデオストリームセットアップパケットのホストによって割り当てられるのと同じ値である。
2バイトのアクノレッジコードフィールドは、指定されたスケーリングビデオストリームを更新しようとする試みの結果を説明するコードを含む値を提供する。一実施形態では、コードは以下のとおりに定義される。
0−ストリーム割り当て試行は成功した。
1−ストリーム割り当て解除試行は成功した。
2−すでに割り当てられているストリームIDを割り当てようとする無効な試行
3−すでに割り当て解除されているストリームIDを割り当て解除しようとする無効な試行
4−クライアントはスケーリングビデオストリームをサポートしない
5−ストリームパケットはクライアントの機能と一貫していない。
6−ストリームID値はクライアントによって許可される最大値より大きい。
7−指定されたストリームを割り当てるには不十分なクライアント内で入手可能なリソース
2バイトのCRCフィールドは、パケット長を含むパケット内のすべてのバイトのCRCを含む。
34.スケーリングされたビデオストリームパケット
スケーリングされたビデオストリームパケットは、特殊なスケーリングされたビデオストリームと関連したピクセルデータを送信するために使用される。このパケットにより参照される(reference)領域のサイズは、スケーリングされたビデオストリームセットアップパケットにより定義される。クライアントは、有効ステータス応答リストパケットの有効パラメーター応答リストの中のパラメーター値143を介して、及びスケーリングされたビデオストリームアクノレジメントパケットのAckコードフィールド内での成功したスケーリングビデオストリーム割り当て反応を使用して、スケーリングビデオストリームパケットをサポートする能力を示すことができる。
スケーリングビデオストリームパケットの1つの実施形態のフォーマットは、概して図78に示されている。図82で分かるように、スケーリングビデオストリームパケットは、パケット長フィールド、パケットタイプフィールド、hClient IDフィールド、ストリームIDフィールド、ピクセルデータ属性フィールド、ピクセルカウントフィールド、パラメーターCRCフィールド、ピクセルデータフィールド、及びピクセルデータCRCフィールドを有するように構造化されている。2バイトのパケットタイプフィールドはスケーリングビデオストリームパケットとしてパケットを識別するために18という値を使用する。hClient IDフィールドはクライアントIDのために予約されており、通常ゼロに設定されている。前述されたように2バイトのストリームIDフィールドがストリームIDの一意の識別子を指定する。この値はスケーリングされたビデオストリームセットアップパケット内のホストによって指定され、スケーリングされたビデオストリームアクノレジメントパケット内で確認される。一実施形態において、2バイトピクセルデータ属性フィールドは、ピクセルデータルーチンおよび表示更新またはバッファロケーションを指定する値を有する。これらの値は一実施形態にある。
一実施形態において、2バイトピクセルデータ属性フィールドは、ピクセルデータルーチンおよび表示更新またはバッファロケーションを指定する値を有する。これらの値は、一実施形態において、以下のように解釈される。ビット1および0は、ピクセルデータが送られるディスプレイを選択する。「11」または「00」のビット値の場合、ピクセルデータは両方の目に対してまたは目のために表示され、「10」の値の場合、ピクセルデータは、左目だけに送られ、「01」の値の場合、ピクセルデータは右目だけに送られる。
ビット7および6は、ピクセルデータが書かれるフレームバッファを指定するディスプレイ更新ビットである。フレーム更新ビットの作用は、より詳細にほかの場所に記載される。ビット「7:6」が「01」であるとき、ピクセルデータはオフライン画像バッファに書かれる。ビット「7:6」が「00」であるとき、ピクセルデータは、ディスプレイをリフレッシュするために使用される画像バッファに書かれる。ビット[7:6]が「11」であるとき、ピクセルデータは、すべての画像バッファに書かれる。ビット[7:6」が「10」なら、これは無効値として取り扱われる。これらのビットは、現在将来の使用のために予約される。この状況において、ピクセルデータは無視され、画像バッファのいずれにも書かれないであろう。ビット2乃至5および8乃至15は、将来の使用のために予約され、一般的にロジックゼロレベルまたはロジックゼロ値に設定される。
2バイトのピクセルカウントフィールドは、以下のピクセルデータフィールド内のピクセル数を指定する。2バイトパラメーターCRCフィールドはパケット長からピクセルカウントへすべてのバイトのCRCを有する。CRCがチェックできない場合には、パケット全体が廃棄される。2バイトピクセルデータフィールドは、スケーリングされてから表示されなければならない未処理のビデオ情報を含む。データは、ビデオデータフォーマットディスクリプタフィールドによって記述されるようにフォーマットされる。データは過去に定められたように、一度に1行ずつ送信される。
2バイトのピクセルデータCRCフィールドはピクセルデータだけのCRCを含む。このCRCがチェックできない場合には、ピクセルデータが依然として使用されるものとするが、CRCエラーカウントは増分される。
35.特殊ステータス要求パケット
特殊ステータス要求パケットは、このパケットに指定されるように、クライアントが機能又はステータスパケットをホストに送り返すことをホストが要求するための手段、機構又は方法を提供する。クライアントは、次の逆方向リンクカプセルかパケット内に指定されるタイプのパケットを返す。クライアントは、クライアントが特殊ステータス要求パケットに応答する機能を有する場合、クライアント機能パケットのクライアント特徴機能フィールドでビット17を一般に設定する。クライアントが返送することができるまたは転送することができるステータスパケットの全てのタイプを決定するために使用するホストにとって都合の良い方法は他で記載されているバリッドステータスリプレイリストパケット(Valid Status Reply List Packet)を使用することである。クライアントは、クライアント機能パケットのクライアント特徴機能フィールドのビット21を使用してバリッドステータスリプレイリストパケットに応答する能力を示すことができる。
特殊ステータス要求パケットの一実施形態のフォーマットは、概して図79に示されている。図79で分かるように、特殊ステータス要求パケットは、パケット長フィールド、パケットタイプフィールド、hClientIDフィールド、ステータスパケットIDフィールド、及びCRCフィールドを有するように構造化されている。パケット長フィールドはパケット長フィールドを含まないパケット内のバイト総数を指定し、通常このパケットタイプの場合10という値で固定されている。138というパケットタイプは、パケットを特殊ステータス要求パケットに識別する。hClient IDフィールド(2バイト)はクライアントIDのための将来の使用のために予約されており、当面ゼロに設定され、一方2バイトのステータスパケットIDフィールドは、クライアントが以下のとおりにホストに送信する機能又はステータスパケットのタイプを指定する。典型的なパケットタイプは以下の通りである。
66−クライアント機能パケットはクライアントにより送信される。
133−アルファ−カーソル画像機能パケットはクライアントに送信される。
139−クライアントが送信できる機能パケットとステータスパケットの正確なタイプを識別する有効ステータス応答リストパケットが送信される。
141−個人クライアント機能パケットはクライアントによって送信される。
142−クライアントエラーレポート表示パケットはクライアントによって送信される。
143−スケーリングビデオストリーム機能パケットがクライアントによって送信される。
144−クライアント識別パケットがクライアントによって送信される。
パケットタイプ56から63は製造メーカに特殊な機能識別子とステータス識別子に使用できる。
CRCフィールドは、パケット長を含むパケット内のすべてのバイトのCRCを再び含む。
36.有効ステータス応答リストパケット
有効ステータス応答リストパケットは、ホストに、クライアントが戻す機能を有するステータスパケットと機能パケットのリストを有する構造、手段または方法を提供する。クライアントは、クライアント機能パケットのクライアント特徴機能フィールドのビット21を使用して有効ステータス応答リストパケットをサポートする能力を示すことができる。
有効ステータス応答リストパケットの一実施形態のフォーマットは概して図80に示されている。図80で分かるように、有効ステータス応答リストパケットは、パケット長フィールド、パケットタイプフィールド、cClient IDフィールド、リスト中の値数フィールド、有効パラメーター応答リストフィールド、及びCRCフィールドを有するように構造化されている。この種のパケットのパケット長は通常10という値に固定され、139というタイプ値は有効ステータス応答パケットとしてパケットを識別する。
cClient IDフィールドはクライアントIDとしての将来の使用のために予約され、通常ゼロに設定されている。リストフィールド内の2バイトの値の数は、以下の有効パラメーター応答リスト内で項目の数を指定する。
有効パラメーター応答リストフィールドは、クライアントがホストに送信できる機能パケット又はステータスパケットのタイプを指定する2バイトのパラメーターのリストを含む。クライアントが、それが(クライアント機能パケットのクライアント特徴機能フィールドのビット21を使用して)特殊ステータス要求パケットに応答できることを示した場合には、それは少なくともクライアント機能パケット(パケットタイプ=66)と有効ステータス応答リストパケット(パケットタイプ=139)を送信できる。クライアントによって送信でき、このリストの中に含められてよいパケットタイプは、一実施形態の目的のためのそのそれぞれの割り当てと共に、以下のとおりである。
66−クライアント機能パケット
133−アルファ−カーソル画像機能パケット
139−クライアントが送信できる機能パケットとステータスパケットの正確なタイプを識別する有効ステータス応答リストパケット
141−パーソナルディスプレイ機能パケット
142−クライアントエラーレポートパケット
143−スケーリング済みビデオストリーム機能パケット
144−クライアント識別パケット
145−代わりの表示機能パケット
パケットタイプ56から63−製造メーカに特殊な機能及びステータス識別子のために使用できる。
CRCフィールドはパケット長を含むパケット内のすべてのバイトのCRCを含む。
37.パーソナルディスプレイ機能パケット
パーソナルディスプレイ機能パケットは、ヘッドマウントディスプレイ又はディスプレイ眼鏡等のパーソナルディスプレイ装置の機能を記述するパラメーターのセットを提供する。これによりホストはクライアントの特定の機能に従って表示情報をカスタマイズできる。
他方、クライアントは有効ステータス応答リストパケットの有効パラメーター応答リストの対応するパラメーターを使用することによってパーソナルディスプレイ機能パケットを送信する能力を示す。
パーソナルディスプレイ機能パケットの1つの実施形態のフォーマットは概して図81に示されている。図81で分かるように、パーソナルディスプレイ機能パケットは、パケット長フィールド、パケットタイプフィールド、cClient IDフィールド、サブピクセルレイアウトフィールド、ピクセル形状フィールド、水平視野フィールド、垂直視野フィールド、視軸交差フィールド、左右画像フィールド、シースルーフィールド、最大明度フィールド、光学機能フィールド、最小IPDフィールド、最大IPDフィールド、曲率リストのIFeldの点フィールド及びCRCフィールドを有するように構造化されている。一実施形態において、パケット長は68に固定されている。141というパケットタイプ値は、パーソナルディスプレイ表示機能パケットとしてパケットを識別する。cClient IDフィールドは将来の使用のために予約されており、通常は当面ゼロに設定されている。
サブピクセルレイアウトフィールドは以下の値を使用して上から下へ、及び左から右へサブピクセルの物理的なレイアウトを指定する。つまり、0はサブピクセルレイアウトが定義されていないことを示し、1は赤、緑、青の縞を示し、2は青、緑、赤の縞を示し、3は、左上に赤、右下に青、及び一方が左下、他方が右上の2個の緑のサブピクセル2×2のサブピクセル配列を有するクワッドピクセルを示し、4は、左下に赤、右上に青の2×2のサブピクセル配列及び一方が左上、他方が右下の2個の緑のサブピクセルを示し、5はデルタ(トライアド)を示し、6は、赤、緑及び青がオーバレイされた(たとえば、フィールド順次色のLCOSディスプレイ)モザイクを示し、7から255の値が将来の使用のために通常予約されている。
ピクセル形状フィールドは、以下の値を使用し特殊な構成のサブピクセルから構成されている各ピクセルの形状を指定し、0はサブピクセル形状が定められていないことを示し、1は円形を示し、2は正方形を示し、3は矩形を示し、4は長円を示し、5は楕円を示し、値6から255が、当業者が理解できるように、所望される形状を示す上での将来の使用に予約されている。
1バイトの水平視野(HFOV)フィールドは、0.5度の増分で水平視野を指定する(例えばHFOVが30度である場合、この値は60である)。この値がゼロである場合にはHFOVは指定されていない。
1バイトの垂直視野(VFOV)フィールドは、0.5度の増分で垂直視野を指定する(例えば、VFOVが30である場合、この値は60である)。この値がゼロである場合、VFOVは指定されていない。
1バイト視軸交差フィールドは、0.01ジオプタ(1/m)増分で視軸交差を指定する(例えば、視軸交差が2.22メートルである場合、この値は45である)。この値がゼロである場合、視軸交差が指定されない。
1バイトの左/右画像重複フィールドは、左画像と右画像の重複のパーセンテージを指定する。パーセント単位の画像重複の許容可能な範囲は1から100である。101から255の値は無効であり、一般に使用されない。この値がゼロである場合には、画像重複は指定されない。
1バイトシースルーフィールドは、画像のシースルーパーセンテージを指定する。パーセント単位のシースルーの許容範囲は0から100である。101から254の値は無効であり、使用されない。この値が255である場合には、シースルーパーセンテージは指定されない。1バイト最大明度フィールドは20ニットの増分で最大明度を指定する(例えば、最大明度が100ニットである場合、この値は5である)。この値がゼロである場合には、最大明度は指定されない。
2バイト光学機能フラグフィールドはディスプレイの光学機能を指定する多様なフィールドを含む。これらのビット値は、通常、以下に従って割り当てられている。
ビット15から5は将来の使用のために受信され、一般にロジック−ゼロ状態に設定されるものとする。
ビット4はメガネ焦点調整を選択し、「0」という値はディスプレイにメガネ焦点調整がないことを意味し、「1」という値はディスプレイがメガネ焦点調整を有することを意味する。
ビット3から2は、以下に従って両眼機能を選択する。0という値は、ディスプレイが両眼用であり、2次元(2D)画像だけを表示できることを意味し、1は、ディスプレイが両眼用であり、3次元(3D)画像を表示できることを意味し、2は、ディスプレイが単眼用であることを意味し、3は将来の使用のために予約されている。
ビット1から0は、左右像面湾曲対称を選択し、0という値は像面湾曲が定義されていないことを意味する。このフィールドがゼロである場合には、A1からE5までのすべての像面湾曲値は、点C3を除きゼロに設定されるものとし、ディスプレイの焦点距離を指定するものとするか、あるいはゼロに設定され、焦点距離が指定されていないことを示すものとする。1という値は左右のディスプレイが同じ対称性を有することを意味する。2は、左右のディスプレイが垂直軸(列C)でミラーリングされていることを意味し、3は将来の使用のために予約されている。
1バイト相互瞳孔間距離(IPD)最小フィールドは、ミリメートル(mm)で最小の相互瞳孔間距離を指定する。この値がゼロである場合には、最小相互瞳孔間距離が指定されない。1バイトの相互瞳孔間距離(IPD)最大フィールドはミリメートル(mm)で最大相互瞳孔間距離を指定する。この値がゼロである場合には、最大相互瞳孔間距離は指定されない。
像面湾曲の点リストフィールドは、1から65535(例えば、1は0.001ジオプターであり、65535は65.535ジオプターである)の範囲でジオプター(1/m)の千分の1で焦点距離を指定する25の2バイトパラメーターを含む。像面湾曲の点リストの25の要素は、図82に示されているようにA1からE5と呼ばれている。該点はディスプレイのアクティブな領域で均等に分散されるものとする。列Cはディスプレイの垂直軸に相当し、行3はディスプレイの水平軸に相当する。列AとEは、それぞれディスプレイの左端縁と右端縁に相当する。そして、行1と5は、それぞれディスプレイの上部端縁と下部端縁に相当する。リスト中の25の点の順序は以下のとおりである。A1、B1、C1、D1、E1、A2、B2、C2、D2、E2、A3、B3、C3、D3、E3、A4、B4、C4、D4、E4、A5、B5、C5、D5、E5
CRCフィールドは、パケット長を含むパケット内のすべてのバイトのCRCを含む。
38.クライアントエラーレポートパケット
クライアントエラーレポートパケットは、クライアントがホストに動作エラーのリストを提供できるようにするための機構又は手段として働く。クライアントはホストから特定のコマンドを受信した結果としてその通常の動作の過程で幅広い範囲のエラーを検出してよい。これらのエラーの例は以下を含む。クライアントは、それがサポートしていないモードで動作するように命令された可能性がある、クライアントは範囲外である、あるいはクライアントの能力を超えている特定のパラメーターを含むパケットを受信した可能性がある、クライアントは不適切な順序でモードに入るように命令された可能性がある。クライアントエラーレポートパケットは、通常の動作中にエラーを検出するために使用される可能性があるが、ホストシステムとクライアントシステムの開発及び統合における問題点を診断するためにシステム設計者と統合者にもっとも有効である。クライアントは、有効ステータス応答リストパケットの有効パラメーター応答リストで142というパラメーター値を使用して、クライアントエラーレポートパケットを送信するその機能を示す。
クライアントエラーレポートパケットの一実施形態のフォーマットは、概して図83に示されている。図83で分かるように、クライアントエラーレポートパケットはパケット長フィールド、パケットタイプフィールド、cClient IDフィールド、リストアイテム数フィールド、エラーコードリストフィールド及びCRCフィールドを有するように構造化されている。142というパケットタイプ値は、パケットをクライアントエラーレポートパケットとして識別する。cClient IDフィールドは将来の使用のために予約され、通常、当面はゼロに設定されている。リストアイテム数フィールド(2バイト)は以下のエラーコードリストの中のアイテム数を指定する。エラーコードリストフィールド(ここでは8バイト)は、1つ又は複数のエラーレポートリストアイテムを含むリストである。単一のエラーレポートリストアイテムのフォーマットは図87Bに示されている。
一実施形態では、図84に示されているように各エラーレポートリストアイテムの長さは正確に4バイトであり、以下を備える一実施形態での構造を有する。つまり、報告されているエラーのタイプを指定する2バイトの表示エラーコードフィールド、2バイトのエラーサブコードフィールドはクライアントエラーコードパケットにより定められるエラーに関してより大きなレベルの詳細を指定する。各クライアントエラーコードの特殊な定義はクライアントの製造メーカによって定義されている。エラーサブコードは、表示エラーコードごとに定義される必要はなく、エラーサブコードが定義されていないそれらの場合、該値はゼロに設定される。各エラーサブコードの特定の定義はクライアントの製造メーカにより定義される。
39.クライアント識別パケット
クライアント識別パケットは、クライアントが特殊ステータス要求パケットに応えて識別データを返すことができるようにする。一実施形態では、クライアントは有効ステータス応答リストパケットの有効パラメーター応答リストの中の144というパラメーターを使用してクライアント識別パケットを送信する能力を示す。ホストが、クライアントからこのデータを読み取ることによってクライアントデバイスの製造メーカ名及び型番を決定できるようにすることが有効である。情報は、クライアントがクライアント機能パケットに記述できない特殊な機能を有するかどうかを判断するために使用されてよい。クライアントから識別情報を読み取るための潜在的に2つの方法、手段又は機構がある。一方は、ベースEDID構造でのフィールドに類似するフィールドを含むクライアント機能パケットの使用による。他方の方法は、クライアント機能パケット内の類似するフィールドに比較される、より濃密な情報のセットを含むクライアント識別パケットの使用による。これは、ホストが3文字EISAコードを割り当てられていない製造メーカを識別できるようにし、シリアル番号が英数字文字を含むことができるようにする。
クライアント識別パケットの一実施形態のフォーマットは、概して図85に示されている。図85で分かるように、クライアント識別パケットは、パケット長フィールド、パケットタイプフィールド、cClient IDフィールド、製造週フィールド、製造年フィールド、製造メーカ名フィールド、製品名長フィールド、シリアル番号長フィールド、製造メーカ名文字列フィールド、製品名文字列フィールド、シリアル番号文字列フィールド、及びCRCフィールドを有するように構造化されている。
2バイトのパケットタイプフィールドは、クライアント識別パケットとしてパケットを識別する値を含む。この値は一実施形態で144になるように選択される。cClient IDフィールド(2バイト)は再びクライアントID用の将来の使用のために予約され、通常ゼロに設定されている。CRCフィールド(2バイト)は、パケット長を含むパケット内のすべてのバイトの16ビットCRCを含む。
1バイトの製造週フィールドは、ディスプレイの製造週を定める値を含む。少なくとも一実施形態では、この値は、それがクライアントによってサポートされる場合1から53の範囲内にある。このフィールドがクライアントによってサポートされていない場合には、それは通常ゼロに設定されている。1バイトの製造年フィールドは、クライアント(ディスプレイ)の製造の年を定める値を含む。他のベース年も使用できるであろうが、この値は開始点としての年1990からオフセットである。1991から2245の範囲の年をこのフィールドによって表すことができる。例:年2003は13という製造年値に対応する。このフィールドがクライアントによってサポートされていない場合には、それはゼロという値に設定されなければならない。
製造メーカ名長フィールド、製品名長フィールド、及びシリアル番号長フィールドは、あらゆるヌル終端又はヌルパッド文字を含む製造メーカ名文字列フィールドの長さ、あらゆるヌル終端又はヌルパッド文字を含む製品名文字列フィールドの長さ、及びそれぞれヌル終端文字又はヌルパッド文字を含むシリアル番号文字列フィールドの長さを指定する、それぞれ2バイトの値を含む。
製造メーカ名文字列フィールド、製品名文字列フィールド、及びシリアル番号文字列フィールドは、それぞれ製造メーカ、製品名、及び英数字シリアル番号を指定するASCII文字列を含む、それぞれディスプレイの製造メーカ名長フィールド、製品名フィールド、及びシリアル番号フィールドによって指定される可変数のバイトを含む。これらの文字列のそれぞれは少なくとも1つのヌル文字で終端する。
40.代替ディスプレイ機能パケット
代替ディスプレイ機能パケットは、MDDIクライアントコントローラーに取り付けられた代替ディスプレイの機能を示すために手段、構造または方法として使用される。それは特殊ステータス要求パケットに応えて送信される。プロンプトを出されると、クライアントデバイスは、サポートされている代替ディスプレイごとに代替ディスプレイ機能パケットを送信する。クライアントが2つ以上の代替ディスプレイを有するなら、クライアントは、単一特定ステータス要求パケットに応答して、各ディスプレイに1つの割合で、複数の代替ディスプレイ機能パケットを送信し、発生し、または供給しなければならない。だけれども、いくつかの構成は、所望に応じて複数の特定ステータス要求パケットを使用することができる。しかしながら、これは、それほど効率的でない。クライアントはAltディスプレイ番号フィールドの値に基づいて、「非シーケンシャルオーダー」と呼ぶことができるものの内の代替ディスプレイ機能パケットを送信してもよい。クライアントは、有効ステータス応答リストパケットの有効パラメーター応答リスト内の145のパラメーター値を介して代替ディスプレイ機能パケットを送信するための能力を示すことができる。
内部モードで動作されるMDDIシステムの場合、MDDIクライアントコントローラーに接続された2以上のディスプレイを有することは、一般的であってよい。一例としてのアプリケーションは、フリップ(flip)の内部に大きなディスプレイを有し外側により小さなディスプレイを有する携帯電話である。2つの潜在的な理由のために代替ディスプレイ機能パケットを戻すことは内部モードのために必要ではない。第1に、ホストは既にプログラムされているかもしれず、また、それらは一般的な装置またはハウジングにおいて使用されるため、別途製造期間中の能力の情報を知らされているかもしれないからである。第2に、2つのアッセンブリに基づき、クライアントはホストに対する接続について容易に接続を断ちまたは引き離すことができず、そしてホストはクライアント機能についてプログラム中に固定されたコピー(hard-coded copy)を含むことができ、または少なくともこれらは、別の場合に起こるように、クライアントにおける変更について変更することができないからである。
クライアント機能パケットの代替ディスプレイ数フィールドは、複数のディスプレイが取り付けられ、代替ディスプレイ機能パケットが各代替ディスプレイの機能を報告するために使用される。ビデオストリームパケットは、クライアントデバイスの中の各代替ディスプレイに対処するためにピクセルデータ属性フィールドに4ビットを含む。
代替ディスプレイ機能パケットの一実施形態のフォーマットは、概して図89に示されている。図86で分かるように、代替ディスプレイ機能パケットは、パケット長フィールド、パケットタイプフィールド、cClient IDフィールド、代替ディスプレイ数フィールド、予約1フィールド、ビットマップ幅フィールド、ビットマップ高さフィールド、ディスプレイウィンドウ幅フィールド、ディスプレイウィンドウ高さフィールド、カラーマップRGB幅フィールド、RGB機能フィールド、白黒機能フィールド、予約2フィールド、Y Cb Cr機能フィールド、Bayer機能フィールド、予約3フィールド、表示特徴機能フィールド、及びCRCフィールドを有するように構造化されている。145というパケットタイプ値は、代替ディスプレイ機能パケットとしてパケットを識別する。cClient IDフィールドは、将来の使用のためのクライアントIDのために予約され、一般的にビットをロジックゼロレベルに設定することにより、通常はゼロに設定されている。
代替ディスプレイ数フィールドは、0から15の範囲内の整数で代替ディスプレイのアイデンティティを示すために1バイトを使用する。第1の代替ディスプレイは典型的には0番として指定され、他の代替ディスプレイは、使用されている最大数が1を差し引いた代替ディスプレイの総数である、一意の代替ディスプレイ数値で識別される。1を差し引いた代替ディスプレイ総数より大きい値は、使用されない。例:一次ディスプレイとMDDIクライアントに接続されている発呼者IDディスプレイを有する携帯電話は、1つの代替ディスプレイを有するため、発呼者IDディスプレイの代替ディスプレイ数はゼロであり、クライアント機能パケットの代替ディスプレイ数フィールドは1という値を有する。
予約1フィールド(1バイト)は、将来の使用のために予約されている。
それゆえ、このフィールド内のすべてのビットは、現在ゼロまたはロジックゼロレベルに等しくし設定される。一実施形態において、パケット内にこのフィールドを存在させる1つの目的は、すべての次の2バイトフィールドを16ビットワードアドレスに合わさせ、4バイトフィールドを32ビットワードアドレスに合わさせることである。
ビットマップ幅フィールドは、ピクセル数として表されるビットマップの幅を指定する2バイトを使用する。ビットマップ高さフィールドはピクセル数として表されるビットマップの高さを指定する2バイトを使用する。ディスプレイウィンドウ幅フィールドは、ピクセル数として表されるディスプレイウィンドウの幅を指定する2バイトを使用する。ディスプレイウィンドウ高さフィールドはピクセル数として表されるディスプレイウィンドウの高さを指定する2バイトを使用する。
カラーマップRGB幅フィールドは、カラーマップ(パレット)表示モードで表示できる赤、緑、及び青の色成分のビット数を指定する2バイトを使用する。色成分(赤、緑、及び青)ごとに最大8ビットが使用できる。8ビットの各色成分がカラーマップパケットで送信されるとしても、このフィールドに定義される各色成分の最下位ビットの数だけが使用される。ディスプレイクライアントがカラーマップ(パレット)フォーマットを使用できない場合、この値はゼロである。カラーマップRGB幅ワードは、3つの別々の符号なし値から構成されている。
ビット3から0は、0から8という値が有効と考えられる、各ピクセル内の青の最大ビット数を定義する。ビット7から4は、0から8の値が有効と考えられる、各ピクセル内の緑の最大ビット数を定義する。ビット11から8は、0から8の値が有効と考えられる、各ピクセル内の赤の最大ビット数を定義する。ビット14から12は将来の使用のために予約されており、通常ゼロに設定されている。ビット15は、パックフォーマット又はアンパックフォーマットでカラーマップピクセルデータを受け入れるクライアントの能力を示すために使用される。ビット15がロジック1レベルに設定されているとき、これは、クライアントがパックフォーマット又はアンパックフォーマットのどちらかでカラーマップピクセルデータを受け入れることができることを示す。ビット15がロジックゼロに設定されている場合、これは、クライアントがアンパックフォーマットでのみカラーマップピクセルを受け入れることができることを示している。
RGB機能フィールドは、RGBフォーマットで表示できる解像度のビット数を指定するための2バイトを使用する。一実施形態では、クライアントがRGBフォーマットを使用できない場合に、この値はゼロに等しく設定される。RGB機能ワードは、以下の3つの別々の符号なし値から構成されている。ビット3から0は、各ピクセル内の青の最大ビット数(青輝度)を定義し、ビット7から4は各ピクセル内の緑の最大ビット数(緑輝度)を定義し、ビット11から8は各ピクセル内の赤の最大ビット数(赤輝度)を定義する。ビット14から12は将来の使用のために予約されており、ゼロに設定されている。ビット15は、パックフォーマット又はアンパックフォーマットでRGBピクセルデータを受け入れるためのクライアントの能力を示すために使用される。ビット15がロジック1レベルに設定されているとき、これは、クライアントがパックフォーマット又はアンパックフォーマットのどちらかでRGBピクセルデータを受け入れることができることを示している。ビット15がロジックゼロに設定されると、これは、クライアントがアンパックフォーマットだけでRGBピクセルデータを受け入れることができることを示している。
1バイトの白黒機能フィールドは、白黒フォーマットで表示できる解像度のビット数を指定するための値又は情報を含む。クライアントが白黒フォーマットを使用できない場合には、この値はゼロに等しく設定される。ビット6から4は、将来の使用のために予約され、通常はゼロに設定されている。ビット3から0は、各ピクセルに存在できるグレイスケールの最大ビット数を定義する。これらの4つのビットにより、各ピクセルが1ビットから15ビットからなることを指定できるようになる。値がゼロである場合には、白黒フォーマットはクライアントによってサポートされていない。ビット7は、1に設定時、クライアントがパックフォーマット又はアンパックフォーマットのどちらかで白黒ピクセルデータを受け入れることを示す。ビット7がゼロに設定されている場合、これはクライアントがアンパックフォーマットだけで白黒ピクセルデータを受け入れることができることを示している。
予約2フィールドは、将来の使用のために予約されている1バイト幅のフィールドであり、通常、このフィールドの中のすべてのビットはロジックゼロレベルに設定されている。一実施形態では、パケットにこのフィールドを存在させる1つの目的は、すべての以後の2バイトフィールドを16ビットワードアドレスに位置合わせさせ、4バイトフィールドを32ビットワードアドレスに位置合わせさせることである。
2バイトのY Cb Cr機能フィールドは、Y Cb Crフォーマットで表示できる解像度のビット数を指定する。クライアントがY Cb Crフォーマットを使用できない場合には、この値はゼロである。Y Cb Cr機能ワードは以下の3つの別々の符号なし値から構成されている。ビット3から0は、Cbサンプルを指定する最大ビット数を定義し、ビット7から4はCrサンプルを指定する最大ビット数を定義し、ビット11から8はYサンプルを指定する最大ビット数を定義し、ビット14から12は将来の使用のために予約され、ゼロに設定されている。ビット15は、1に設定時に、クライアントがパックフォーマット又はアンパックフォーマットのどちらかでY Cb Crピクセルデータを受け入れることができることを示す。ビット15がゼロに設定されている場合、これはクライアントがY Cb Crピクセルデータをアンパックフォーマットだけで受け入れることができることを示している。
1バイトBayer機能フィールドは、解像度、ピクセルグループ及びBayerフォーマットで転送できるピクセル順序のビット数を指定する。クライアントがBayerフォーマットを使用できない場合には、この値はゼロに設定されている。Bayer機能フィールドは以下の値から構成されている。ビット3から0は各ピクセルに存在する輝度の最大ビット数を定義し、ビット5から4は、必要とされる可能性のあるピクセルグループパターンを定義し、ビット8から6は必要とされるピクセル順序を定義し、ビット14から9は将来の使用のために予約され、ゼロに設定されている。ビット15は、1に設定時、クライアントがパックフォーマット又はアンパックフォーマットのどちらかでBayerピクセルデータを受け入れることができることを示す。ビット15がゼロに設定されている場合、これは、クライアントがアンパックフォーマットだけでBayerピクセルデータを受け入れることができることを示す。
予約された3フィールド、ここでは2バイトは、将来の使用のために予約される。
それゆえ、このフィールド内のすべてのビットは、典型的にロジックゼロレベルまたはゼロ値に設定されるかまたは等しい。一実施形態において、パケット内にこのフィールドを持たせる1つの目的は、次の2バイトフィールドを16ビットワードアドレスと位置合わせさせ、4バイトフィールドを32ビットワードアドレスと位置合わせさせることである。
ディスプレイ特徴機能インジケータ、ここでは4バイトは、代替ディスプレイ内の特定の特徴がサポートされるかどうかを示すフラッグのセットを含む。1に設定されたビットは、特定のまたはあらかじめ設定された機能がサポートされることを示し、ゼロに設定されたビットは、機能がサポートされないことを示す。
一実施形態において、ディスプレイ特徴機能フィールドは、サポートされる代替ディスプレイ内の特定の特徴を示すフラッグのセットを含む4バイトを使用する。ロジック1レベルに設定されるビットは、機能がサポートされることを示し、一方ロジックゼロレベルに設定されるビットは、機能がサポートされないことを示す。一実施形態において、ビット0のための値は、ビットマップブロック転送パケット(タイプ71パケット)がサポートされるかどうかを示す。ビット1、2、および3のための値は、それぞれビットマップエリア塗りつぶしパケット(タイプ72パケット)、ビットマップパターン塗りつぶしパケット(73型パケット)またはリードフレームバッファパケット(タイプ74パケット)がサポートされるか否かを示す。ビット4のための値は、透明色イネーブルパケットを用いて1つの色を透明にさせる機能を代替ディスプレイが有するか否かを示す。
この実施形態において、ディスプレイ特徴機能フィールドのビット10の値は、代替ディスプレイがディスプレイ電力状態01をサポートするための能力を有するか否かを示す。ディスプレイ電力状態は、上述したディスプレイ電力状態パケットの電力状態フィールドのビット[3:2]を用いて設定される。ディスプレイ電力状態01は、選択されたディスプレイが照射されず、もしあれば最小の電力量を消費する状態であり、フレームバッファの内容は一般的にこの状態の期間中に維持されるように保証されるかまたは合理的に保証される。
ディスプレイ特徴機能フィールドのビット13の値は、VCP特徴パケット、すなわち、VCP特徴要求パケット、VCP特徴応答パケット、VCP特徴設定パケット、有効パラメーター要求パケットおよび有効パラメーター応答パケットをサポートすることにより1つ以上のビデオパラメーターを設定する能力を代替ディスプレイが有しているか否かを示す。ビット14のための値は、代替ディスプレイが、図88Aに示すオフラインディスプレイフレームバッファにピクセルデータを書き込む能力を有するか否かを示す。このビットがロジック1レベルに設定されるなら、ディスプレイ更新ビット(ビデオストリームパケットのピクセルデータ属性フィールドのビット7および6)は、値「01」に設定されてもよい。
ディスプレイ特徴機能フィールドのビット15の値は、図88Bに示される、表示画像をリフレッシュするために現在使用されているディスプレイフレームバッファにのみピクセルデータを書き込む能力を代替ディスプレイが有するときを示す。このビットがロジック1に設定されるなら、ディスプレイ更新ビット(ビデオストリームパケットのピクセルデータ属性フィールドのビット7および6)「00」の値に設定されてもよい。ビット16のための値は、単一ビデオストリームパケットからのピクセルデータを、図88Cに示すすべてのディスプレイフレームバッファに書き込む能力を代替ディスプレイが有するときを示す。このビットがロジック1レベルに設定されるなら、ディスプレイ更新ビット(ビデオストリームパケットのピクセルデータ属性フィールドのビット7および6)は、値「11」に設定されてもよい。
一実施形態において、ディスプレイ機能特徴フィールドのビット21のための値は、これらのパケットがビット0、1、2またはこのフィールドにより指定される代替ディスプレイによりサポートされるなら、ビットマップブロック転送パケット(タイプ71パケット)のラスターオペレーションフィールド、ビットマップエリア塗りつぶしパケット(タイプ72パケット)、およびビットマップパターン塗りつぶしパケット(タイプ73パケット)を使用する能力を代替ディスプレイが有するときを示す。一実施形態において、ビット21がロジックゼロレベルまたは値を有するなら、およびパケットがサポートされるなら、代替ディスプレイは、ラスターオペレーションフィールドを使用する能力を有さず、代替ディスプレイは典型的に、これらのパケットにより指定されるピクセルロケーションにコピーするかまたは書き込む能力を有するのみてある。
一実施形態において、ディスプレイ特徴機能フィールドのビット9乃至5、11、12、20乃至17、および31乃至22は、現在、将来の使用のため、またはシステム設計者により有用な代替指定のために予約され、一般的にゼロ値またはロジックゼロレベルに等しく設定される。
一実施形態において、2バイトのCRCフィールドは、パケット長を含むパケット内のすべてのバイトの16ビットCRCを含む。
41.レジスタアクセスパケット
レジスタアクセスパケットは、ホスト又はクライアントのどちらかに、MDDIリンクの反対端の構成レジスタとステータスレジスタにアクセスする手段、機構又は方法を与える。これらのレジスタは、各ディスプレイ又はデバイスコントローラーに一意となる可能性がある。これらのレジスタは、設定構成、運転モードを必要とするすでに多くのディスプレイに存在し、他の有用且つ必要な設定値を有している。レジスタアクセスパケットは、MDDIホスト又はクライアントがレジスタに書き込むだけではなく、MDDIリンクを使用してレジスタを読み取ることも要求できるようにする。ホスト又はクライアントがレジスタ読み取りを要求すると、反対側はレジスタデータを同じパケットタイプで送信することによるが、これが読み取り/書き込み情報フィールドを使用してある特定のレジスタから読み取られたデータであることを示すことによっても応答しなければならない。レジスタアクセスパケットは、1より大きいレジスタカウントを指定することによって複数のレジスタを読み取る、又は書き込むために使用されてよい。クライアントは、クライアント機能パケットのクライアント特徴機能フィールドのビット22を使用してレジスタアクセスパケットをサポートする能力を示す。クライアントは、カプセル化パケットを用いてレジスタアクセスパケットを送信するであろう。それゆえ、パケット構成または構造内のパケットとして何が現れるかを提示するであろう。
レジスタアクセスパケットの一実施形態のフォーマットは概して図87に示されている。図87で分かるように、レジスタアクセスパケットは、パケット長フィールド、パケットタイプフィールド、bClient IDフィールド、読み取り/書き込みフラグフィールド、レジスタアドレスフィールド、パラメーターCRCフィールド、レジスタデータリストフィールド及びレジスタデータCRCフィールドを有するように構造化されている。146というパケットタイプ値は、レジスタアクセスパケットとしてパケットを識別する。bClient IDフィールドは将来の使用のために予約されており、通常、当面ゼロに設定されている。
2バイトの読み取り/書き込みフラグフィールドは、書き込み又は読み取り、あるいは読み取りに対する応答のどちらかとして特定のパケットを指定し、データ値のカウントを提供する。
ビット15から14は、読み取り/書き込みフラグとして働く。ビット[15:14]が「00」である場合には、このパケットはレジスタアドレスフィールドによってアドレス指定されるレジスタに書き込まれるデータを含む。指定されたレジスタに書き込まれるデータはレジスタデータリストフィールドに含まれている。ビット[15:14]が「10」である場合には、これはレジスタアドレスフィールドによってアドレス指定されている1つ又は複数のレジスタからのデータに対する要求である。ビット[15:14]が[11]である場合には、そのパケットは、読み取り/書き込みフラグのビット15:14が「10」に設定されているレジスタアクセスパケットに応えて要求されたデータを含む。レジスタアドレスフィールドは、第1のレジスタデータリストアイテムに対応するレジスタのアドレスを含み、レジスタデータリストフィールドは、1つ又は複数のアドレスから読み取られたデータを含む。ビット[15:14]が「01」である場合には、これは無効値として処理され、この値は将来のために予約され、現時点で使用されないが、当業者は、将来のアプリケーションのためにそれをどのように採用するかを理解するであろう。
ビット13:0はレジスタデータリストフィールドで送信される32ビットのレジスタデータアイテムの数を指定するために14ビットの符号なし整数を使用する。ビット15:14が「00」に等しい場合には、ビット13:0はレジスタアドレスフィールドにより指定されるレジスタで開始するレジスタに書き込まれるレジスタデータリストフィールドに含まれる32ビットのレジスタデータアイテムの数を指定する。ビット15:14が「10」に等しい場合には、ビット13:0は、受信側装置がそのレジスタが読み取られるのを要求する装置に送信する32ビットのレジスタデータアイテムの数を指定する。
このパケットの中のレジスタデータリストフィールドにはアイテムは含まれず、ゼロ長である。ビット15:14が「11」に等しい場合には、ビット13:0は、レジスタデータリストフィールドに含まれているレジスタから読み取られた、32ビットレジスタデータアイテムの数を指定する。現在、ビット15:14は無効値と見なされている「01」に等しく設定されておらず、無効の値とみなされ、それ以外の場合は将来の指定又は使用のために予約されている。
レジスタアクセスフィールドは、書き込まれる又は読み取られるレジスタアドレスを示すために4バイトを使用する。そのアドレス指定が32ビット未満であるレジスタをアドレス指定する場合、上位ビットはゼロに設定される。
2バイトパラメーターCRCフィールドはパケット長からレジスタアクセスまでのすべてのバイトのCRCを含む。このCRCがチェックできない場合、パケット全体が廃棄される。
レジスタデータリストフィールドは、クライアントレジスタに書き込まれる4バイトのレジスタデータ値、又はクライアントデバイスレジスタから読み取られた値のリストを含む。
2バイトのレジスタデータCRCFフィールドは、レジスタデータリストだけのCRCを含む。このCRCがチェックできない場合には、レジスタデータは依然として使用されてよいが、CRCエラーカウントが増分される。
D.パケットCRC
CRCフィールドは、パケットの最後に、著しく大きなデータフィールドを有することがあるパケットの中のより重大なパラメーターの後にも出現することがあり、したがって転送中のエラーの尤度が上昇する。2つのCRCフィールドを有するパケットの場合、CRCジェネレータは、ただ一方だけが使用されるときに、長いデータフィールドの後のCRC計算がパケットの始まりでパラメーターによって影響を及ぼされないように第1のCRCの後に再初期化される。
パケットが複数のビットエラーを含み良好なCRCを生成するというありそうもないことがある。エラーを備えたパケットに関して良好なCRCを検出する確率は、多くのエラーを含む非常に長いパケット上の7.6×10-6にほぼ等しい。設計によって、MDDIリンクは、非常に低いまたはゼロエラーレートを有するであろう。CRCはリンクの調子を監視するために使用されることを意図しており、パケット再送信すべきかどうかを決定するために特定のパケットに関してエラーを検出することを意図していない。
例示的な実施形態では、CRC計算のために使用される多項式はCRC−16、つまりX16+X15+X2+X0として知られている。本発明を実現するために有効なCRCジェネレータとチェッカ3600のサンプルインプリメンテーションは図36に示されている。図36では、CRCレジスタ3602は、Tx_MDDI_Data_Before_CRC線路上の入力であるパケットの第1のビットの転送の直前に0x0001という値に初期化され、次にパケットのバイトがLSBで最初に開始するレジスタの中にシフトされる。この図のレジスタビット番号が、使用されている多項式の順序に対応し、MDDIによって使用されるビット位置には対応しないことに注意する。単一方向でCRCレジスタをシフトする方がより効率的であり、この結果、MDDIビット位置14に達するまで、CRCビット15をMDDI CRCフィールドのビット位置0に、CRCレジスタビット14をMDDI CRCフィールドビット位置1に表示させる等である。
一例としては、クライアント要求そしてステータスパケットのパケットコンテンツが0x00c、0x0046、0x000、0x400、0x00、0x00、0x000(または、0x0c、0x00、0x046、0x00、0x00、0x00、0x00、0x04、0x00、0x00、0x00、0x00としてのバイトの連続として表現され)、であり、マルチプレクサ3604と3606及びNANDゲート3608の入力を使用して提出されると、Tx_MDDI_Data_With_CRC線路で結果として生じるCRC出力は0xd9aaである(0xaa 0xd9のようなシーケンスとして表される)。
CRCジェネレータとチェッカ3600が1台のCRCチェッカとして構成されるとき、Rx_MDDI_Data線路で受信されるCRCは、マルチプレクサ3604とイクスクルーシブOR(XOR)ゲート3612に入力され、NORゲート3610、ANDゲート3608、およびANDゲート3614を使用してCRCレジスタ内で発見される値とビット単位で比較される。ANDゲート3614によって出力されるようなエラーがある場合には、ゲート3614の出力をレジスタ3602の入力に接続することによりCRCはCRCエラーを含むパケットごとに一度増分される。図36の図に示される例の回路が、既定のCHECK_CRC_NOWウィンドウ内で複数のCRCエラー信号を出力できる(図37Bを参照されたい)ことに注意する。したがって、CRCエラーカウンタは通常、CHECK_CRC_NOWがアクティブである各間隔内に第1のCRCエラーだけをカウントする。CRCジェネレータとして構成される場合、CRCはパケットの最後と一致する時間にCRCレジスタから退出時間を記録される。
入力信号と出力信号及びイネーブル信号のタイミングは、図37Aと図37Bに図で描かれている。CRCの生成とデータのパケットの伝送は、Tx_MDDI_Data_Before_CRC信号とTx_MDDI_Data_With_CRC信号と同様に、Gen_Reset信号、Check_CRC_Now信号、Generate_CRC_Now信号及びSending_MDDI_Data信号の状態(0又は1)と共に図37Aに示されている。データのパケットの受信及びCRC値のチェックは、Rx_MDDI_Data信号とCRCエラー信号と同様に、Gen_Reset信号、Check_CRC_Now信号、Generate_CRC_Now信号、及びSending_MDDI_Data信号の状態と共に図37Bに示されている。
E.パケットCRCのためのエラーコードオーバロード
データパケットとCRCだけがホストとクライアントの間で転送されているときは常に、対処されているエラーコードはない。唯一のエラーは同期の損失である。それ以外の場合、リンクが良好なデータ転送経路又はパイプラインの欠如からタイムアウトするのを待機してから、リンクをリセットし、先に進まなければならない。残念なことに、これは多大な時間を必要とし、いくぶん非効率である。
一実施形態で使用するために、パケットのCRC部分がエラーコード情報を転送するために使用される新しい技法が開発された。これは概して図65に示されている。すなわち、1つ又は複数のエラーコードが、通信処理又はリンクの内に発生する可能性のある特定の所定のエラー又は不具合を示すデータ転送を処理するプロセッサ又は装置によって作成される。エラーに遭遇すると、該適切なエラーコードが作成され、パケットのCRCのためのビットを使用して転送される。つまり、CRC値はCRCフィールドの値を監視するエラーモニタ又はチェッカによって受信端で検出できる所望されるエラーコードと共にオーバロードされるか、上書きされる。エラーコードが何らかの理由からCRC値に一致するケースでは、エラーのコンプリメント(compliment)が混乱を妨げるために転送される。
一実施形態では、ロバストなエラー警告検出システムを提供するために、エラーコードは、エラー検出後に転送又は送信される一連のパケット、通常はすべてを使用して数回転送されてよい。これは、エラーを生じさせた状態がシステムから取り除かれる点まで発生し、その点で規則正しいCRCビットが別の値にオーバロードされることなく転送される。
CRC値をオーバロードするこの技法は、最小量の余分なビット又はフィールドを使用する一方でシステムエラーに対するはるかに迅速な対応を提供する。
図66に示されているように、前述された、あるいは公知の他の回路網の一部を形成できるエラー検出器又は検出手段6602を使用し、通信リンク又はプロセスの中でのエラーの存在又は実在を検出する、CRC上書き機構又は装置6600が示されている。他の回路網の一部として形成できるあるいは、事前に選択されるエラーメッセージを記憶するためにルックアップテーブル等の技法を使用することができるエラーコードジェネレータ又は手段6604は、発生中として検出された特定の所定のエラー又は不具合を示すために1つ又は複数のエラーコードを作成する。デバイス6602と6604が、所望されるように、単一の回路又は装置として、あるいは他の公知のプロセッサと要素のためのステップのプログラミングされたステップの一部として形成できることは容易に理解される。
1つ又は複数の選択されたエラーコードが転送されているCRC値と同じであるかどうかを確かめるためにチェックするためのCRC値コンパレーター又は比較手段6606が示されている。そうである場合には、コードコンプリメントジェネレータ又は生成手段又は装置が、元のCRCパターン又は値と間違われないように、及び検出方式を混乱させたり、複雑化しないようにエラーコードのコンプリメントを提供するために使用される。エラーコードセレクタ又は選択手段要素又は装置6610は、挿入する、又は上書きすることが所望されるエラーコード又は値、あるいはそれらのそれぞれのコンプリメントを適宜に選択する。エラーコードCRCオーバーライター又は上書き機構又は手段6612は、挿入されるデータストリーム、パケット及び所望されるコードを受信し、所望されるエラーコードを受信側装置に転送するために対応する又は適切なCRC値を上書きする装置である。
言及されたように、エラーコードは一連のパケットを使用して数回転送されてよいため、オーバーライター6612は、処理中にコードのコピーを維持するためにメモリ記憶素子を活用する、あるいは必要に応じて、又は所望されるようにその値を記憶する又は保持するために使用できる過去の要素又は他の公知の記憶ロケーションからこれらのコードをリコールしてよい。
図66の汎用処理、上書き機構が実現している、さらに詳細に図67Aと図67Bに示されている。図67Aでは、1つ又は複数のエラーが、通信データ又はプロセスのステップ6702で検出され、この状態を示すためにステップ6704でエラーコードが選択される。同時に、又は適切な時点で、置換されるCRC値はステップ6706でチェックされ、ステップ6708で所望されるエラーに比較される。この比較の結果は、前述されたように、所望されたコード又は他の代表的な値が存在するCRC値と同じであるかどうかに関する決定である。これが当てはまる場合、処理は、コンプリメント、あるいはいくつかのケースでは所望されるように別の代表値が挿入するためのコードとして選択されるステップ6712に進む。どのエラーコード又は値がステップ6710と6714で挿入されなければならないのかがいったん決定されると、その適切なコードが挿入のために選択される。これらのステップは明確にするために別々として描かれているが、通常はステップ6708の決定の出力に基づいた単一の選択である。最後に、ステップ6716では、パケットがプロセスのターゲットとされている状態での転送のために、適切な値がCRCロケーションで上書きされる。
図67Bに示されるように、パケット受信側では、パケットCRC値はステップ6722で監視されている。一般的に、CRC値は、データ転送のエラーが発生したかどうか、及び1つ又は複数のパケットの再送を要求するか否か、あるいは追加の動作を抑制するかどうか等を判断するためにシステム内は1つ又は複数のプロセスに監視されており、そのうちのいくつかは前述されている。情報はこのような監視の一部として値を公知の又は事前に選択されたエラーコード又は代表的な値に比較し、エラーの存在を検出するためにも使用できる。代わりに、別個のエラー検出プロセスとモニタが実現できる。コードが存在すると考えられる場合に、それは抽出され、あるいはそれ以外の場合は追加の処理のためにステップ6724で注記される。これが実際のコードであるのか否か、あるいはコンプリメントであるのか否かに関する決定はステップ6726で下すことができ、その場合、追加ステップ6728が値を所望されるコード値に変換するために使用される。どちらのケースでも結果として生じる抽出コード、コンプリメント、又は他の回復された値は、次にステップ6730で送信されたコードからどのようなエラーが発生したのかを検出するために使用される。
V.リンクハイバネーション
MDDIリンクは素早くハイバネーション状態に入ることができ、そして素早くハイバネーションからウェイクアップする。この応答性は通信システムまたは装置電力が消費を低減するためにMDDIリンクを無理やりハイバネーション周波数にさせることを可能にする。それが使用のために非常に速く再度ウェイクアップすることが可能だからである。一実施の形態において、外部モードクライアントはハイバネーションから早い時間でウェイクアップするので、1Mbpsからなるデータレートでそしてストローブパルスタイミングでそれを実行し、つまり、MDDI_Stb対は500kHzレートでトグルすべきである。一度クライアントの特徴がホストによりまたは通信において発見されると、続いてホストはリンクを一般的には1Mbpsからクライアントが動作可能な最大レートの如何なるレートにおいてもウェイクアップすることができる。内部モードクライアントは、ホストおよびクライアントの双方が動作可能な如何なるレートにおいてもウェイクアップすることができる。このことはまた速い時間の内部モードウェイクアップについて一般的に適用可能である。
一実施の形態では、リンクが休止状態からウェイクアップするとき、ホストとクライアントは、パルスのシーケンスを交換する。これらのパルスは、最大リンク動作速度における信号を受信するのに必要とされるディファレンシャルレシーバとして電流の小部分のみを消費する低速ラインレシーバを使用して検出することができる。ホストまたはクライアントのいずれか一方はリンクをウェイクアップすることができ、この場合ウェイクアッププロトコルはホストとクライアントの双方が同時にウェイクアップしようと試みる場合に起りうるコンテンションを処理するために設計される。
ハイバネーション状態が継続する期間にMDDI_DataおよびMDDI_Stb差動ドライバーは機能を無効にされ、そして全てのディファレンシャルペアにかかるディファレンシャル電圧はゼロボルトである。ハイバネーションからウェイクアップする期間においてパルスのシーケンスを検出するために使用されるディファレンシャルレシーバは意図的な電圧オフセットを有する。一実施の形態では、これらのレシーバにおけるロジック1とロジックゼロレベル間の閾値は約125mVである。このことは非−駆動ディファレンシャルペアがリンクがウェイクアップする期間においてロジックゼロレベルと判断される原因となる。
ハイバネーション状態に入るためにホストはリンクシャットダウンンパケットのCRCの後64MDDI_Stbサイクルを送信する。ホストはCRCの後16〜56MDDI_Stbサイクルの範囲のホストのMDDI_Data0の出力について機能を無効にする(出力無効伝播遅延を含む)。ホストはリンク終了パケットのCRCの後、それがウェイクアップシーケンスを開始する前に、64MDDI_Stbサイクルを送信することを終了する。一実施の形態において、ウェイクアップが開始されたホストは、パルスをMDDI_Stb上で駆動する前に、MDDI_Data0が適正なロジック1レベルに達した後、少なくとも100nsec待たなければならないホストとして規定される。一実施の形態において、クライアントはリンク終了パケットのCRCの後、ホストをウェイクアップすることを試みるためにそれがMDDI_Data0をロジック1レベルに駆動する前、少なくとも60MDDI_Stbサイクル待つ。
ハイバネーション状態から"ウェイクアップする"ためにいくつかの処理または工程が着手される。クライアント、ここではディスプレイ、がホストからのデータまたは通信、サービスを必要とする場合、それはMDDI_Data0ラインを70〜1000μsec前後の間ロジック1状態に駆動し、ここでMDDI_Stbは非活動状態にあり、そして、例え所望により他の期間が使用できるとしても、MDDI_Stbが活動状態になった後、MDDI_Data0が約70MDDI_Stbサイクル(60〜80の範囲にわたる)の間ロジック1レベルに駆動されるように保つ。クライアントは続いてMDDI_Data0ドライバーの機能を、それを高インピーダンス状態に置くことにより、無効にする。
もし休止状態の継続する間においてMDDI_Stbが実行可能な状態にある場合、たとえありそうでなくとも、続いてクライアントはMDDI_Data0のみを約70MDDI_Stbサイクル(60〜80の範囲にわたる)の間、ロジック1状態に駆動するであろう。この動作はホストがデータトラフィックを順方向リンク(208)において起動または再起動し、そしてクライアントにその状態に関し調査する原因となる。
ホストは要求パルスの存在を検出しなければならず、そして少なくとも200nsec前後の間MDDI_Stbをロジック−ゼロレベルにそしてMDDI_Data0をロジック−ハイレベルに駆動するスタートアップシーケンスを開始する。そしてトグルする間、MDDI_Stbは、MDDI_Data0を約150MDDI_Stbサイクル(140〜160の範囲)の間ロジック1レベルに駆動し、そして約50MDDI_Stbサイクル(40〜60の範囲)の間ロジックゼロレベルに駆動することを続ける。クライアントは、ロジック1状態において80MDDI_Stbサイクルよりも多い間に、MDDI_Data0を検出した場合、サービス要求パルスを送信すべきではない。クライアントが60〜80のMDDI_Stbサイクルの間にロジック1レベルにおいてMDDI_Data0を検出した場合、それはこの間隔の間に何処でホストがMDDI_Stbサイクルに関しMDDI_Data0をロジックゼロレベルに駆動するかの探索を開始する。ホストがMDDI_Data0を50MDDI_Stbサイクルの期間においてロジックゼロレベルに駆動した後、ホストはリンク上にパケットの送信を開始する。送信される最初のパケットはサブフレームヘッダーパケットである。クライアントは、MDDI_Data0が50サイクル間隔の40MDDI_Stbサイクルの間ロジックゼロレベルにおける後、サブフレームヘッダーパケットを探すことを開始する。休止処理および開始シーケンスに関する時間間隔の時間および許容度の選択の特徴はさらに以下で議論される(図68A〜Cを参照されたい)。
ホストは最初にMDDI_Stbを動作可能にし、そして同時にそれをロジックゼロレベル駆動することによりウェイクアップを始動することができる。MDDI_Stbはパルスが下に記載のように出力されるまではロジック1レベルに駆動されるべきではない。MDDI_Stbがロジックゼロレベルに達した後、ホストはMDDI_Data0を動作可能にし、同時にそれをロジック1レベルに駆動する。MDDI_Data0はインターバルまでウェイクアップ処理の期間ロジックゼロレベルに駆動されるべきではない。MDDI_Data0は、以下に記載するように50MDDI_Stbパルスの期間に対してロジックゼロレベルに駆動される。ホストは、パルスをMDDI_Stbに駆動する前、MDDI_Data0が適正なロジック1レベルに達した後、少なくとも200nsec待つべきである。このタイミングの関係は最悪の事態の出力エネーブル遅延を考慮する場合に生ずる。このことは、ホストによって駆動されたMDDI_Data0についてロジック1レベルによって起動された後、クライアントがそのMDDI_Stbレシーバを完全に動作可能にするのに充分な時間をもつことを実質的に補償する。
競合状態のない典型的なクライアントサービス要求イベント3800のための処理ステップの例は、イベントが文字A、B、C、D、E、F及びGを使用して図解の便宜上名付けられている図38に描かれている。プロセスは、ホストがクライアントデバイスに、リンクが低電力ハイバネーション状態に遷移することをそれに知らせるために、リンクシャットダウンパケットを送信するときに点Aで開始する。次のステップで、ホストは、MDDI_Data0ドライバーをディスエーブルし、MDDI_Stbドライバーを点Bで示されるようにロジックゼロに設定することによって低電力ハイバネーション状態に入る。MDDI_Data0は高インピーダンスバイアスネットワークによってロジックゼロレベルに駆動される。しばらくしてから、クライアントはMDDI_Data0を、点Cで見られるようなロジック1レベルに駆動することによってサービス要求パルスをホストに送信する。ホストは高インピーダンスバイアスネットワークを使用して依然としてロジックゼロレベルをアサートするが、クライアントの中のドライバーが強制的に回線をロジック1レベルにする。50μsec以内にホストはサービス要求パルスを認識し、点Dで見られるように、そのドライバーをイネーブルすることによってMDDI_Data0上でロジック1レベルをアサートする。
次に、クライアントはサービス要求パルスをアサートしようとするのをやめ、クライアントは点Eで見られるように、そのドライバーを高インピーダンス状態にする。ホストは、点Fで示されるように50μsecの間MDDI_Data0をロジックゼロレベルに駆動し、MDDI_Data0のロジックゼロレベルと一貫した方法でMDDI_Stbを作成し始める。クライアントは、MDDI_Data0が40MDDI_Stbサイクルの間ロジックゼロレベルの後、サブフレームヘッダーパケットを探索することを開始する。MDDI_Data0をロジックゼロレベルにアサートし、MDDI_Stbを50μsecの間駆動した後に、ホストは点Gで示されるようにサブフレームヘッダーパケットを送信することにより順方向リンクでデータの送信を開始する。
類似する例は、リンク再起動シーケンスが開始後にサービス要求がアサートされ、イベントがやはり文字A、B、C、D、E、F及びGを使用して名付けられる図39に示されている。これは、要求パルス又はクライアントからの信号がサブフレームヘッダーパケットを破壊しそうになる最悪のケースのシナリオを表している。プロセスは、ホストがクライアントデバイスに、リンクが低電力ハイバネーション状態に遷移することをそれに知らせるために再びリンクシャットダウンパケットを送信するときに、点Aで開始する。次のステップでは、ホストは、点Bで示されるように、MDDI_Data0ドライバーをディスエーブルし、MDDI_Stbドライバーをロジックゼロレベルに設定することによって低電力ハイバネーション状態に入る。前記のように、MDDI_Data0は、高インピーダンスバイアスネットワークによってロジックゼロレベルに駆動される。ある期間の後、ホストは、点Cで見られるように150μsecの間ロジック1レベルにMDDI_Data0を駆動することによってリンク再起動シーケンスを開始する。リンク再起動シーケンス開始後50μsecが経過する前に、ディスプレイは点Dで見られるように70μsecの持続期間MDDI_Data0もアサートする。これは、ディスプレイがホストからのサービスを要求する必要があり、ホストがすでにリンク再起動シーケンスを開始したことを認識していないために発生する。次にクライアントはサービス要求パルスをアサートしようとすることをやめ、点Eで見られるように、クライアントはそのドライバーを高インピーダンス状態にする。ホストはロジック1レベルにMDDI_Data0を駆動し続ける。ホストは点Fに示されているように、50μsecの間MDDI_Data0をロジックゼロレベルに駆動し、MDDI_Data0でのロジックゼロレベルと一貫するようにMDDI_Stbも作成し始める。MDDI_Data0をロジックゼロレベルにアサートし、MDDI_Stbを50μsec駆動した後、ホストはサブフレームヘッダーパケットを送信することにより順方向リンクでデータの送信を開始する。
前記説明から、過去の解決策が、スリープ解除シーケンスの一部としてホストに2つの状態を経験させることを必要としたことが分かる。第1の状態の場合、ホストは150μsの間MDDI_Data0信号を高に駆動し、次に、MDDI_Stb回線をアクティブ化する一方で50μsの間MDDI_Data0信号を低に駆動し、次にMDDIパケットの送信を開始する。このプロセスは、MDDI装置と方法を使用して達成可能なデータレートという点で最先端に進展するためにうまく働く。しかしながら、前述されたように、状態に対する応答時間の短縮又は次のステップ又はプロセスをより迅速に選択できるようにするという点でのさらなる速度は処理又は要素を簡略化する能力であり、つねに要求されている。
出願者は、ホストが信号トグルのためにクロックサイクルベースのタイミングを使用するウェイクアップ処理及びタイミングに対する新しい発明の手法を発見した。この構成では、ホストは、ホストがウェイクアップシーケンスの始まりにMDDI_Data0信号を高に駆動してから0から10μsec、MDDI_Stbのトグルを開始し、信号が低に駆動されるまで待機しない。ウェイクアップシーケンスの間、ホストは、MDDI_Data0信号が常にロジックゼロレベルであるかのようにMDDI_Stbをトグルする。
これは事実上クライアント側から時間の概念を排除し、ホストは、最初の2つの状態のための過去の150μsの期間と50μsの期間から、これらの期間の間の150クロックサイクルと50クロックサイクルに変化する。
ホストはそのデータラインを高に駆動することに責任を持つようになり、10−クロックサイクルのうちに、データラインがゼロであるかのようにストローブ信号の送信を開始する。ホストが150クロックサイクルの間データラインを高に駆動した後、ホストは、ストローブ信号の送信を続けながら50クロックサイクルの間データラインを低に駆動する。ホストは、これらのプロセスの両方ともを完了後、最初のサブフレームヘッダーパケットの送信を開始できる。
クライアント側では、クライアントインプリメンテーションは、ここでデータラインが最初は高く、次に低くなるクロックサイクル数を計算するために生成されたクロックを使用できる。データライン駆動高状態で発生する必要のあるクロックサイクル数は150であり、データライン駆動低状態で発生する必要のあるクロックサイクル数は50である。つまり、適切なウェイクアップシーケンスのために、クライアントは、低であるデータの少なくとも50の連続クロックサイクルが後に続く、高であるデータラインの少なくとも150の連続クロックサイクルをカウントできなければならない。いったんこれらの2つの条件が満たされると、クライアントは第1のサブフレームの一意のワードの検索を開始できる。このパターンの中断は、カウンタを、クライアントが高であるデータラインの最初の150連続クロックサイクルを再び探す初期状態に戻すための基礎として使用される。
ハイバネーションからのホストベースのウェイクアップのための本発明のクライアントインプリメンテーションは、クロックレートが前述されたように1Mbpsで強制的に開始されないことを除き、初期の起動ケースに非常に類似している。代わりに、クロックレートは、通信リンクがハイバネーションに入ったときにどのような過去の速度でアクティブであっても再開するために設定できる。ホストが前述されたようにストローブ信号の伝送を開始すると、クライアントは、低であるデータラインの少なくとも50連続クロックサイクルが後に続く、高であるデータラインの少なくとも150連続クロックサイクルを再びカウントできなければならない。いったんこれらの2つの条件が満たされると、クライアントは一意のワードの検索を開始できる。
ハイバネーションからのクライアントベースのウェイクアップのための本発明のクライアントインプリメンテーションは、それがクライアントにデータラインを駆動させることによって起動するという点を除きホストベースのウェイクアップに類似している。クライアントはホストデバイスをウェイクアップするために、クロックを使用せずにデータラインを非同期で駆動できる。いったんホストが、データラインがクライアントによって高に駆動されていると認識すると、それはそのウェイクアップシーケンスを開始できる。クライアントは、ウェイクアッププロセスを介してまたはウェイクアッププロセスの期間にホストにより発生されるクロック数をカウントすることができる。いったんクライアントが高であるデータの70連続クロックサイクルをカウントすると、それはデータラインを高に駆動するのを停止できる。この点で、ホストはすでにデータラインも高にしているはずである。クライアントは、次に高であるデータラインの150クロックサイクルに達するために、高であるデータラインの別の80連続クロックサイクルをカウントすることができ、次に低であるデータラインの50クロックサイクルを探すことができる。いったんこれらの3つの条件が満たされると、クライアントは一意のワードを探し始めることができる。
スリープ解除処理のこの新しいインプリメンテーションの利点とは、それが時間測定装置に対する必要性を排除するという点である。これが発振器であるのか、あるいはコンデンサ式放電回路であるのか、あるいは他のこのような公知の装置であるのかに関係なく、クライアントは起動状態を確認するためにもはやこのような外部装置を必要としない。これにより、コントローラー、カウンタ等をクライアントデバイスボードで実現するときに資金と回路面積を節約する。これはクライアントにとって利点ではない可能性があるが、ホストにとってはこの技法はコア回路網のために使用される超高密度ロジック回路(VHDL)という点でホストを潜在的に簡略化するはずである。コア要素がホストベースのウェイクアップを待機するために外部回路網が実行している必要はないため、ウェイクアップ通知及び測定ソースとしてデータラインとストローブラインを使用することの電力消費も低くなる。使用されたサイクル又はクロック期間の数は例示的であり、他の期間は当業者に明らかとなるように使用できる。
ウェイクアップ処理のこの新しいインプリメンテーションの利点とは、それが時間測定装置に対する必要性を排除するという点である。これが発振器であるのか、あるいはコンデンサ式放電回路であるのか、あるいは他のこのような公知の装置であるのかに関係なく、クライアントは起動状態を確認するためにもはやこのような外部装置を必要としない。これにより、コントローラー、カウンタ等をクライアントデバイスボードで実現するときに資金と回路面積を節約する。これはクライアントにとって利点ではない可能性があるが、ホストにとってはこの技法はコア回路網のために使用されるVHDLという点でホストを潜在的に簡略化するはずである。コア要素がホストベースのウェイクアップを待機するために外部回路網が実行している必要はないため、ウェイクアップ通知及び測定ソースとしてデータラインとストローブラインを使用することの電力消費も低くなる。
この新しい技法の動作を明確にし、説明するために、MDDI_Data0、MDDI_Stb及びクロックサイクルに関する多様な動作のタイミングが図68A、図68B及び図68Cに示されている。
競合のない典型的なホスト起動型スリープ解除の処理ステップの例は、文字A、B、C、D、E、F及びGを使用して、イベントが図中再び便宜上名付けられている図68Aに示されている。プロセスは、ホストがクライアントデバイスに、それにリンクが低電力ハイバネーション状態に遷移することを知らせるためにリンクシャットダウンパケットを送信するときに点Aで開始する。次のステップ、点Bでは、ホストは、MDDI_Stbがトグルするのを停止する前にクライアントによる処理を完了できるようにするために、約64サイクル(あるいはシステム設計のために所望されるとおりに)MDDI_Stbをトグルし、クライアントデバイス内の回復したクロックを停止する。ホストは、当初MDDI_Data0をロジックゼロレベルに設定してから、MDDI_Data0出力を、CRC後に16サイクルから48サイクル(通常は出力ディスエーブル伝播遅延を含む)の範囲でMDDI_Data0出力をディスエーブルする。CRCから48サイクル後、及び次の段階(C)の前にクライアント内のMDDI_Data0とMDDI_Stbのための高レート受信機を低電力状態にすることは望ましい場合がある。クライアントはMDDI_Data0およびMDDI_Stbについてその高レートレシーバを、リンクシャットダウンパケットのCRCの後、MDDI_Stbサイクルの48番目のライジングエッジの後は、何時でも休止状態に配置する。クライアントは、リンクシャットダウンパケットのCRCの後、MDDI_Stbサイクルの64番目のライジングエッジの前は、MDDI_Data0およびMDDI_Stbについての高レートレシーバを休止状態に配置することを推奨される。
ホストはMDDI_Data0ドライバーとMDDI_Stbドライバーをディスエーブルし、ホストコントローラーを低電力ハイバネーション状態にすることによって点又はステップCで低電力ハイバネーション状態に入る。所望されるように(高インピーダンスバイアスネットワークを使用して)MDDI_Stbドライバーをロジックゼロレベルに設定する、あるいはハイバネーションの間トグルを続けることもできる。クライアントは低電力レベルハイバネーション状態にもある。
ある期間の後で、ホストはMDDI_Data0ドライバー出力とMDDI_Stbドライバー出力をイネーブルすることによって点Dでリンク再起動シーケンスを開始する。ホストは、ドライバーがそのそれぞれの出力を完全にイネーブルするために要する時間の限り、MDDI_Data0をロジック1レベルに、MDDI_Stbをロジックゼロレベルに駆動する。ホストは、通常、MMDI=Stbdeパルスを駆動する前に、これらの出力が所望されるロジックレベルに達してから約200ナノ秒待機する。これにより、受信を準備するためのクライアント時間が可能になる。
ホストドライブがイネーブルされ、MDDI_Data0がロジック1レベルに駆動されている状態で、ホストは、点Eで見られるように150MDDI_Stbサイクルの持続期間中MDDI_Stbのトグルを開始する。ホストは、点Fで示されているように50サイクル、MDDI_Data0をロジックゼロレベルに駆動し、クライアントは、MDDI_Data0が40MDDI_Stbサイクルの間ロジックゼロレベルにあった後にサブフレームヘッダーパケットを探し始める。ホストは、点Gで示されているようにサブフレームヘッダーパケットを送信することによって順方向リンクでデータ送信を開始する。
競合のない典型的なホスト起動型ウェイクアップ処理ステップの例は、文字A、B、C、D、E、F、G、H及びIを使用して、イベントが図中再び便宜上ラベルが付けられている図68Bに示されている。前記のように、プロセスは、ホストがクライアントに、それにリンクが低電力状態に遷移することを知らせるためにリンクシャットダウンパケットを送信するときに点Aで開始する。
点Bでは、ホストは、MDDI_Stbがトグルするのを停止する前にクライアントによる処理を完了できるようにするために約64サイクル(又はシステム設計のために所望されるとおりに)MDDI_Stbをトグルし、クライアントデバイス内の回復されたクロックを停止する。ホストは当初MDDI_Data0もロジックゼロレベルに設定し、次にCRC後に16から48サイクル(通常は出力ディスエーブル伝搬遅延を含む)の範囲でMDDI_Data0出力をディスエーブルする。CRC後の48サイクルの後で、次の段階(C)の前に、クライアント内のMDDI_Data0とMDDI_Stbのための高レート受信機を低電力状態にすることが望ましい場合がある。
ホストはMDDI_Data0ドライバーとMDDI_Stbドライバーをディスエーブルし、ホストコントローラーを低電力ハイバネーション状態にすることによって点つまりステップCで低電力ハイバネーション状態に入る。所望されるように、(高インピーダンスバイアスネットワークを使用して)MDDI_Stbドライバーをロジックゼロレベルに設定すること、あるいはハイバネーションの間トグルし続けることもできる。クライアントも低電力レベルハイバネーション状態にある。
ある期間の後、クライアントは、MDDI_Stb受信機をイネーブルし、MDDI_Stbの受信されたバージョンが、ホストがそのMDDI_Stbドライバーをイネーブルする前にクライアントのロジックゼロレベルにあると保証するためにMDDI_Stb受信機でオフセットをイネーブルすることによっても点Dでリンク再起動シーケンスを開始する。所望されるように有効な差動信号の受信を保証し、誤りのある信号を抑止するために、クライアントが、受信機をイネーブルするのよりわずかに先にオフセットをイネーブルすることが望ましい場合がある。クライアントは、MDDI_Data0ラインをロジック1レベルに駆動する一方でMDDI_Data0ドライバーをイネーブルする。オフセットおよび標準MDDI_Stb差動受信機をイネーブルするための時間が200nsecより小さい場合、MDDI_Data0およびMDDI_Stbについて同時にイネーブルされることが認められる。
約1msec以内、点E内に、ホストはクライアントからのサービス要求パルスを認識し、ホストはMDDI_Data0ドライバー出力とMDDI_Stbドライバー出力をイネーブルすることによってリンク再起動シーケンスを開始する。ホストは、ドライバーがそのそれぞれの出力をイネーブルするのにかかる限り、MDDI_Data0をロジック1レベルに、MDDI_Stbをロジックゼロレベルに駆動する。ホストは通常、MDDI_Stbでパルスを駆動する前に、これらの出力が所望されるロジックレベルに達してから約200ナノ秒待機する。これによりクライアントに受信に備える時間が与えられる。
ホストドライバーがイネーブルされ、MDDI_Data0がロジック1レベルに駆動されている状態で、ホストは、点Fで見られるように150MDDI_Stbサイクルの持続期間、MDDI_Stbでパルスを出力し始める。クライアントは、MDDI_Stbで最初のパルスを認識すると、そのMDDI_Stb受信機でオフセットをディスエーブルする。クライアントは70MDDI_Stbサイクルの間ロジック1レベルにMDDI_Data0を駆動し続け、点GでMDDI_Dat0ドライバーをディスエーブルする。ホストは、80の追加のMDDI_Stbパルスの期間、MDDI_Data0をロジック−1レベルに駆動することを続け、そして点HにおいMDDI_Data0をロジック−ゼロレベルに駆動する。
点GとHで見られるように、ホストは50サイクルの間MDDI_Data0をロジックゼロレベルに駆動し、クライアントは、MDDI_Data0が40MDDI_Stbサイクルの間ロジックゼロレベルにあった後サブフレームヘッダーパケットを探し始める。50サイクルの期間の間のMDDI_Stbの駆動の後、ホストは、点Iで見られるようにサブフレームヘッダーパケットを送信することにより順方向リンクでデータ送信を開始する。
クライアントから競合がある、つまりクライアントもリンクをスリープ解除することを希望する典型的なホスト起動型スリーブ解除のための処理ステップの例は、図68Cに示されている。イベントは、文字A、B、C、D、E、F、G、H及びIを使用して図中、便宜上再び名付けられる。前記のように、プロセスは、ホストがクライアントに、リンクが低電力状態に遷移することを知らせるためにリンクシャットダウンパケットを送信するときに点Aで開始し、クライアントによる処理を完了できるようにするために、MDDI_Stbが約64サイクルの間(又はシステム設計のために所望されるとおりに)トグルされる点Bに進み、それから、MDDI_Data0ドライバーとMDDI_Stbドライバーをディスエーブルし、ホストコントローラーを低電力ハイバネーション状態にすることによってホストが低電力ハイバネーション状態に入る点Cに進む。しばらくしてから、ホストは、MDDI_Data0ドライバー出力とMDDI_Stbドライバー出力をイネーブルすることによって点Dでリンク再起動シーケンスを開始し、点Eで見られるように150MDDI_Stbサイクルの期間、MDDI_Stbのトグルを開始する。
点Eの後最大70MDDI_Stbサイクルで、ここでは点Fで、クライアントはまだ、ホストがロジック1レベルにMDDI_Data0を駆動していることを認識していないため、クライアントもMDDI_Data0をロジック1レベルに駆動する。これは、クライアントがサービスしたいという望みを有するが、それが通信しようとしているホストがすでにリンク再起動シーケンスを開始していることを認識していないためにここで発生する。点Gでは、クライアントはMDDI_Data0を駆動するのをやめ、その出力をディスエーブルすることによってそのドライバーを高インピーダンス状態にする。ホストは、追加の80サイクルMDDI_Data0をロジック1レベルに駆動し続ける。
ホストは、点Hで示されているように50サイクルの間、MDDI_Data0をロジックゼロレベルに駆動し、クライアントは、MDI_Data0が40 MDD_Stbサイクルの間ロジックゼロレベルにあった後にサブフレームヘッダーパケットを探し始める。ホストは点Iに示されているようにサブフレームヘッダーパケットを送信することによって順方向リンクでデータの転送を開始する。
VI.インターフェース電気仕様
例の実施形態では、非ゼロ復帰(NRZ)フォーマットは、クロック情報をデータ信号とストローブ信号の中に埋め込むことを可能にするデータ−ストローブ信号又はDATA−STBフォーマットを使用して符号化される。クロックは、複雑な移送ロックループ回路網を使用しなくても回復できる。前述されたように他の導線、プリント配線、又は転送要素を使用することもできるが、データは双方向差動リンク上で伝搬され、通常ワイヤラインケーブルを使用して実現される。ストローブ(STB)信号は、ホストによってのみ駆動される単向性のリンク上で伝搬される。ストローブ信号は、データライン又は信号上で同じままとなる連続状態0又は1があるときは常に値(0又は1)をトグルする。
ビット「1110001011」等のデータシーケンスをDATA−STB符号化を使用してどのようにして送信できるのかの例は図40にグラフ形状で示されている。図40では、DATA(データ)信号4002は、信号タイミングチャートの一番上の行に示され、STB(ストローブ)信号4004は2番目の行に示され、毎回適宜に位置合わせされている(共通開始点)。時間が過ぎるにつれて、データライン4002(信号)で状態の変化が発生し、次にSTB(ストローブ)ライン4004(信号)が過去の状態を維持し、このようにしてデータ信号の第1の「1」状態は、その開始値であるSTB(ストローブ)信号の最初の「0」状態と相関する。しかしながら、もしデータ信号の状態、レベルが変化しないときには、データが別の「1」値を提供する図40のケースと同様に、STB信号は本例で反対の状態つまり「1」にトグルする。つまり、DATAとSTBの間にはビットサイクルあたりただ1つの遷移しかない。したがって、DATA(データ)信号が「1」でとどまるのでSTB信号は再び、今回は「0」に遷移し、DATA(データ)信号がレベルを「0」に変えると、このレベル又は値を保持する。データ(DATA)信号が「1」にとどまるときには、DATA(データ)信号が変化する、あるいはレベル又は値を保持するので、STB(ストローブ)信号は本例では反対の状態、つまり「1」にトグルする等である。
これらの信号を受信すると、排他的OR(XOR)演算が、所望されるデータ信号とストローブ信号との相対比較のためにタイミングチャートの下部に示されている、クロック信号4006を作成するためにDATA(データ)信号とSTB(ストローブ)信号で実行される。ホストにある入力データからDATA(データ)出力又は信号とSTB(ストローブ)出力又は信号を生成し、次にクライアントにあるデータからDATA(データ)信号とSTB(ストローブ)信号を回復する又は捕捉しなおすための有効な回路網の例は図41に示されている。
図41では、受信部分4120は信号を受信し、データを回復するために使用されるが、伝送部分4100は、中間信号経路4102上でオリジナルのDATA(データ)信号とSTB(ストローブ)信号を生成し、送信するために使用される。図41に示されているように、ホストからクライアントにデータを転送するために、DATA(データ)信号は回路をトリガするためのクロック信号と共に、2つのD型フリップフロップ回路要素4104と4106に入力される。該2つのフリップフロップ回路出力(Q)は、次に、2台の差動ラインドライバー4108と4110(電圧モード)を使用してそれぞれ信号MDDI_Data0、MDDI_Data0−、及びMDDI_Stb+、MDDI_Stb−の差動組に分割される。3入力排他的NOR(XNOR)ゲート、回路、又はロジック素子4112は両方のフリップフロップのDATA(データ)と出力を受信するために接続され、同様にMDDI_Stb+信号、MDDI_Stb−信号を生成する第2のフリップフロップにデータ入力を提供する出力を生成する。便宜上、XNORゲートはそれが事実上ストローブを生成するフリップフロップのQ出力を反転していることを示すために反転バブル(inversion bubble)を設置させる。
図41の受信部分4120では、MDDI_Data0+信号、MDDI_Data0−信号及びMDDI_Stb+信号、MDDI_Stb−信号が、差動信号から単一の出力を生成する2台の差動ラインレシーバ4122と4124のそれぞれにより受信される。増幅器の出力は次に2入力排他的OR(XOR)ゲート、回路、又はクロック信号を発生させるロジック素子4126の入力のそれぞれに入力される。このクロック信号は、遅延素子4132を通してDATA(データ)信号の遅延バージョンを受信する2つのD型フリップフロップ回路4128と4130のそれぞれをトリガするために使用され、その内の一方(4128)がデータ「0」値を生じさせ、他方(4130)がデータ「1」値を生じさせる。クロックはXORロジックから独立した出力も有する。クロック情報はDATA(データ)回線とSTB(ストローブ)回線の間で分配されるため、どちらの信号も、クロックレートの半分より高レートな状態の間で遷移しない。クロックはDATA(データ)信号とSTB(ストローブ)信号の排他的OR処理を使用して再生されるため、システムは、事実上、クロック信号が単一の専用データラインで直接的に送信されるときの状況に比べて、入力データとクロック間の二倍の量のスキューに耐えている。
MDDIデータ対、つまりMDDI_Stb+信号とMDDI_Stb−信号は雑音の負の影響からの免疫性を最大限にするために差動モードで運用される。各差動の組は信号を伝送するために使用されているケーブルまたは導体の特性インピーダンスを用いて並列終端される。一般に全ての並列終端は、クライアント装置に存在する。これは順方向トラフィック(データがホストからクライアントに送信される)のための差動レシーバに近いが、しかしこれはケーブルまたは他の導電体または逆方向トラフィック(データがクライアントからホストに送信される)に関する伝送要素の駆動端部にある。逆方向トラフィックの場合、信号はクライアントによって駆動され、ホストにおける高インピーダンスレシーバによって反射され、そしてクライアントにおいて終端する。どこかに記載したように、リバースデータまたは逆方向リンクを介したデータは、ケーブル内の往復遅延の逆数より大きなデータレートで転送または送信することができる。MDDI Stb+およびMDDI Stb−導体または信号はホストによってのみ駆動される。
本発明のMDDインターフェースの一部として信号を転送するためのドライバー、受信機及び終端を達成するために有効な要素の例示的な構成は図42に示されている。この例示的なインターフェースは、1Vパワースイングより小さくそして低パワードレインを有する低電圧センシング、ここでは200mV、を使用する。各信号対のドライバーは差動電流出力を有する。MDDIパケットを受信する間、MDDI_DataおよびMDDI_Stb対は0Vの電圧閾値を有する普通の差動レシーバを使用する。ハイバネーション状態においてドライバーの出力は使用不能にされ、並列終端抵抗器は各信号対の差動電圧を0Vに引き付ける。ハイバネーションの間、MDDI_Data0対上の特定のレシーバは正の125mVのオフセット入力閾値を有し、これはハイバネーションラインレシーバに非駆動信号対をロジックゼロレベルとして解釈させる。
差動対の差動電圧は、正(+)信号上の電圧マイナス負(−)信号上の電圧の差分として定義される。その差動対信号の名前は、「+」または「−」で終了する。これは、それぞれ対の正信号または負信号を示す。差動対のドライバーの出力電流は、正(+)出力から流れる電流として定義される。差動ドライバーの負(−)出力を通過する電流は常に大きさが等しいが、同じ差動ドライバーの正(+)の出力を通過する電流と比べて方向が反対である。
時々ホスト又はクライアントは、データの流れの方向が変化(ホストからクライアントへ、またはクライアントからホストへ)する場合、対について適切なロジックレベルを保証するためにロジック1レベルまたはロジックゼロレベルに差動対を同時に駆動する。出力電圧範囲および出力基準は同じロジックレベルに同時に駆動された出力によって満たされるであろう。いくつかのシステムにおいて、ハイバネーション期間中およびハイバネーション状態からウェイクアップしたときに、小電流を終端された作動対に駆動して、ある時期において小さなオフセット電圧を作る必要があるかもしれない。これらの状態において、動作可能にされたオフセット−電流バイアス回路は以下のリーケージを駆動しなければならない。
ESD-and-RX−内部ESDダイオードおよび差動レシーバ入力
ESD-and-RX≦1μA ITx-Hi-Z−高インピーダンス状態での差動ドライバー出力
Tx-Hi-Z≦1μA Iexternal-ESD−外部ESD保護ダイオードを通るリーケージ Iexternal-ESD≦3μA 。
これらのリーケージ電流の各々は図47に示されている。プルアップおよびプルダウン回路は、上に記載された全てが同時に起こる場合の、最悪の状態のリーケージ状況において、最小差動電圧に到達しなければならない。外部ESD保護ダイオードの無い内部モードにおいて合計のリーケージは≦4μAであり、そして外部ESD保護ダイオードを有する外部モードにおいて≦10μAである。
差動ラインドライバーの電気パラメーターおよび特性は、表IXa−IXdに一例示実施形態として記載される。機能的に、ドライバーは入力で直接的にロジックレベルを正の出力に、入力の逆数を負の出力に転送する。入力から出力への遅延は差動的に駆動される差動線路に十分に整合されている。大部分のインプリメンテーションでは、出力での電圧振幅は、電力消費と電磁放射線を最小限に抑えるために入力での振幅より少ない。一実施形態において、約0.5Vの最小電圧スイングがある。しかしながら、当業者に知られているように他の値を使用することができる。発明者達は、設計制約に応じて、いくつかの実施形態においてより小さな値を意図する。
差動線路受信機は高レートの電圧コンパレーターと同じ特性を持っている。図41では、バブルのない入力は正の入力であり、バブルのある入力は負の入力である。出力は、(Vinput+)−(Vinput−)がゼロより大きい場合には、ロジック1である。これを説明する別の方法は、非常に大きな(実質的には無限の)利得を有する差動増幅器であり、出力はロジック0電圧レベルと1電圧レベルでクリッピングされる。
様々な組の間の遅延スキューは、差動伝送システムを潜在的な最高の速度で動作するために最小限に抑えられなければならない。
Figure 2014053920
注1:最大立ち上がり時間および立下り時間は、1つの差動対上の1ビットを送信するための間隔の30%または100nsecのどちらか小さいほうである。
Figure 2014053920
注1:最大立ち上がり時間および立下り時間は、1つの差動対上の1ビットを送信するための間隔の30%または100nsecのどちらか小さいほうである。
Figure 2014053920
Figure 2014053920
図42では、通信リンク4206上でパケットを転送しているホストコントローラー4202とクライアント又はディスプレイコントローラー4204が示されている。クライアントが3つのドライバー4230、4232、および4234を採用する一方で、ホストコントローラーは、伝送されるクライアントData信号を受信するのと同様に、ホストDATAおよび伝送されるSTB信号を受信するために3つのドライバー4210、4212、および4214のシリーズを採用する。ホストDATA(4212)の通過に責任を負うドライバーは、ホストからクライアントへの伝送が望まれる場合のみ通信リンクの起動を一般的に可能にする、動作可能な信号入力を採用する。データ伝送の一部としてSTB信号が形成されるので、このドライバー(4212)に関し追加の動作可能な信号は採用されない。クライアントDATAおよびSTBレシーバ(4132、4230)夫々の入力は、それぞれ横切るように配置される終結インピーダンスまたは抵抗4218および4220を有する。クライアントからホストへ伝送されるデータ信号を準備するためにクライアント制御器のドライバー4234が使用され、ここで入力側のドライバー4214がデータを処理する。
特別のレシーバ(ドライバー)4216および4236がDATAラインに結合または接続され、そして他で議論される中止制御の一部として、前に議論した125mV電圧オフセットを生成または使用する。オフセットはロジックゼロレベルとして休止ラインレシーバが非−駆動信号を解釈する原因となる。
前記ドライバー及びインピーダンスは離散構成要素として、あるいは回路モジュール又はさらに費用効果の高いエンコーダ又はデコーダ解決策として働く特定用途向け集積回路(ASIC)の一部として形成できる。
電力が、HOST_PwrとHOST_Gndと呼ばれる信号を1組の導線上で使用して、クライアントデバイス、つまりディスプレイに、ホストデバイスから転送されるのは容易に理解できる。信号のHOST_Gnd部分は、基準接地、及び電源戻り経路又は表示装置用の信号として働く。HOST_Pwr信号はホストデバイスによって駆動されるクライアント装置電源として働く。例示的な構成では、低電力応用例の場合、表示装置は最高500mAまで引き出すことができる。HOST_Pwr信号は、リチウムイオン型電池又はホストデバイス内に常駐する電池パック等を含むが、これらに限定されない携帯電源から提供でき、HOST_Gndに関して3.2ボルトから4.3ボルトの範囲となってよい。
VII.タイミング特性
A.概要
ハイバネーション状態に入るために(サービスは要求されず、所望されず、または必要とされない)、およびホストの開始によってまたはクライアントの開始によってホストからクライアントへのサービスを保証するために採用されるステップおよび信号レベルは、それぞれ図43A、図43Bおよび図43Cに示されている。図43A、43B、43Cでは、描かれている信号の第1の部分は、ホストから転送されているリンクシャットダウンパケットであり、データラインは次に高インピーダンスバイアス回路を使用してロジックゼロ状態に駆動される。データはクライアント、またはそのドライバーがディスエーブルされているホストによって送信されていない。MDDI_Stbはリンクシャットダウンパケットの間アクティブであるので、MDDI_Stb信号線路のための一連のストローブパルスは下部に見ることができる。いったんこのパケットが終了し、ホストがバイアス回路とロジック回路をゼロに駆動するのでロジックレベルがゼロに変化する。これは、ホストからの最後の信号転送又はサービスの終端を表し、過去におけるいかなる時点でも発生できたであろうし、サービスの過去の休止及びサービス開始前の信号の状態を示すために含まれている。所望であれば、そのような信号は、このホスト装置により引き受けられていた「周知」の従来の通信なしに通信リンクを適切な状態にリセットするために送信することができる。
図43Aに示すように、および上述したリンクシャットダウンパケットに対して述べたように、低電力ハイバネーション状態において、MDDI_Data0ドライバーは、リンクシャットダウンパケット内のオールゼロフィールドの最後のビットの後に16番目乃至48番目のMDDI_Stbサイクルまたはパルスの後に開始する高インピーダンス状態にディスエーブルされる。タイプ2、タイプ3、またはタイプ4リンクの場合、MDDIData1乃至MDDIDataPwr7信号も、MDDI_Data0ドライバーがディスエーブルされるのと同じ時間に高インピーダンスに設定される。オールゼロフィールドの定義に記載されるように、MDDI_Stbは、リンクシャットダウンパケットのCRCフィールドのMSBに続く(またはシステム設計のために要望通りに)64サイクルの間トグルし、クライアントにより処理を完了可能にし、クライアントコントローラーにおける規則正しいシャットダウンを容易にする。1つのサイクルは低から高への遷移の後に高から低への遷移が続くか、または高から低への遷移の後に低から高への遷移が続く。オールゼロフィールドが送信された後、ホスト内のMDDI_StbドライバーおよびMDDI_Data0ドライバーはディスエーブルされ、ホストは低電力ハイバネーション状態に入る。ある期間の後で、MDDI_Data0ラインおよびMDDI_Stbラインまたはドライバー出力をイネーブルにすることにより、ホストは、図43bおよび43cに示されるリンクリスタートシーケンスを開始し、ホストまたはクライアントが開始したウェイクアップ要求の一部としてMDDI_Stbをトグルし始める。
図43Bに示すように、MDDI_Data0およびMDDI_Stbのためのドライバーからの信号出力がディスエーブルの状態である時間が経過した後、指定された期間tstb-dagta-enblMDDI_Stbドライバーをイネーブルすることによりホストはサービスを開始するまたはハイバネーションからウェイクアップする。その期間、ラインが完全にイネーブルにされ、次にMDDI_Data0ドライバーをイネーブルにするまで、ラインはロジックゼロレベルに駆動される。指定された期間tclient-startupに対して生じるハイレベルまたはロジック1レベルにMDDI_Data0が到達した後にホストは、MDDI_Stbをロジックゼロレベルにホールドする。tclient-startup期間の終わりでホストは、MDDI_Stb信号またはラインをトグルする。ホストは、MDDI_Data0ラインを高く、すなわちロジック1レベルに駆動し、クライアントは、指定された期間trestart-highMDDI_Data0を駆動せず、指定された期間trestart-lowMDDI_Data0ラインを低く、すなわち、ロジックゼロレベルに駆動する。この後、サブフレームヘッダーパケットを用いて第1のフォワードトラヒックが開始し、次にフォワードトラヒックパケットが転送される。trestart-lowの期間および次のサブフレームヘッダーパケットの期間、MDDI_Stb信号はアクティブである。
図43cに示すように、MDDI_Data0およびMDDI_Stbのためのドライバーからの信号出力がディスエーブルされた状態である時間が経過した後に、ホストがMDDI_Stbドライバーをイネーブルにする前に、MDDI_Stb受信機内のオフセットをイネーブルにするかまたは上述したように、指定された期間tstb-dagta-enbl出力信号をイネーブルにすることによりクライアントはサービス要求を開始するかまたはハイバネーションからウェイクアップする。次に、クライアントは指定された期間thost-detectMDDI_Data0ドライバーをイネーブルにする。その期間、ホストがMDDI_Stbトグリングを始める前にラインはロジックゼロレベルに駆動される。
期間thost-detect中にホストが要求を検出する前にある時間量が経過しまたは必要かもしれない。その後で、trestart-high期間中にMDDI_Data0をロジック1またはハイレベルに駆動することによりリンクスタートアップシーケンスを用いてホストがMDDI_Stbをトグルする前に、指定された期間tstb-startupMDDI_Stbをロジックゼロレベルに保持することによりホストが応答する。クライアントがMDDI_Stb上の第1のパルスを認識すると、クライアントはMDDI_Stb受信機内のオフセットをディスエーブルにする。クライアントは、ホストラインをドライブするのを検出するまで指定された期間tclient-detect、MDDI_Data0をロジック1レベルに駆動し続ける。この時点で、クライアントは、要求をデアサートしMDDI_Data0ドライバーをディスエーブルするので、クライアントからの出力は再びロジックゼロレベルになり、ホストはMDDI_Data0を駆動している。上述したように、ホストは、MDDI_Data0をtrestart-highの期間ロジック1レベルに駆動し続け、trestart-lowの期間MDDI_Data0ラインを低く駆動する。その後で、サブフレームヘッダーパケットを用いて第1のフォワードトラヒックが開始する。MDDI_Stb信号はtrestart-low期間、及び以後のサブフレームヘッダーパケットの間アクティブである。
表Xは、前述された多様の期間の長さの代表的な時間、及び例示的な最小データレートと最大データレートに対する関係性を示す。
Figure 2014053920
ここでLink_Data_Rateは単一のデータ対のビットレートである。
Figure 2014053920
当業者は、図41と図42に示されている個々の要素の機能が周知であり、図42の要素の機能が図43a、43b、43cのタイミング図で確認されることを容易に理解する。図42に示されている直列終端及びハイバネーション抵抗器についての詳細は、その情報が、データ−ストローブ符号化を実行し、そこからクロックを回復する方法の説明には不必要であるため図41から省略された。
B.データ−ストローブタイミング順方向リンク
ホストドライバー出力から順方向リンクでのデータ転送の切り替え特性は表XI−1に示されている。表XIは、表形式の所望される最小と最大対特定の信号遷移が発生するための典型的な時間を提示する。例えば、最小時間は約ttbit−0.5nsecであり、最大は約ttbit+0.5nsecであるが、遷移がデータ値(「0」又は「1」の出力)の始まりから最後までに発生する典型的な時間の長さ、ttdd−(ホスト−出力)と呼ばれるData0からData0遷移は、ttbitである。Data0、他のデータライン(DataX)、及びストローブ線路(Stb)での遷移間の相対的なスペーシングは、それぞれttds−(ホスト−出力)、ttss−(ホスト−出力)、ttsd−(ホスト−出力)、ttddx−(ホスト−出力)、ttdx−(ホスト−出力)、ttdxs−(ホスト−出力)、及びttsdx−(ホスト−出力)と呼ばれているData0からストローブ、ストローブからストローブ、ストローブからData0、Data0から非Data0、非Data0から非Data0、非Data0からストローブ、及びストローブから非Data0遷移が示されている図44に描かれている。
Figure 2014053920
順方向リンクでデータを転送している同じ信号のクライアント受信機入力のための典型的なMDDIタイミング要件は表XI−2に示されている。同じ信号が説明されているが、時間は遅延しているので、当業者によって理解されるように、それぞれのラベルの信号特性又は意味を説明するために新しい図は必要とされない。
Figure 2014053920
図45と図46は、ホストがそれぞれホストドライバーをイネーブル又はディスエーブルするときに発生することがある応答の遅延の存在を図解する。逆方向リンクカプセル化パケット又は往復遅延測定パケット等の特定のパケットを転送しているホストの場合、転送されたとして図45に示されているパラメーターCRCパケット、ストローブ位置合わせパケット、及び全ゼロパケット等、ホストは所望されるパケットが転送された後にラインドライバーをディスエーブルする。しかしながら、図45に示されているように、これはおそらく特定の制御素子又は回路素子が存在する状態では達成可能であるが、線路の状態は必ずしも「0」から所望されるさらに高い値に瞬時に切り替わらないが、応答にはホストドライバーディスエーブル遅延期間と呼ばれている期間を要する。それはこの期間の長さが0ナノ秒(nsec)であるように実質的に瞬時に発生できるが、それは、ガード時間1パケット期間又は方向転換1パケット期間の間に発生する所望される最大期間長である10nsecのさらに長い期間でさらに容易に広がるであろう。
図46を見ると、ホストドライバーが逆方向リンクカプセル化パケット又は往復遅延測定パケット等のパケットを転送するためにイネーブルされているときに信号レベル変化が起こったことがわかる。ここでは、ガード時間2パケット期間又は方向転換2パケット期間の後、ホストドライバーはイネーブルされ、レベル、ここでは「0」を駆動し始め、その値には、第1のパケットが送信される前に、ドライバー再イネーブル期間の間に発生するホストドライバーイネーブル遅延期間と呼ばれる期間に近づく又は達する。
同様のプロセスは、ドライバーについて、及びクライアントデバイス、ここではディスプレイのための信号転送について発生する。これらの期間の長さの一般的な指針及びそれぞれの関係性は以下の表XIIに示されている。
Figure 2014053920
C. ホストおよびクライアントイネーブルおよびディスエーブル時間
ホストおよびクライアントの出力イネーブルおよびディスエーブル時間のための切替特性および相対的なタイミング関係または逆方向リンクカプセル化パケット構造に対する動作は、図48に示される。ドライバー出力機能または動作は、ホスト出力イネーブル時間のためのthost-enable、ホスト出力ディスエーブルのためのthost-disable、クライアント出力イネーブル時間のためのtclient-enable、クライアント出力ディスエーブル時間のためのtclient-disableとしてラベルが付けられる。ある信号遷移のための典型的な時間は以下に記載される。これらの動作の最小期間は、ゼロナノ秒であろう。インターフェースを採用するシステム設計から決定された典型値または最大値は、恐らく8ナノ秒またはそれ以上のオーダーである。
これらの期間の長さのための一般的なガイドライン、(ホストおよびクライアントイネーブル/ディスエーブル時間)およびそれらの相対的な関係は以下のXIIIに示される。
Figure 2014053920
VIII.リンクコントロール(リンクコントローラー動作)のインプリメンテーション
A.状態機械パケットプロセッサ
MDDIリンク上で転送されているパケットは、所望されるようにさらに低い速度で確実に対処されるが、非常に迅速に、通常約300Mbps以上の速度でディスパッチされる。この種のバス又は転送リンクの速度は速すぎて、現在市販されている(経済的な)汎用マイクロプロセッサ等が制御することはできない。したがって、この種の信号転送を達成するための実用的なインプリメンテーションは、それらが意図されている適切な視聴覚サブシステムに転送される又はリダイレクトされるパケットを作成するために入力パケットストリームを解析するためにプログラマブル状態機械を活用することである。このような装置は周知であり、通常、所望される高レート又は超高レートの動作を達成するためには、限られた数の動作、機能又は状態に専用である回路を使用する。
汎用コントローラー、プロセッサ、又は処理要素は、さらに低い速度要件を有する制御パケット又はステータスパケット等のなんらかの情報により適切に作用する、あるいは操作するために使用できる。それらのパケット(制御、ステータス、又は他の所定のパケット)が受信されると、ステータス機械は、音声パケットと視覚パケットが処置のためにその適切なデスティネーションに転送される間に所望される結果(効果)を提供するために作用を受けることができるように、それらをデータバッファ又は類似する処理要素を通して汎用プロセッサに渡す必要がある。将来、マイクロプロセッサ又は他の汎用コントローラー、プロセッサ、又は処理要素がより速いデータレート処理機能を達成するために製造される場合には、通常は記憶要素又は媒体に記憶されているプログラムとして、状態、又は後述される状態機械もこのような装置のソフトウェア制御を使用して実現される可能性がある。
汎用プロセッサ機能は、いくつかのモデム又はグラフィックプロセッサが何らかの機能を実行しハードウェアの複雑性とコストを低減するためにコンピューター内で発見される処理能力を利用するのと大体同じ方法で、コンピューターアプリケーションにおけるマイクロプロセッサ(CPU)、又はコントローラー、プロセッサ、デジタル信号プロセッサ(DSP)、特殊化した回路、又は無線装置で見つけられるASIC等を利用することにより実現することができる。しかしながら、このサイクル共用又は使用は、このような素子の処理速度、タイミング、又は全体的な動作にマイナス影響を及ぼす可能性があるため、多くの応用例では、この汎用処理のために専用回路又は素子が好ましい。
画像データがディスプレイ(マイクロディスプレイ)に表示されるために、あるいはホストデバイスによって送信されるすべてのパケットを確実に受信するために、クライアント信号処理は順方向リンクチャネルタイミングと同期される。つまり、クライアントに到達する信号及びクライアント回路は、適切な信号処理のために実質的に時間同期される必要がある。1つの実施例の信号によって達成される状態の高水準図は、図49の図に提示されている。図49では、1つのASYNC FRAME(非同期フレーム状態)4904、2つの同期取得状態(ACQUIRING SYNC STATES)4902と4906、及び3つの同期中状態(IN−SYNC STATES)4908、4910、及び4912として分類されている状態機械4900の考えられる順方向同期「状態」が示されている。
ステップ又は状態4902を開始することによって示されているように、プレゼンテーション装置のようなディスプレイ又はクライアントは事前に選択された「同期なし」状態で開始し、検出される第1のサブフレームヘッダーパケットの一意のワードを検索する。この同期なし状態が、最小通信設定、又はタイプ1インターフェースが選択される「後退」設定を表すことが注記されなければならない。一意のワードが検索中に発見されると、ディスプレイはサブフレーム長フィールドを保存する。この第1のフレームに対する処理のための、あるいは同期が得られるまで、CRCビットのチェックはない。このサブフレーム長がゼロである場合は、同期状態処理はここで同期がまだ達成されていないことを示す「非同期フレーム」状態と呼ばれる状態4904に相応して進む。処理のこのステップは、図49の遭遇cond3、つまり条件3を有すると名付けられる。それ以外の場合、フレーム長がゼロより大きい場合には、同期状態処理は、インターフェース状態が「1つの同期フレームを発見」として設定される状態4906に進む。処理のこのステップは、遭遇cond5、つまり図49の条件5と名付けられている。さらに、状態機械が、ゼロより大きいフレーム長の間、フレームヘッダパケット及び良好なCRC決定を見る場合、処理は「1つの同期フレームを発見」に進む。これは会議cond6、つまり図49の条件6と名付けられている。
システムが「同期なし」以外の状態にあるそれぞれの状況において、良好なCRC結果を有するパケットが検出された場合、インターフェース状態は「同期中」状態4908に変更される。処理の中のこのステップは図49において遭遇cond1、または条件1を有するものとして名付けられている。他方いずれかのパケットのCRCが正しくない場合には、同期状態処理は、「同期なしフレーム(NO SYNC FRAME)」状態のインターフェース状態4902に進むか又は戻る。この処理の部分は図49の状態図において遭遇cond2または条件2と名付られている。
B.同期のための獲得時間
インターフェースは、同期が失われたと決定し、「NO SYNC FRAME(同期なしフレーム)」状態に戻る前に特定数の「同期エラー」に対処するように構成できる。図49では、いったん状態機械が「IN−SYNC STATE(同期中状態)」に到達し、エラーが検出されないと、それは連続してcond1結果に遭遇し、「IN−SYNC(同期中)」状態のままとなる。しかしながら、いったん1つのcond2結果が検出されると、処理は「1同期エラー」状態4910に状態を変更する。この時点で、処理が別のcond1結果を検出する結果となると、状態機械は「同期中」状態に戻り、それ以外の場合、それは別のcond2結果に遭遇し、「TWO−SYNC−ERRORS(2同期エラー)」状態4912に移る。この場合も先と同様に、cond1が発生すると、処理は状態機械を「IN−SYNC(同期中)」状態に戻す。それ以外の場合、別のcond2に遭遇し、状態機械は「同期なし」状態に戻る。インターフェースが「リンクシャットダウンパケット」に遭遇すると、これによりリンクがデータ転送を終了し、図49の状態図の中のcond4、つまりミーティング条件4と呼ばれる、同期するものが何もないので「同期なしフレーム」状態に戻ることも理解可能である。
サブフレーム内のどこか固定されたロケーションに現れる可能性のある一意のワードの「偽のコピー」を繰り返すことができることが理解される。その状況では、サブフレームヘッダーパケット上のCRCは、MDDインターフェース処理が「IN SYNC(同期中)」状態に進むために処理されるときにも有効でなければならないため、状態機械がサブフレームに同期する可能性はきわめて低い。
サブフレームヘッダーパケット内のサブフレーム長は、リンクがシャットダウンされる前にホストがただ1つのサブフレームを送信し、MDDインターフェースが休止ハイバネーション状態に入れられる、又は構成されることを示すためにゼロに設定されてよい。この場合、ディスプレイはサブフレームヘッダーパケットを検出後、ただ1つのサブフレームだけが、リンクがアイドル状態に遷移する前に送信されるため、順方向リンクで直ちにパケットを受信しなければならない。通常の、又は典型的な動作では、サブフレーム長は非ゼロであり、クライアントは、インターフェースが図49に集合的に「IN−SYNC(同期中)」状態として示されているそれらの状態にある間に順方向リンクパケットを処理するに過ぎない。
外部モードクライアント装置は、ホストが既に順方向リンクデータシーケンスを伝送している場合に、ホストに取付けることができる。この状態では、クライアントはホストに同期しなければならない。クライアントが順方向リンク信号に同期するのに要する時間は、サブフレームサイズと順方向リンクデータレートに応じて可変である。順方向リンク内で無作為な、又はさらに無作為なデータの一部として一意のワードの「偽のコピー」を検出する尤度は、サブフレームサイズがさらに大きいときより大きくなる。同時に、順方向リンクデータレートが低速化すると、偽検出から回復する能力は低くなり、そうするために要する時間は長くなる。
1つ以上の実施形態の場合に、MDDI逆方向リンクが低電力モードになるために順方向リンク送信を停止する前またはリンクを完全に遮断する前にMDDI逆方向リンクが安定であることを保証するためにMDDIホストは、あるさらなるステップを実行しなければならないことが推奨されるまたは理解される。
生じる可能性のある1つの問題は、ホストが、往復遅延値の正しくない測定値を使用するなら、これにより、順方向リンクが良いように見えてもクライアントからのすべての次に受信される逆方向データ送信は失敗するということである。これは、クライアントが順方向リンクに同期していないときに、ホストが往復遅延測定パケットを送信しようと試みるなら起こり得る。または往復遅延に影響を及ぼす差動ドライバーおよび受信機の伝搬遅延に対応する大きな変化を生じさせる極端な周囲温度変化により起こり得る。断続的なケーブルまたはコネクタの接触不良も、クライアントが一時的に同期を損なわせ、同期を取り戻させる。その期間クライアントは、往復遅延測定パケットを受信し損なうかもしれない。次の逆方向リンクパケットは、ホストにより正しくデコードできないであろう。
生じる可能性のある他のタイプの問題は、クライアントが一時的に同期を損ない、クライアントが同期を取り戻す前にホストがリンクシャットダウンパケットを送信することである。ホストはハイバネーションにはいるであろうが、クライアントは、ハイバネーション状態に入ることはできない。なぜなら、クライアントは、リンクシャットダウンパケットを受信していなかったし、リンクはハイバネーション状態にあるのでクロックを持たないからである。
そのような問題を克服するための1つの技術または実施形態は、リンクをハイバネーション状態にする前にクライアントが順方向リンクと同期していることをホストに保証させることである。MDDIホストがこれをできないならまたはそのような機会を持たないなら、たとえば、MDDIホストが電力を損失しているときまたは動作中に生じるケーブル、導体、またはコネクタの分離、切断、断線によりリンクが不意に破壊されるかまたは故障するなら、ホストは第1に、クライアントが往復遅延測定プロセスを開始する前または逆方向リンクカプセル化パケットを送信する前に同期することをホストが保証しなければならない。
ホストは、順方向リンクの完全性を決定するためにクライアントにより送信されたクライアント要求およびステータスパケット内のCRCエラーカウントフィールドを観察することができる。このパケットはクライアントからのホストにより要求される。しかしながら、主要リンクの故障または崩壊の場合には、この要求はたぶん応答されないであろう。なぜならクライアントは、パケットを正しくデコードできないであろうし、またはパケットを全く受信できないかもしれないからである。逆方向リンクカプセル化パケットで送信されたクライアント要求およびステータスパケットを用いたCRCエラーカウントのための要求は、一種の防御の第1線である第1の完全性チェックとして作用する。ホストは、クライアントが同期をやめたことについての仮説が正しいものか否かを確認するために往復遅延測定パケットを送信することができる。クライアントが往復遅延測定パケットに応答しないなら、ホストは、クライアントが同期をはずれ同期を取り戻す処理を開始したと結論づけるであろう。
クライアントがクライアント要求およびステータスパケットをホストに返送することを要求するために、逆方向リンクフラッグフィールドのビット1を1にセットして、ホストは、クライアントに逆方向リンクカプセル化パケットを周期的に送信することによりクライアント内のCRCエラーカウントを連続的に監視しなければならない。
クライアントが順方向リンクとの同期を損失している可能性がより高いとホストが結論づけると、ホストは、フィラーパケット以外の任意のパケットを送信しようとする前に次のサブフレームヘッダまで待つ。これは、クライアントが十分な時間でサブフレームヘッダーパケットに含まれる1つの固有のワードを検出または探すことを可能にするために行われる。これに続いて、クライアントは正しいロケーションにおいて固有のワードを発見しないであろうからクライアントは、自身をリセットしたであろうとホストは仮定してもよい。この時点で、ホストは、往復遅延測定パケットを有したサブフレームヘッダーパケットを追跡してもよい。クライアントが依然として往復遅延測定パケットに正しく応答していないなら、ホストは再同期処理を反復してもよい。正しい応答は、往復遅延測定パケットの測定期間にクライアントが指定されたシーケンスをホストに返送するものである。このシーケンスが受信されないなら、逆方向リンクカプセル化パケット内で逆方向データを受信する試みは失敗するであろう。この性質の連続した失敗は、ある他のシステムエラーを示しているかもしれない。このエラーは、ある別の方法で解決されなければならないであろう。そして、この時点でリンク同期の一部ではない。
しかしながら、成功した往復遅延測定パケットの後で、ホストが依然として損傷したデータを見るならまたは逆方向リンクカプセル化パケットで応答がないなら、ホストは、往復遅延測定パケットを再送信することにより逆方向データサンプリングが正しいことを確認しなければならない。多くの試みの後でこれが成功しないなら、一実施形態の場合、ホストは、逆方向除数値を増加させることにより逆方向データを低減することが推奨される。
ホストは、MDDIリンクをハイバネーション状態に設定する前にリンク故障検出そしておそらくは上述したリンク再同期化ステップを実行しなければならない。これは、一般的に、リンクが後に再開されたときに実行される往復遅延測定パケットが成功することを保証するであろう。ホストがリンク故障を疑う理由がなく、逆方向リンクカプセル化パケットに対する正しい応答およびゼロ順方向リンクCRCエラーがクライアントにより報告されるなら、ホストは、すべてがしかるべく適切に(例えばリンク故障がない)動作または機能していると仮定してもよく、電力ダウン/ハイバネーションプロセスに進んでもよい。
同期に対してホストがテストすることができる他の方法は、ホストが往復遅延測定パケットを送信し、クライアントからの適切な応答を確認することである。適切な応答がホストにより受信されるなら、ホストは、合理的に、クライアントが成功裏に順方向リンクパケットを解釈していると仮定することができる。
C.初期化
前述されたように、「起動」時に、ホストは順方向リンクを、1Mbpsという最小の必須、つまり所望されるデータレートで、又は以下で動作するように構成し、サブフレーム長とメディアフレームレートを既定の応用例のために適宜に構成する。つまり、順方向リンクと逆方向リンクの両方がタイプ1インターフェースを使用して動作を開始する。これらのパラメーターは通常、ホストがクライアントディスプレイ(又は他のタイプのクライアントデバイス)のための機能又は所望される構成を決定する間に一時的に使用されることになる。ホストは、ディスプレイ又はクライアントが表示機能パケットで応答することを要求するために、要求フラグのビット「0」を一(1)という値に設定させる逆方向リンクカプセル化パケットが後に続く順方向リンク上でサブフレームヘッダーパケットを送信又は転送する。いったんディスプレイが順方向リンクで(又は順方向リンクと)同期を獲得すると、クライアント機能パケットとクライアント要求及びステータスパケットを逆方向リンク又はチャネル上で送信する。
ホストは、最適の、又は所望されるレベルの性能のリンクを再構成する方法を決定するためにクライアント機能パケットの内容を調べる。ホストは、ホストとクライアントが互いに互換性のあるプロトコルのバージョンを使用することを確認するためにプロトコルバージョンフィールドと最小プロトコルバージョンフィールドを調べる。プロトコルバージョンは、通常、他のプロトコルの要素が互換性がない、あるいは互換性があると完全に理解されないときにも互換性を決定できるように表示機能パケットの最初の2つのパラメーターとして留まる。
内部モードにおいて、ホストは、クライアント能力パケットを受信する必要なくして前もってクライアントのパラメーターを知ることができる。リンクは、ホストとクライアントが両方動作することができる任意のデータレートで開始してよい。多くの実施形態において、システム設計者は、たいがいデータ転送を急がせるために最大の達成可能なデータレートでリンクを開始することを選択するであろう。しかしながら、これは必要ではなく、多くの状況において使用されないかもしれない。内部モード動作の場合、ハイバネーションシーケンスからのリンクリスタートの期間中に使用されるストローブパルスの周波数は通常この所望のレートと一致するであろう。
D.CRC処理
すべてのパケットタイプについて、パケットプロセッサ状態機械は、CRCチェッカが適切に又は正確に制御されることを保証する。それは、また、CRC比較の結果、1つ又は複数のエラーが検出されるとCRCエラーカウンタを増分し、それは処理されている各サブフレームの始まりでCRCカウンタをリセットする。
E.同期チェックの代替損失
前記の一連のステップ又は状態はさらに高いデータレート又はスループット速度を生じさせるが、出願人は、ホストとの同期の損失があることを宣言するためにクライアントが使用する代替配列又は状態の変化は、事実上、なおさらに高いデータレート又はスループットを達成するために使用できることを発見した。新しい発明の実施形態は状態を変更するための状態が変更されているが、同じ基本構造を有する。さらに、新しいカウンタがサブフレーム同期のためにチェックを行うのに役立つために実現されている。これらのステップ及び状態は、方法の動作又は状態機械を確立する上で有効な一連の状態及び条件を示す状態機械図63に関して提示されている。「ACQUIRING−SYNC STATES(同期状態獲得)」部分と「IN−SYNC STATES(同期中状態)」部分だけが明確にするために示されている。加えて、結果として生じる状態は、状態機械自体と同様に、実質的には同じであるため、それらは同じ番号付けを使用する。しかしながら、状態を変更するための条件(及び状態機械の動作)はやや変化し、その結果、相違点を識別する上での都合を考えて2つの図(1、2、3、4、5及び6対61、62、63、64、65)の間で明確にするためにすべてが番号を付け直される。ASYNC FRAME(非同期フレーム)状態はこの説明では考慮されないために、1つの状態(4904)と条件(6)は図中では使用されない。
図63では、図49に示されているような事前に選択された「同期なし」状態4902で、(表示又はプレゼンテーション用の)システム又はクライアントが状態機械5000で開始する。同期なし状態4902から状態を変更するための第1状態変化は、同期パターンの発見である条件64にある。サブフレームヘッダのCRCもこのパケットを順送りにすると仮定すると(条件61を満たす)パケットプロセッサ状態機械の状態は同期中状態4908に変更できる。同期エラー、条件62は、状態機械を状態4910に、第2の発生を状態4912にシフトさせる。しかしながら、MDDIパケットのCRC故障により状態機械は同期状態4908から外れ、1同期エラー状態4910になることが発見された。MDDIパケットの別のCRC故障により、2つの同期故障状態4912に動かされる。正しいCRC値で復号されるパケットにより、状態機械は同期中状態4908に戻る。
変更されたのは、「あらゆる」パケットについてCRC値又は決定を活用することである。
つまり、単にサブフレームヘッダーパケットを観察する代わりに、同期の損失を決定するために状態機械にパケットごとのCRC値を調べさせるのである。この構成又はプロセスでは、同期の損失は一意のワード及び単にサブフレームヘッダCRC値を使用して決定されない。
新しいインターフェースインプリメンテーションによりMDDインターフェースリンクは、はるかに迅速に同期失敗を認識し、したがってそれらからさらに迅速に回復することもできるようになる。
このシステムをさらに堅固にするために、クライアントはサブフレームカウンタを追加又は活用する必要がある。クライアントは、一意のワードの存在がないか、それが到着又は信号内で発生することが予想されるときにチェックする。一意のワードが正しいときに発生しないと、クライアントは、それが複数(ここでは3)のパケット回数又はサブフレーム長を上回る期間待機しなければならなかった場合よりはるかに迅速に同期失敗が発生したことを認識できる。一意のワードのテストがそれが存在しない、言い換えるとタイミングが正しくないことを示すと、クライアントは直ちに同期のリンク損失を宣言し、同期なし状態に移ることができる。正確な一意のワードの存在がないかチェックするプロセスは、一意のワードが正しくないと述べて、状態機械に条件65(cond65)を追加する。サブフレームパケットがクライアントで受信されることを予想され、一致しない場合、クライアントはただちに同期なし状態4902に移動し、通常、状態4910と4912を通って行き来して遭遇される複数の同期エラー(条件62)を待つ追加の時間を省くことができる。
この変化は、サブフレーム長をカウントするためにクライアントコア内で追加のカウンタ又はカウント機能を使用する。一実施形態では、カウントダウン機能が使用され、現在処理されていた任意のパケットの転送が、カウンタが時間切れになった場合にサブフレーム一意のワードがないかチェックするために中断される。代わりに、カウンタは数え上げることができ、カウントは所望される最大の、又は特定の所望される値に比較され、その時点で現在のパケットがチェックされる。このプロセスはクライアントを、異常に長いパケット長でクライアント上、誤って受信されるパケットを復号することから保護する。サブフレーム長カウンタが復号されていた他のなんらかのパケットを中断することを必要とした場合には、パケットはサブフレーム境界を越えてはならないので、同期の損失を決定できる。
IX.パケット処理
状態機械が受信する前述された各種パケットについて、それはインターフェースの動作を実現するために、特定の処理ステップ又は一連のステップに着手する。順方向リンクパケットは、通常、以下の表XIVに一覧表示される例示的な処理に従って処理される。
Figure 2014053920
Figure 2014053920
X.逆方向リンクデータレートの減速
発明者らにより、ホストリンクコントローラーのために使用される特定のパラメーターが、非常に望ましい最大又はさらに最適化された(スケール)逆方向リンクデータレートを達成するために特殊な方法で調整又は構成できることが観察された。例えば、逆方向リンクカプセル化パケットの逆方向データパケットフィールドを転送するために使用される時間中、MDDI_Stb信号組は、順方向リンクデータレートの半分で周期的なデータクロックを作成するためにトグルする。これは、ホストリンクコントローラーが、あたかも全ゼロを送信しているかのようにMDDI_Data0信号に対応するMDDI_Stb信号を生成させるために発生する。MDDI_Stb信号は、クライアントから逆方向リンクデータを転送するためのクロック信号を発生させるためにそれが使用される場合に、ホストからクライアントに転送され、逆方向データはホストに送り返される。MDDIを利用するシステム内の順方向経路と逆方向経路での信号転送及び処理のために遭遇される遅延の典型的な量の図解は図50に示されている。図50では、一連の遅延値、1.5nsec、8.0nsec、2.5nsec、2.0nsec、10nsec、15nsec、8nsec及び25nsecは、それぞれStb+/−生成、クライアント用のケーブル転送、クライアントレシーバ、クロック作成、信号時間記録、Data0+/−生成、ケーブル転送からホストへ、及びホスト受信機段のための処理部分近くに示されている。
順方向リンクデータ及び遭遇する信号処理遅延に応じて、この「往復」効果又はイベントのセットを完了するには、MDDI_Stb信号での1つのサイクルより多くの時間を要する可能性があり、時間又はサイクルの望ましくない量の時間又はサイクルの消費につながる。この問題を回避するために、逆方向レート除数が、逆方向リンク上の1ビット時間がMDDI_Stb信号の複数のサイクルに及ぶことが可能になる。これは、逆方向リンクデータは順方向リンクレート未満であることを意味する。
インターフェースを通る信号遅延の実際の長さが、それぞれの特定のホスト−クライアントシステム又は使用されているハードウェアに応じて異なる可能性があることが注記されなければならない。必要とされていないが、各システムは通常、逆方向レート除数を最適値に設定できるように、システム内での実際の遅延を測定するために往復遅延測定パケットを使用することによりさらによく機能させることができる。ホストは簡単ではあるが低速度で動作する基本データサンプリング、またはより複雑であるが高い逆データレートをサポートする高度なデータサンプリングのいずれかをサポートすることができる。両方の方法をサポートするクライアントの機能は同一と考えられる。
往復遅延は、ホストに往復遅延測定パケットをクライアントに送信させることにより測定される。クライアントは、測定期間フィールドと呼ばれるそのパケットの中の事前に選択された測定ウィンドウの内部で、あるいはその間に1のシーケンスをホストに送り返すことによってこのパケットに応答する。この測定の詳細なタイミングは前述された。往復遅延は、逆方向リンクデータが安全にサンプリングできる速度を決定するために使用される。
往復遅延測定は、0xff、0xff、0x00応答シーケンスがクライアントからホストで受信し直されると、測定期間フィールドの始まりと時間期間の始まりの間で発生する順方向リンクデータクロック間隔の数を決定すること、検出すること、あるいはカウントすることからなる。クライアントからの応答が、測定カウントが増分しそうになる前に順方向リンククロック期間のほんの少し、受信できることに注記する。この未修正の値が逆方向レート除数を計算するために使用される場合、それは信頼できないデータサンプリングのために逆方向リンクでビットエラーを引き起こすであろう。この状況の一例は、図51に示されており、ホストでMDDI_Data、ホストでのMDDI_Stb、ホストの内部の順方向リンクデータクロック、及び遅延カウントを表す信号が結果として生じるピクセルをグラフ形式で示されるデスティネーションピクセルロケーションに書く。図51では、応答シーケンスは遅延カウントが6から7に増分する前に順方向リンククロック期間の一部、ディスプレイから受信された。遅延が6であると見なされる場合には、ホストは逆方向データをビット遷移の直後に、あるいはおそらくビット遷移の途中でサンプリングする。この結果、ホストで誤ったサンプリングが行われるであろう。この理由から、測定遅延は、通常、それが逆方向データ除数を計算するために使用される前に1、増分されなければならない。
逆方向レート除数は、逆方向リンクデータをサンプリングする前に、ホストが待機しなければならないMDDI_Stbサイクルの数である。MDDI_Stbは順方向リンクレートの2分の1である速度で循環されるので、補正往復遅延測定は2で除算されてから次の整数に切り上げられる必要がある。公式として表すと、この関係性は以下のとおりである。
Figure 2014053920
示されている例の場合、これは以下になる。
Figure 2014053920
この例で使用される往復遅延測定が6と対照的に7であった場合、逆方向レート除数も4に等しくなるであろう。
逆方向リンクデータは、逆方向リンククロックの立ち上がりでホストによりサンプリングされる。逆方向リンククロックを作成するにはホストとクライアント(ディスプレイ)の両方に存在するカウンタ又は類似する公知の回路又は装置がある。カウンタは、逆方向リンククロックの第1の立ち上がりが、逆方向リンクカプセル化パケットの逆方向リンクパケットフィールドの第1のビットの始まりで発生するように初期化される。これは、後述の例について図52Aに示されている。カウンタはMDDI_Stb信号の各立ち上がりで増分し、それらがラップアラウンドするまで発生するカウント数は、逆方向リンクカプセル化パケットの中の逆方向レート除数パラメーターにより設定される。MDDI_Stb信号は順方向リンクレートの2分の1でトグルするため、逆方向リンクレートは、逆方向レート除数で除算された順方向リンクレートの2分の1である。例えば、順方向リンクレートが200Mbpsであり、逆方向レート除数が4である場合は、逆方向リンクデータレートは以下のように表される。
Figure 2014053920
逆方向リンクカプセル化パケット内のMDDI_Data0信号線とMDDI_Stb信号線のタイミングを示す例は図52に示されており、図に使用されているパケットパラメーターは以下の値を有する。
パケット長=1024(0x0400) 方向転換1長=1
パケットタイプ=65(0x41) 方向転換2長=1
逆方向リンクフラグ=0 逆方向レート除数=2
パラメーターCRC=0xdb43 全ゼロは0x00である パケット長フィールドとパラメーターCRCフィールドの間のパケットデータは以下のとおりである。 0x00、0x04、0x41、0x00、0x02、0x01、0x01、0x43、0xdb、0x00、...
クライアントから返された第1の逆方向リンクパケットは、7というパケット長及び70というパケットタイプを有するクライアント要求及びステータスパケットである。
このパケットはバイト値0x07、0x00、0x46、...等で開始する。しかしながら、第1のバイト(0x07)だけが図52で可視である。この第1の逆方向リンクパケットは、実際の逆方向リンク遅延を示すために、図中、ほぼ1逆方向リンククロック期間時間移動されている。クライアント往復遅延に対するゼロホスト付きの理想的な波形は点線トレースとして示されている。
パラメーターCRCフィールドのMSバイトは転送され、パケットタイプが先行し、次に全ゼロフィールドが続く。ホストからのストローブは1からゼロに、及びホストからのデータがレベルを変更するにつれて1に切り替わり、さらに幅広いパルスを形成する。データがゼロになると、ストローブはさらに高いレートで切り替わり、データラインでのデータの変化だけが位置合わせフィールドの最後近くで変化を引き起こす。ストローブは長期間、データ信号の固定された0レベル又は1レベルのために図の残りの部分についてさらに高レートで切り替わり、パルスパターン(端縁)に立ち下りで遷移する。
ホストの逆方向リンククロックは、クロックが逆方向リンクパケットに対処するために起動される方向転換1期間の最後までゼロである。図の下部の矢印は、開示の残りの部分から明らかとなるようにデータがいつサンプリングされるのかを示している。方向転換1の後に開始した、転送されているパケットフィールドの第1のバイト(ここでは11000000)が示されており、線路レベルはディスエーブルされているホストドライバーから安定化している。第1のビットの通過の遅延は、ビット3について見られるように、データ信号のための点線から見られる。
図53では、順方向リンクデータレートに基づいて逆方向レート除数の典型的な値を観察できる。実際の逆方向レート除数は適切な逆方向リンク動作を保証するために往復リンク測定の結果として求められる。第1の領域5302は、安全な動作の領域に相当し、第2の領域5304は限界性能の領域に相当し、第3の領域5306は、適切に機能する可能性が低い設定値を示す。
往復遅延測定及び逆方向レート除数設定値は、それらが送信される又は受信されるビット数よりむしろ実際のクロック期間の単位で表され、動作されるために順方向リンク又は逆方向リンクのどちらかでのインターフェースタイプ設定のどれかで動作している一方で同じである。
典型的に、最大の可能な逆方向レート除数は、タイプ1インターフェースを用いて往復遅延測定パケットの測定窓に送信することができるビットの数の半分である。すなわち、この場合(512バイト・8ビット/バイト)/2=2048である。
逆方向ビット時間を往復遅延よりも小さくすることができる代替として進歩した逆方向データサンプリング方法も採用することができる。この技術の場合、ホストは、往復遅延を測定するだけでなく、クライアントの「理想」ビット境界およびゼロ遅延とのリンクに対してクライアントからの応答の位相も決定することができる。クライアント装置応答の位相を知ることにより、ホストは、クライアントから逆方向のデータビットをサンプルするために相対的に安全な時間を決定することができる。往復遅延測定は、逆方向データパケットフィールドの開始に対して逆方向データの第1ビットのロケーションをホストに示す。
進歩したデータサンプリングの一例の一実施形態は図52Bにグラフの形式で示される。
ゼロ往復遅延を有する理想的な逆方向データ信号は、破線の波形として示される。3.5と4MDDI_Stbサイクルとの間の実際の往復遅延は、実線の波形と理想との間の遅延における差分として観察することができる。これは、往復遅延測定パケットを用いて測定されるであろう同じ遅延であり、7の順方向リンクビット時間に等しい測定された往復遅延値であろう。この実施形態において、逆方向データビットは、2MDDI Stbパルスの長さであり、これは、4の順方向リンクビット時間であり、2に等しい逆方向レート除数に対応する。進歩した逆方向データサンプリングの場合、どこかに記載したように計算するかわりに2のあらかじめ選択された逆方向レート除数を使用するほうが便利である。これは、進歩した逆方向データサンプリングに対して実質的に最適な選択のようにみえる。なぜならば、理想的なサンプリングポイントは、上述した一般的な測定を用いて容易に決定することができるからである。
逆方向データのための理想的なサンプリングポイントは、逆方向ビットあたりの順方向リンククロックの数または逆方向ビットあたりの往復遅延モジュロ順方向リンククロックの数により除算される合計往復遅延のリマインダ(reminder)をとることにより容易に計算することができる。次に、データ遷移から離れた安全なポイントを得るために1または2を減算する。この例では、7mod4=3、従って3−1=2または3−2=1である。
安全なサンプリングポイントは、ゼロ往復遅延のための「理想的」ビット境界の端から1または2の順方向リンクビット時間である。図は、タイミング図の底部における連続した垂直矢印により示されるように、理想的なビット境界から2の順方向リンクビット時間におけるサンプリングポイントを示す。第1のサンプリングポイントは、測定された往復遅延の後の第1の理想的なビット境界プラス安全サンプリングのためのオフセットである。この例において、往復遅延測定値は7である。従って次の理想的なビット境界は8番目のビット時間であり、従って安全サンプリングポイントに対して1または2を加算し、従って、第1のビットは、逆方向データパケットフィールドの後の9または10の順方向リンクビット時間でサンプルされなければならない。
XI.方向転換及びガード時間
逆方向リンクカプセル化パケット内の方向転換1フィールドは、ホストドライバーのための時間をディスエーブルにしクライアントドライバーのための時間を同時にイネーブルにすることができる。往復遅延測定パケット内のガード時間1フィールドはホストとクライアントの重畳を可能にし、ホストインターフェースドライバーがディスエーブルされる前にクライアントドライバーがイネーブルになることができる。逆方向リンクカプセル化パケット内の方向転換2フィールドはクライアントからの以前のフィールド内のデータを、ホストドライバーがイネーブルになる前に完全に送信することを可能にする。ガード時間2フィールドは、クライアントとホストドライバーをロジックゼロレベルで同時に駆動可能にする時間値または期間を提供する。ガード時間1フィールドおよびガード時間2フィールドは、調節するように意図されていない長さのためのあらかじめ設定されたまたはあらかじめ選択された値で一般的に充填される。使用されているインターフェースハードウェアに応じて、これらの値は、経験によって得られるデータを用いて開発してもよいし、ある場合には、動作を改良するために調節してもよい。
方向転換1
いくつかの因子は、方向転換1の長さの決定に寄与し、これらの値は、順方向リンクデータレート、ホスト内のMDDIデータドライバーの最大ディスエーブル時間、およびホストディスエーブル時間と一般的に同じであるクライアントドライバーのイネーブル時間である。方向転換1フィールドの長さは、24tBIT(表XIII)になるように選択される。方向転換1フィールドの順方向リンクバイトの数における長さは、インターフェースタイプ因子を用いて決定され、以下の関係を用いて計算される。
Figure 2014053920
ただし、インターフェースタイプ因子はタイプ1の場合1、タイプ2の場合2、タイプ3の場合4、およびタイプ4の場合8である。
方向転換2
方向転換2のために一般的に使用される時間の長さを決定する因子は、通信リンクの往復遅延、クライアント内のMDDIデータドライバーの最大ディスエーブル時間、およびクライアントドライバーディスエーブル時間と同じであるように指定されるホストドライバーのイネーブル時間である。最大ホストドライバーイネーブル時間およびクライアントドライバーディスエーブル時間はどこかで指定される。往復遅延はtBITの単位で測定される。方向転換2フィールドの順方向リンクバイトの数において指定される最小の長さは以下の関係に従って計算される。
Figure 2014053920
例えば、10の順方向リンククロックの往復遅延を有するタイプ3の順方向リンクは典型的に、
Figure 2014053920
のオーダーの方向転換2遅延を使用する。
XII.代替逆方向リンクタイミング
前述されたタイミングと保護周波数帯は高データ転送速度インターフェースを達成するために努力するが、発明者らは、逆方向タイミング発見を変更することにより、往復時間より短い逆方向ビット長を可能にする技法を発見した。
前記に提示されたように、逆方向リンクのタイミングに対する過去の手法は、クロックサイクルの数が逆方向タイミングパケットのガード時間1の最後のビットから、最初のビットがIOクロックの立ち上がりでサンプリングされるまでカウントされるように構成されている。それはMDDIの入力と出力を計時するために使用されるクロック信号(複数の場合がある)である。したがって逆方向レート除数のための計算は以下により示される。
Figure 2014053920
これは非常に信頼できる逆方向リンクを生じさせる往復遅延に等しいビット幅を提供する。しかしながら、逆方向リンクは、発明者らが利用を希望するさらに高レートに、つまりさらに高いデータ転送速度で運転できることが示されてきた。新しい本発明の技法はインターフェースの追加の機能をさらに高レートに達するために活用することを可能にする。
これは、ホストに、1がサンプリングされるまでクロックサイクル数をカウントさせることによって達成されるが、ホストは逆方向タイミングパケットの間立ち上がりと立ち下りの両方でデータラインをサンプリングする。これによりホストは、ビットが安定していることを確実にするために、逆方向ビットの中のもっとも有効な、あるいは最適でもあるサンプリング点を選ぶことができる。つまり、逆方向トラフィック逆方向カプセル化パケットにとってデータをサンプリングするためのもっとも有効又は最適な立ち上がりを発見することである。最適なサンプリング点は逆方向リンク除数と、第1のものが立ち上がりで検出されたのか、あるいは立ち下りで検出されたのかの両方に依存している。新しいタイミング方法により、ホストは逆方向カプセル化パケットにおいてどこでサンプリングするのかを決定するために、逆方向リンクタイミングのためにクライアントによって送信される0xFF 0xFF 0x00パターンの第1の端縁を単に探すことができるようになる。
到着する逆方向ビット及びそのビットがどのようにして多様な逆方向レート除数を探すのかの例は、ガード時間1の最後のビット以来発生した多くのクロックサイクルと共に、図64に示されている。図64では、最初の端縁が立ち上がりと立ち下りの間で(立ち上がり/立ち下りと名付けられる)発生すると、それが逆方向ビットの期間内で発生する唯一の立ち上がりであるため、1という逆方向レート除数の最適サンプリング点、つまり最適サンプル点は「b」と名付けられているクロックサイクル端縁である。2という逆方向レート除数の場合、サイクル端縁「c」は「b」よりビット端縁により近いので、最適サンプリング点はおそらく依然としてクロックサイクル前縁「b」である。4という逆方向レート除数の場合、最適サンプリング点は、それは、値がおそらく安定化した逆方向ビットのバックエッジにさらに近いので、おそらくクロックサイクル端縁「d」である。
図64に戻ると、しかしながら、第1の端縁が立ち下りと立ち上がり(立ち下り/立ち上がりと名付けられた)の間で発生すると、1という逆方向レート除数の最適サンプリング点は、それは逆方向ビット期間内の唯一の立ち上がりであるため、サンプリング点クロックサイクル端縁「a」である。2という逆方向レート除数の場合、最適サンプリング点は端縁「b」であり、4という逆方向レート除数の場合は最適サンプリング点は端縁「c」である。
逆方向レート除数がどんどん大きくなるにつれて、真ん中にもっとも近いのは立ち上がりでなければならないので、最適サンプリング点も確かめる又は選択するのが容易になる。
ホストは、タイミングパケットデータの立ち上がりデータがデータラインで観察される前に立ち上がりクロックの数を見つけ出すためにこの技法を使用できる。その結果、それは、端縁が立ち上がりと立ち下りの間で発生するのか、あるいは立ち下りと立ち上がりの間で発生するのか、ならびに逆方向レート除数がいくつであるのか、番号カウンタを追加するためにいくつの追加クロックサイクルが加算されるのかに基づいて、ビットが常に可能な限り真中近くでサンプリングされることを無理なく保証することを決定できる。
いったんホストがクロックサイクル数を選択又は決定すると、それは、特定の逆方向レート除数が働くかどうかを判断するためにクライアントと多様な逆方向レート除数を「検討」できる。ホスト(とクライアント)は1という除数で開始し、この逆方向レートがデータを転送するために適切に機能するかどうかを判断するために、クライアントから受信される逆方向ステータスパケットのRCをチェックできる。CRCが改悪されている場合、おそらくサンプリングエラーがあり、ホストは逆方向レート除数を高め、ステータスパケットの要求を再び試みることができる。第2の要求したパケットが改悪されている場合には、除数を再び増加でき、要求を再び行うことができる。このパケットが正しく復号されている場合、この逆方向レート除数はすべての将来の逆方向パケットについて使用できる。
[00610] この方法は、逆方向タイミングが初期の往復タイミング推定値から変化してはならないために効果的且つ有用である。順方向リンクが安定している場合、クライアントは、逆方向リンク障害があったとしても順方向リンクパケットを復号し続けなければならない。いうまでもなく、この方法は完全な逆方向リンクを保証しないため、リンクのための逆方向リンク除数を設定するのはホストの責任である。加えて、除数はIOクロックを作成するために使用されるクロックの質におもに左右される。そのクロックがかなりの量のジッターを有していると、サンプリングエラーの可能性は高くなる。このエラー確率は、往復遅延のクロックサイクル量と共に増加する。
このインプリメンテーションは、タイプ1逆方向データに最善に働くと考えられるが、データライン間のスキューが大きすぎて、ただ1つのデータ組だけ最善に働く速度でリンクを実行できないために、タイプ2からタイプ4の逆方向データでは問題を呈する可能性がある。しかしながら、おそらくデータレートは動作のためにタイプ2からタイプ4も用いる前記方法に従って減速される必要はない。この方法は、理想的な、又は最適なクロックサンプルロケーションを選択するために各データラインで重複される場合にも最善に働く可能性がある。それらがデータ組ごとに同じサンプル時間にある場合、この方法は作用し続けるであろう。それらが異なるサンプル期間にある場合には、2つの異なる手法が使用されてよい。第1は、たとえそれが各データ組にとって同じでないにしても、データポイントごとに所望される、あるいはさらに最適化されたサンプルロケーションを選択することである。次にホストはデータ組の集合からビットのすべてをサンプリングした後にデータストリームを再構築できる。つまり、タイプ2に2ビット、タイプ3に4ビット、及びタイプ4に8ビットである。他方のオプションは、データ組ごとのデータビットを同じクロック端縁でサンプリングできるように、ホストが逆方向レート除数を増加させることである。
XIII.リンク遅延及びスキューの影響
MDDI_Data組とMDDI_Stbの間の順方向リンクでの遅延スキューは、遅延スキュー補償が使用されない限り、考えられる最大データレートを制限できる。タイミングスキューを引き起こす遅延の差異は、コントローラーロジック回路、ラインドライバーとレシーバ、及び以下に概略されるようなケーブルとコネクタに起因している。
A.スキューによって制限されるリンクタイミング分析(MDDIタイプ1)
1.タイプ1リンクの遅延及びスキューの例
図41に示されているインターフェース回路に類似した典型的なインターフェース回路は、タイプ1インターフェースリンクに対処するために図57に示されている。図57では、伝搬遅延とスキューの例示的な又は典型的な値は、MDDI1型順方向リンクの複数の処理又はインターフェース段のそれぞれに示される。MDDI_StbとMDDI_Data0の間の遅延のスキューは、出力クロックのデューティサイクルを変形させる。フリップフロップ5728、5732を使用する受信機フリップフロップ(RXFF)段階のD入力でのデータは、それが確実にサンプリングできるようにクロック端縁後にわずかに変化しなければならない。図は、このタイミング関係を生じさせることにまつわる2つの異なる問題点を解決するために使用されている2つのカスケード式遅延線路5732aと5732bを示している。実際のインプリメンテーションでは、これらは単一の遅延要素に結合されてよい。
インターフェースを通した例示的な信号処理のためのタイプ1リンク上でのデータ、Stb(ストローブ)及びクロック回復タイミングは、図58に示されている。
著しい総遅延スキューは通常、以下の段階のスキューの合計から発生する又は生じる。つまりフリップフロップ5704、5706付きの送信機フリップフロップ(TXFF)、ドライバー5708、5710付きの送信機ドライバー(TXDRVR)、ケーブル5702、受信機5722、5724付きの受信機ラインレシーバ(RXRCVR)、及び受信機XORロジック回路(RXXOR)である。遅延1 5732aは、以下の関係性によって決定されるRXXOR段階でのXORゲート5736の遅延に一致、又は超えなければならない。
Figure 2014053920
受信機フリップフロップ5728、5732のD入力が、そのクロック入力の前に変化しないようにこの要件を満たすことが望ましい。これはRXFFの保持時間がゼロである場合に有効である。
遅延2の目的又は機能は、以下の関係性に従ってRXFFフリップフロップの保持時間を補償することである。
Figure 2014053920
多くのシステムでは、保持時間がゼロであるため、これはゼロとなり、いうまでもなくその場合遅延2の最大遅延もゼロとなる場合がある。
受信機XOR段階での最悪のケースのスキューへの貢献は、遅延1が最大値であり、XORゲートからのクロック出力が以下の関係性に従って可能な限り早期に起こるデータ−遅れ/ストローブ−早期ケースにある。
Figure 2014053920
この状況では、データは、ビットn+1が受信機フリップフロップの中に記録される時間に非常に近い2ビット期間、nとn+1の間で変化する可能性がある。
MDDI 1型リンクの最大データレート(最小ビット期間)は、RXFF段階に合計データセットアップを加えたMDDIリンク内のすべてのドライバー、ケーブル、及び受信機を通して遭遇される最大スキューの関数である。RXRCVR段階の出力までのリンクの総遅延スキューは以下のように表現でき、
Figure 2014053920
「ケーブル」は、さまざまな導体、相互接続、ワイヤおよび対応する遅延を表し、最小ビット期間は、
Figure 2014053920
によって指定される。
外部モードの場合、図57に示す例において、
Figure 2014053920
であり、最小ビット期間は以下のように表すことができる。
Figure 2014053920
またはほぼ434Mbpsとして記載することができる。内部モードの場合、図57に示す例において、
Figure 2014053920
であり、最小ビット期間は以下のように表すことができる。
Figure 2014053920
または、ほぼ555Mbpsとして記載することができる。
B.MDDIタイプ2、タイプ3、及びタイプ4のリンクタイミング分析
図41と図57に示されるインターフェース回路に類似する典型的なインターフェース回路は、タイプ2、タイプ3、タイプ4インターフェースリンクに対処するために図59に示されている。追加の要素は、追加の信号処理に対処するためにTXFF(5904)、TXDRVR(5908)、RXRCVCR(5922)及びRXFF(5932、5928、5930)段で使用される。図59では、伝搬遅延とスキューの例示的な又は典型的な値が、MDDIタイプ2順方向リンクの複数の処理段階又はインターフェース段階のそれぞれに示されている。出力クロックのデューティサイクルに影響を及ぼすMDDI_StbとMDDI_Data0の間の遅延でのスキューに加えて、これらの2つの信号と他のMDDIデータ信号の両方の間にもスキューがある。フリップフロップ5928と5930からなる受信機フリップフロップB(RXFFB)段のD入力でのデータは、それが確実にサンプリングできるようにクロック端縁の後わずかに変更される。MDDI_Data1がMDDI_Stb又はMDDI_Data0より早く到着すると、MDDI_Data1は少なくとも遅延スキューの量、サンプリングされるのを遅らされなければならない。これを達成するためには、データは遅延3遅延線路を使用して遅延されている。MDDI_Data1がMDDI_StbとMDDI_Data0より後に到着し、それが遅延3分遅延する場合には、MDDI_Data1が変化する点が次のクロック端縁のより近くに移動する。このプロセスがMDDIタイプ2、タイプ3又はタイプ4リンクのデータレートの上限を決定する。2つのデータ信号とMDDI_Stbの互いに関するタイミング又はスキュー関係性に対するいくつかの例示的な異なる可能性は、図60A、図60B及び図60Cに示されている。
MDDI_DataXが可能な限り早期に到着するときにRXFFBで確実にデータをサンプリングするために、遅延3は以下に従って設定されている。
Figure 2014053920
最大リンク速度は最小許容ビット期間により決定される。これは、MDDI_DataXが可能な限り遅れて到着すると最も影響を受ける。その場合、最小許容サイクル時間は以下によって示される。
Figure 2014053920
したがって、リンク速度の上限は
Figure 2014053920
であり、以下を考えれば
Figure 2014053920
である。
前記に示される例では、最小ビット期間の下限は以下の関係性により示される。
Figure 2014053920
これは、ほぼ174Mbpsである。
これは、タイプ1リンクと共に使用できる最大データレートよりはるかに遅い。MDDIの自動遅延スキュー補償機能は、遅延スキューが有効なデータセットアップのまさに端部である最大リンクレートファクタに対して及ぼす影響を大幅に削減する。MDDI_Data0およびMDDI_Stbとの間の較正されたスキューは、
Figure 2014053920
であり、最小ビット期間は、
Figure 2014053920
である。MDDI_DataOおよびMDDI_Stbの間の正確に測定されたスキューは次のとおりである:
「TB」またはtbはビット境界から最小出力レベルまでの信号ジッターを表す。非対称は、差動受信機を介したまたは差動受信機の内部遅延の非対称性質を指す。「TP4」は、クライアントのための差動ラインドライバーおよび受信機のための接続またはインターフェース(クライアント内のMDDIコントローラー装置のピン)として電気的特徴および試験目的のために関連づけられるまたは効率的に定義される。それは、便宜的または所定のポイントを表す。そのポイントから信号遅延は測定され、システムの残りの全体にわたってリンクに対して特徴づけられる。一実施形態において、TP4においてパラメーターtBの最大値は、クライアント送信機の場合、外部モードに対して関係
Figure 2014053920
によって定義され、内部モードに対して関係
Figure 2014053920
により定義される。
クライアント受信機の場合、外部モードに対して関係
Figure 2014053920
により定義される。
ラベルTP4は、インターフェースとリンクにおいてさまざまなテストポイント(TP)を番号づけするのに単に有用である。一実施形態において、このテストポイントロケーションは内部モードと外部モードの両方に対して同じであるように定義される。差動ラインドライバーおよび受信機を含むホスト内のMDDIコントローラー装置の接続またはインターフェースピンのためのまたは関連する対応する「TPO」テストポイントがある。この実施形態において、TP0におけるパラメーターTBの最大値は、ホスト受信機の場合、内部モードに対して関係
Figure 2014053920
により定義され、外部モードに対して関係
Figure 2014053920
により定義される。そしてホスト送信機の場合
Figure 2014053920
により定義される。
図59に示す例において
Figure 2014053920
であり、最小ビット期間は、
Figure 2014053920
であり、ほぼ606Mbpsである。
MDDI_Data1ができるだけ早く到着するとき、RXFFBにおいてデータを確実にサンプルするために、関連するプログラム可能な遅延は1タップの精度を有する最善の設定に調整され、そして追加のタップ遅延が安全のために追加される。最大リンクスピードが最小の許容可能なビット期間により決定される。これはMDDI_Data1が可能な限り遅く到着する場合に最も影響を受ける。この場合、最小の許容可能なサイクルタイムは、
Figure 2014053920
である。但し、「TA」またはtAはビット境界から中央交差までの信号ジッターを表す。
図59において示される実施形態において、標本のMDDI_Data1に基づく最小ビット期間の下限境界は、次の通りである。
Figure 2014053920
一実施形態において、内部モードの場合のホスト送信機内の遅延スキュー、遅延非対称、およびクロックジッターのための典型的な合計遅延時間は以下のように定義されるであろう。
Figure 2014053920
一実施形態において、InternalNrodeのためのホスト送信機の中の遅れスキュー、遅れ非対称およびクロックジッターのための典型的な総遅延時間は、次のように定義されるだろう:そして、外部モードの場合、
Figure 2014053920
のように定義されるであろう。一方、内部モードの場合のクライアント装置(tB-TP4)における遅延スキュー、遅延非対称、およびセットアップ時間のための典型的な合計遅延時間は、
Figure 2014053920
であり、外部モードの場合は、
Figure 2014053920
である。但し、TBDという用語は、外部モード接続のためのさまざまな良く理解された特徴および動作要件に依存するであろう決定された値になるように将来のための柔軟な場所を維持するラベルである。
XIV.物理層相互接続説明
本発明に従ってインターフェースを実現するために有効な物理接続は、ホスト側でヒロセ電機株式会社(Hirose Electric Company Ltd.)により製造されるパーツ番号3260−8S2(01)、クライアント装置側でヒロセ電機株式会社(Hirose Electric Company Ltd.)により製造されるパーツ番号3240−8P−C等の市販されているパーツを使用して実現できる。タイプ1/タイプ2インターフェースと共に使用されるこのようなコネクタ向けの例示的なインターフェースピン割り当て、つまり「ピン配列」は、表XVに一覧表示され、図61に図解されている。
Figure 2014053920
シールドは、ホストインターフェース内のHOST_Gndに接続され、ケーブルの中のシールドドレイン線はクライアントコネクタのシールドに接続されている。ただし、シールドとドレイン線はクライアントの内部の回路接地には接続されていない。
相互接続要素又は素子は、相対的な装置サイズに比べて邪魔にならず、悪趣味にならずにPDA及び無線電話、あるいは携帯ゲーム機等の移動体通信装置及び計算装置と使用するほど十分小型であるために選ばれる、あるいは設計されている。あらゆるコネクタ及びケーブル布線は、典型的な消費者環境で使用するのに十分なほど耐久性があり、特にケーブル布線のために小型に対処し、相対的に低コストでなければならない。転送要素は、タイプ1とタイプ2の場合、最高450Mbps、8ビット並列タイプ4バージョンの場合最高3.6Gbpsの転送率を有する差動NRZデータであるデータ信号とストローブ信号に対処する必要がある。
内部モードの応用例の場合、使用されている導線に対して同じ向きのコネクタはないか、あるいはこのような接続要素は非常に小型化する傾向があるかのどちらかである。1つの例は、集積回路又はホスト又はクライアントデバイスのどちらかを収容している素子を受け入れるためのゼロ挿入力の「ソケット」である。別の例はホストとクライアントが多様な相互接続導線と共にプリント基板上で常駐し、集積回路の相互接続のために導線上での接点にはんだ付けされているハウジングから伸びる「ピン」又は「接点」を有する場合である。
XV.動作
本発明の実施形態を使用するインターフェースの動作中にデータとパケットを処理する上で講じられる一般的なステップのまとめは、図55のパケットを処理するインターフェース装置の概要と共に、図54Aと図54Bに示されている。これらの図中、プロセスは、クライアント及びホストが通信路、ここではケーブルを使用して接続されているかどうかに関する決定を行うステップ5402で開始する。これは、(USBインターフェースについて見られているように)ホストへの入力でコネクタ又はケーブル又は信号の存在を検出するソフトウェア又はハードウェアを使用する、ホストによる周期的なポーリングを使用することによって、あるいは他の公知の技法で発生することができる。ホストに接続されているクライアントがない場合には、それは、応用例に応じて単に所定の長さの待機状態に入る、ハイバネーションモードに入る、あるいはユーザにホストを再アクティブ化するための処置を講じることを要求する可能性のある将来の使用に待機するために非活性化される場合がある。例えば、ホストがコンピュータータイプの装置に常駐するとき、ユーザは画面アイコンをクリックする、あるいはクライアントを探すためにホスト処理をアクティブ化するプログラムを要求しなければならない可能性がある。この場合も先と同様に、ホスト又は常駐ホストソフトウェアの機能と構成に応じてUSB型接続の簡略なプラグインにより、ホスト処理をアクティブ化できるであろう。
いったんクライアントがホストに接続される、あるいはその逆の場合、又は存在しているとして検出される場合、クライアント又はホストのどちらかがステップ5404と5406でサービスを要求する適切なパケットを送信する。クライアントはステップ5404でクライアントサービス要求パケット又はステータスパケットのどちらかを送信できるであろう。前述されたように、リンクは、これが続く通信リンクの完全な初期化ではないように、過去にシャットダウンできた、あるいはハイバネーションモードであったことが注記される。いったん通信リンクが同期され、ホストがクライアントと通信しようとすると、クライアントはステップ5408でのように、ホストへクライアント機能パケットも提供する。ホストは、ここでクライアントが対処できる転送速度を含むサポートのタイプの決定を開始できる。
一般的には、ホストとクライアントは、ステップ5410で例えばタイプ1、タイプ2等の使用されるサービスモードのタイプ(速度/速度)も交渉する。いったんサービスタイプが確立されると、ホストは情報の転送を開始できる。加えて、ホストは、ステップ5411に図示されるように他の信号処理と並列に通信リンクのタイミングを最適化するために往復遅延測定パケットを使用してよい。
前述されたように、すべての転送は、データのタイプ、ここではビデオ及び音声ストリームパケット、及びステップ5414で転送されているのが示されるフィラーパケットが後に続く、ステップ5412で転送されているのが示されるサブフレームヘッダーパケットで開始する。音声データとビデオデータは過去に作成された又はパケットの中にマッピングされ、フィラーパケットはメディアフレーム用の必要数のビットを記入するために必要に応じて、又は所望されるように挿入される。ホストは、サウンドデバイスをアクティブ化するために順方向音声チャネルイネーブルパケット等のパケットを送信できる。加えて、ホストは前述された他のパケットタイプ、ここではカラーマップの転送、ビットブロック転送、又はステップ5416の他のパケットを使用してコマンド及び情報を転送できる。さらに、ホストとクライアントは適切なパケットを使用してキーボード又はポインティングデバイスに関連するデータを交換できる。
動作中、インターフェースモードの別のデータレート又はタイプを所望するホスト又はクライアントにつながる複数の異なるイベントの1つが発生することがある。例えば、コンピューター又はデータを通信する他の装置は、パケットの作成又はプレゼンテーションにおいて低速化を引き起こすデータを処理する際の荷重条件に遭遇するであろう。データを受信するクライアント装置は専用AC電源からさらに制限された電池電源に変更し、データを迅速に転送できない、容易にコマンドを処理できない、あるいはより限られた電力設定の元で同程度の解像度又はカラー階調を使用できないであろう。代わりに、制限条件は排除される、あるいは姿を消し、装置がさらに高レートでデータを転送できるようにする。これはより望ましく、さらに高レートの転送速度モードへの変更を要求できる。
これらのあるいは他の種類の公知の条件が発生する、あるいは変化する場合、ホスト又はクライアントのどちらかはそれらを検出し、インターフェースモードを再交渉しようとしてよい。これは、ホストが、別のモードへのハンドオフを必要とするクライアントにインターフェースタイプハンドオフ要求パケットを送信するステップ5420で示され、クライアントは変更が求められることを確認するインターフェースタイプアクノレッジパケットを送信し、ホストは、指定されたモードに変更するために実行型ハンドオフパケットを送信する。
このような要素はホスト側に存在してもよいが、処理の特定の順序を要求していないが、クライアントとホストはポインティングデバイス、キーボード、又はおもにクライアントと関連付けられる他のユーザ型入力装置向けの、あるいはそれらから受信されたデータに関連するパケットも交換できる。これらのパケットは、通常、状態機械(5502)ではなく、汎用プロセッサタイプの素子を使用して処理される。加えて、前述されたコマンドのいくつかは汎用プロセッサ(5504、5508)によっても処理されるであろう。
データとコマンドがホストとクライアントの間で交換された後で、なんらかの点で、追加データが転送されるべきかどうか、あるいはホスト又はクライアントが転送にサービスを提供するのをやめるかどうかに関して決定が下される。これはステップ5422に示されている。リンクがハイバネーション状態に入る、又は完全にシャットダウンされるかのどちらかである場合、ホストはクライアントにリンクシャットダウンパケットを送信し、両方の側がデータの転送を終了する。
前記動作処理で転送されているパケットは、ホストコントローラーとクライアントコントローラーに関連して前述されたドライバーと受信機を使用して転送される。これらのラインドライバー及び他のロジック素子は図55の概要に示されているように、前述された状態機械と汎用プロセッサに接続されている。図55では、状態機械5502及び汎用プロセッサ5504と5508がさらに、専用のUSBインターフェース、メモリ素子、又はビュー表示装置用のデータソースとビデオ制御チップを含むがこれらに限定されない、それらが対話するリンクコントローラーの外部に常駐する他の構成部品等の図示されていない他の要素に接続されてよい。
プロセッサ及び状態機械は、通信リンクの効率的な確立又は終端、及びパケットの転送を保証するために、ガード時間に関して関連して前述されたようなドライバーのイネーブルとディスエーブルに制御を提供する。
XVI.ディスプレイフレームバッファ
ビデオデータバッファリング要件はコンピューターグラフィックと比較して、動画ビデオ画像について異なっている。ピクセルデータは、ディスプレイ上の画像を局所的にリフレッシュできるように、ほとんどの場合クライアント内のローカルフレームバッファに記憶される。
フルモーションビデオが表示されている(ディスプレイ内のほぼすべてのピクセルが各メディアフレームを変更する)とき、ディスプレイ上の画像は第2のフレームバッファからリフレッシュされているが、通常、1つのフレームバッファの中に入信ピクセルデータを記憶することが好ましい。3つ以上のディスプレイバッファは後述されるように可視アーチファクトを排除するために使用されてよい。画像全体が1つのフレームバッファ内に受け入れられると、バッファの役割は交換でき、新規に受信された画像は次にディスプレイをリフレッシュするために使用され、他のバッファは画像の次のフレームで充填される。この概念は、ピクセルデータが、表示更新ビットを「01」に設定することによりオフライン画像バッファに書き込まれる図88Aに示されている。
他の応用例では、ホストは画像全体を塗り直す必要なく、画像の小さな部分だけを更新する必要がある。この状況では、図88Bに詳細に示されるように、新しいピクセルを、表示をリフレッシュするために使用されているバッファに直接的に書き込むことが望まれる。
小型ビデオウィンドウ付きの固定画像を有する応用例では、図88Cに示されるように両方のバッファ(「11」に等しい表示更新ビット)に固定された画像を書き込み、後に表示更新ビットを「01」に設定することによりオフラインバッファに動画のピクセルを書き込むことが最も容易である。
以下の規則は、同時に新しい情報をクライアントに書き込み、表示をリフレッシュしながら、バッファポインタの有効な操作を記述している。3つのバッファポインタが存在する。つまり、current_fillは、MDDIリンク上でデータから現在充填されているバッファを指す。just_filledは、最も最近充填されたバッファを指す。being_displayedは表示をリフレッシュするために現在使用されているバッファを指す。すべての3つのバッファポインタは0からN−1の値を含んでよく、Nはディスプレイバッファの数であり、N≧2である。バッファポインタ上の演算はNを係数としている。例えばN=3及びcurrent_fill=2のとき、current_fillを増分すると、current_fillは0に設定される。N=2である単純な場合には、just_filledは常にcurrent_fillの補数である。あらゆるMDDIメディアフレーム境界(サブフレームカウントフィールドがゼロに等しいサブフレームヘッダーパケット)で、指定された順序で以下の演算を実行する。just_filledをcurrent_fillに等しく設定し、current_fillをcurrent_fill+1に設定する。
MDDIビデオストリームパケットは、以下の構造又は方法論に従ってバッファ更新する。つまり表示更新ビットが「01」に等しいとき、ピクセルデータはcurrent_fillによって指定されるバッファに書き込まれる。表示更新ビットが「00」に等しいとき、ピクセルデータはjust_filledによって指定されるバッファに書き込まれる。及び、表示更新ビットが「11」に等しいときには、ピクセルデータはすべてのバッファに書き込まれる。表示はbeing_displayedポインタによって指定されるバッファからリフレッシュされる。表示が1つのフレームリフレッシュエポックの最後のピクセルをリフレッシュした後、及びそれが次のフレームリフレッシュエポックの中の最初のピクセルのリフレッシュを開始する前に、表示更新プロセスはbeing_refreshedをjust_filledに等しく設定する動作を実行する。
ピクセルデータ属性フィールドを有したパケットは、ピクセルデータが書かれるフレームバッファを指定する表示更新ビットの対を含む。クライアント機能パケットは、表示更新ビットのどの組み合わせがクライアントでサポートされるのかを示す3つの追加ビットを有する。多くの場合、コンピューターにより作成される画像はユーザ入力に基づいて増分的に更新される、あるいはコンピューターネットワークから受信される情報から引き出される必要がある。表示更新ビット組み合わせ「00」と「11」は、ピクセルデータを、表示されているフレームバッファに、あるいは両方のフレームバッファに書き込ませることによってこの運転モードをサポートする。
ビデオ画像に対処するとき、図89は、ビデオデータが、表示更新ビットが「01」に等しい状態でMDDIリンク上で送信されるときに1組のフレームバッファを使用してどのようにしてビデオ画像が表示されるのかを示す。メディアフレーム境界がMDDIリンクで検出されると、表示リフレッシュプロセスは、現在リフレッシュされているフレームのリフレッシュプロセスが完了すると次のフレームバッファからのリフレッシュを開始する。
図89に関連する重要な仮定は、画像が、クライアントが表示をリフレッシュするためにフレームバッファからピクセルを読み取るのに使用するのと同じ順序で(通常、左上、行ごとに読み取り、画面の右下角へ)送信されるピクセルの連続ストリームとしてホストから受信されるという点である。これは、表示リフレッシュ動作と画像転送動作が同じフレームバッファを参照している場合に重要な詳細である。
部分的な画像を表示するのを回避するために、表示リフレッシュフレームレートが画像転送フレームレートを上回ることが必要である。図90は、どのようにしてゆっくりとした表示リフレッシュ速度で画像フラグメンテーションが発生できるのか、つまりどのようにして表示リフレッシュが画像転送より低速なのかを示す。
コンピューターグラフィックス画像と動画ビデオ画像の組み合わせを含む画像では、ビデオピクセルデータはメディアフレームの小さい部分を含んでいる可能性がある。これは、表示リフレッシュ動作と画像転送が同じフレームバッファを参照する状況では重要になるであろう。これらの状況は、表示をリフレッシュするためにバッファから読み取られたピクセルが2コマ前のバッファに書き込まれたピクセルである可能性がある、あるいはそれらが同じフレームバッファに直ちに書き込まれているフレームに一致する可能性がある、図91で斜行平行線の陰影により示されている。
3つのフレームバッファをクライアントで使用すると、図92に示されているようなフレームバッファへのアクセスの競合のある小さなウィンドウの問題が解決される。
ただし、図93に示されているように、表示リフレッシュレートがMDDIリンク上のメディアフレームレート未満である場合には依然として問題がある。
図94に示されるように、単一バッファを動画ビデオ画像に使用することはやや問題がある。バッファへの画像転送より高レートの表示リフレッシュの場合、リフレッシュされている画像が書き込まれているフレームの上部を示し、画像の下部は過去に転送されたフレームとなる。画像転送より高レートの表示リフレッシュ(好ましい運転モード)の場合、類似する分割された画像を示すフレームの例がより頻繁になるであろう。
XVII.マルチプルクライアントサポート
現在のプロトコルバージョンは、複数のクライアントデバイスを直接的にサポートしているように考えられない。しかしながら、大部分のパケットは、複数のクライアントがいるシステム内で特定のクライアントデバイスをアドレス指定するために使用できる予約クライアントIDフィールドを含んでいる。現在、多くの応用例の場合、このクライアントID又はこれらのクライアントIDはゼロに設定される。サブフレームヘッダーパケットもホストが複数のクライアントシステムをサポートするか否かを示すためのフィールドを含む。したがって、複数のクライアントデバイスが、複数のクライアントホスト又はクライアントとの将来の互換性のためにシステム設計者が計画するのを支援するためにMDDインターフェース又はプロトコルの将来の応用例で接続され、アドレス指定される可能性がある様式がある。
複数のクライアントを有するシステムでは、図95に示されるように、クライアントのデイジーチェーンを使用して、又はハブを使用して、あるいは図96に示されるようにこれらの技法の組み合わせを使用してクライアントがホストに接続されるのが有用である。また、ホストがあるエラーメッセージを表示して接続されたクライアントを管理することは有用であるかもしれない。例えばアドレス0を所望する1つ以上のクライアントが接続されているときのエラーメッセージである。これはマルチクライアントシステムの場合であってはならない。そのようなディスプレイは唯一のクライアントとして動作するように期待するまたは設定されるからである。
XIII. 補遺
本発明の実施形態のためのアーキテクチャ及びプロトコルを実現するために使用される多様なパケットについて前述されたフォーマット、構造、及びコンテンツに加えて、さらに詳しいフィールドコンテンツ又は動作がここではパケットタイプのいくつかのために提示されている。これらは、ここで当業者が種々の応用例のために本発明をさらに容易に理解し、利用できるようにするために、そのそれぞれの使用又は動作をさらに明確にするためにここで提示されている。すでに説明されていないフィールドの内の数個しかここではさらに説明されない。さらに、これらのフィールドには、前記に提示された実施形態に関連した例示的な定義及び値が提示される。しかしながら、このような値は本発明の制限として解釈されるべきではなく、インターフェースとプロトコルを実現するために有効な1つ又は複数の実施形態を表し、すべての実施形態がいっしょに又は同時に実践される必要はない。他の値は、当業者により理解されるように、データ又はデータレート転送結果の所望されるプレゼンテーションを達成するために、他の実施形態で使用できる。
A.ビデオストリームパケットの場合
一実施形態では、ピクセルデータ属性フィールド、ここでは、2バイトは、以下のように解釈される一連のビット値を有する。ビット1と0は、どのようにして表示ピクセルデータが送られるのかを選択する。「11」というビット値の場合、ピクセルデータは両目に、又は両目用に展示され、ビット値「10」の場合、ピクセルデータは左目だけに送られ、ビット値「01」の場合、ピクセルデータは右目だけに送られ「00」というビット値の場合、ピクセルデータは後述されるようなビット8から11によって指定されるように代替ディスプレイに送られる。クライアント内にあるまたは使用中または動作されている一次ディスプレイがステレオ画像またはある形態の画像化をサポートしないなら、これらのコマンドは、ディスプレイにより所望される効果を持つように効率的に埋め込むことができない。この状況または構成で、クライアントは、ビット値に関係なくまたは「01」、「10」または「11」のビットの組み合わせのいずれかに対して一次ディスプレイにピクセルデータを送らなければならない。なぜなら、結果として生じるコマンドまたは制御は、ディスプレイにより実施されないであろうからである。実施形態により要求されないが、ステレオ表示能力をサポートしないこれらのクライアント内の一次ディスプレイをアドレスするために値「11」を使用することが推奨される。
ビット2は、「0」という値がピクセルデータが標準漸次フォーマットであることを意味し、行番号(ピクセルY座標)が、ある行から次の行に進むときに1増分されることを意味する、ピクセルデータがインタレースフォーマットで提示されるかどうかを示す。ビットに「1」という値があるとき、ピクセルデータはインタレースフォーマットであり、行番号は、ある行から次の行に進むときに2で増分される。ビット3は、ピクセルデータが代替ピクセルフォーマットを取ることを示す。これはビット2でイネーブルされる標準インタレースモードに類似しているが、インタレースは水平の代わりに垂直である。ビット3が「0」であるとき、ピクセルデータは標準漸次フォーマットであり、列番号(ピクセルX座標)が、各連続ピクセルが受信されると1増分される。ビット3が「1」であるとき、ピクセルデータは代替ピクセルフォーマットを取り、列番号は各ピクセルが受信されると2増分される。
データは、無線電話又は類似した装置又はポータブルコンピューター又は前述されたようなこのような他の装置用の内部ディスプレイに、又は内部ディスプレイから転送される、あるいはデータは装置に内蔵される、又は直接的に結合されるカメラに、又はカメラから転送されているので、ビット4は、ピクセルデータがディスプレイに関連するのか、あるいはカメラに関連するのかを示す。ビット4が「0」であるとき、ピクセルデータはディスプレイフレームバッファへ、又はディスプレイフレームバッファから転送されている。ビット4が「1」であるとき、ピクセルデータは何らかのタイプのカメラ又はビデオ装置へ、又はそれから転送されており、このような装置は技術で周知である。
ビット5は、ピクセルデータがいつディスプレイ内のピクセルの次の連続行を含むのかを示すために使用される。これは、ビット5が「1」に等しく設定されるケースと見なされる。ビット5が「1」に設定されるときには、X左端縁、Y上部端縁、X右端縁、Y下部端縁、X開始、Y開始パラメーターが定義されず、クライアントによって無視される。ビット15がロジック1レベルに設定されると、これは、このパケットの中のピクセルデータが画像の中のピクセルの最後の行であることを示す。クライアント機能パケットのクライアント特徴機能インジケータフィールドのビット8は、この特徴がサポートされているかどうかを示す。
ビット7と6は、ピクセルデータが書き込まれなければならないフレームバッファを指定する表示更新ビットである。さらに具体的な効果は他の場所で説明される。「01」というビット値の場合、ピクセルデータはオフライン画像バッファに書き込まれる。「00」というビット値の場合、ピクセルデータは、表示をリフレッシュするために使用される画像バッファに書き込まれる。「11」というビット値の場合、ピクセルデータはすべての画像バッファに書き込まれる。「10」というビット値又は組み合わせは無効値又は指定として処理され、ピクセルデータは無視され、画像バッファのどれにも書き込まれない。この値はインターフェースの将来の応用例のために使用される可能性がある。
ビット8から11は、代替ディスプレイ又はピクセルデータが送られるディスプレイロケーションを指定する4ビットの符号なし整数を形成する。ビット0と1は、ディスプレイクライアントが代替ディスプレイ番号としてビット8から11を解釈するために「00」に等しく設定される。ビット0と1が「00」に等しくない場合には、ビット8から11はロジックゼロレベルに設定される。
ビット12から14は、将来の使用のために予約され、通常ロジックゼロレベルに設定されている。ビット15は、前述されたように、ビット5と共に使用される。ビット15をロジック1に設定すると、ピクセルデータフィールドの中のピクセル行がデータのフレームの最後の行であることが示される。ビット5がロジック1に設定される次のビデオストリームパケットは、次のビデオフレームのピクセルの第1の行に相当する。
2バイトのX開始フィールドとY開始フィールドは、ピクセルデータフィールドの第1のピクセルの点(X開始、Y開始)の絶対X座標と絶対Y座標を指定する。X右端縁フィールドとY下部端縁フィールドは更新されているウィンドウの右端縁のX座標と下部端縁のY座表を指定するが、2バイトのX左端縁フィールドとY上部端縁フィールドは、ピクセルデータフィールドによって充填される画面ウィンドウの左端縁のX座標と上部端縁のY座標、上部端縁のY座標を指定する。
ピクセルカウントフィールド(2バイト)は、以下のピクセルデータフィールドの中のピクセル数を指定する。
パラメーターCRCフィールド(2バイト)は、パケット長からピクセルカウントまでのすべてのバイトのCRCを含む。このCRCがチェックできない場合、パケット全体が廃棄される。
ピクセルデータフィールドは、表示されなければならず、ビデオデータフォーマットディスクリプタフィールドによって記述されるようにフォーマットされる未処理ビデオ情報を含む。データは他の箇所に説明されるように一度に一「行」送信される。ピクセルデータアトリビュートフィールドのビット5がロジックレベル1に設定された場合、ピクセルデータフィールドは、最も左側のピクセルに対応する伝送された最初のピクセルおよび最も右側のピクセルに対応する伝送された最後のピクセルを有す、ピクセルの1つの行を正確に含む。
ピクセルデータCRCフィールド(2バイト)は、ピクセルデータだけの16ビットCRCを含む。この値のCRC検証が失敗すると、ピクセルデータは依然として使用できるが、CRCエラーカウントが増分される。
B.音声ストリームパケットの場合
一実施形態では、音声チャネルIDフィールド(1バイト)が、音声データがクライアントデバイスによって送信される特定の音声チャネルを識別するために8ビットの符号なし整数値を使用する。物理音声チャネルは、それぞれ左前チャネル、右前チャネル、左後チャネル、右後チャネル、前中央チャネル、サブウーファーチャネル、サラウンド左チャネル及びサラウンド右チャネルを示す、0、1、2、3、4、5、6又は7という値としてこのフィールドによって物理チャネルに指定される、あるいは物理チャネルにマッピングされる。254という音声チャネルID値は、デジタル音声サンプルの単一のストリームが左前チャネルと右前チャネルの両方に送信されることを示す。これにより、音声通信にステレオヘッドセットが使用される、生産性強化応用例がPDAで使用される、あるいは単純なユーザインターフェースが警告音を生成する他の応用例のために使用される等の応用例のための通信を簡略化する。現在8から253の範囲及び255のIDフィールドのための値は、当業者によって予期されるように、新しい設計が追加の指定を所望する使用のために予約されている。
予約1フィールド(1バイト)は通常将来の使用のために予約されており、このフィールドのすべてのビットはゼロに設定される。このフィールドの1つの機能はすべての以後の2バイトフィールドを16ビットワードアドレスに位置合わせさせ、4バイトフィールド2を32ビットワードアドレスに位置合わせさせることである。
音声サンプルカウントフィールド(2バイト)は、このパケットの音声サンプル数を指定する。
サンプルあたりビット及びパッキングフィールドは音声データのパッキングフォーマットを指定する1バイトを含む。一実施形態では、通常利用されるフォーマットは、ビット4から0が、PCM音声サンプルあたりのビット数を定義することである。次にビット5は、デジタル音声データサンプルがパックされているかどうかを指定する。前述されたように、図12は、パッキングされたサンプルとバイト位置合わせされた音声サンプルの間の差異を示す。ビット5の「0」という値は、デジタル音声データフィールドの中の各PCM音声サンプルがインターフェースバイト境界とバイト位置合わせされていることを示し、「1」という値は、各連続PCM音声サンプルが過去の音声サンプルに対してパックされていることを示す。このビットは、ビット4から0(PCM音声サンプルあたりのビット数)に定義される値が8の倍数ではないときにだけ有効である。ビット7から6は、システム設計が追加の指定を所望する用途に予約され、通常ゼロという値で設定される。
音声サンプルレートフィールド(1バイト)は、音声PCMサンプルレートを指定する。利用されるフォーマットは、それぞれ0という値が毎秒8,000サンプル(sps)という速度を示し、1という値が16,000sps、2という値が24,000sps、3という値が32,000sps、4という値が40,000sps、5という値が48,000sps、6という値が11,025sps、7という値が22,050sps、及び8という値が44,100spsを示し、9から255という値は将来の使用のために予約されており、それらは現在ゼロに設定されている。
パラメーターCRCフィールド(2バイト)は、パケット長から音声サンプルレートまでのすべてのバイトの16ビットCRCを含む。このCRCが適切にチェックできないとき、パケット全体が廃棄される。デジタル音声データフィールドは再生される未処理音声サンプルを含み、通常、符号なし整数として線形フォーマットの形をとる。音声データCRCフィールド(2バイト)は、音声データだけの16ビットCRCを含む。このCRCがチェックできない場合、音声データは依然として使用できるが、CRCエラーカウントは増分される。
C.ユーザ定義ストリームパケット用
一実施形態では、2バイトのストリームID番号フィールドは、特定のユーザが定義したストリームを識別するために使用される。ストリームパラメーターフィールドとストリームデータフィールドのコンテンツは、通常、MDDI装置製造メーカによって定義される。2バイトのストリームパラメーターCRCフィールドは、パケット長から始まり音声コーディングバイトまでのストリームパラメーターのすべてのバイトの16ビットのCRCを含む。このCRCがチェックできない場合、パケット全体が廃棄される。MDDIインターフェースの最終用途により必要とされない場合、つまりスそれらがオプションと考えられている場合、ストリームパラメーターフィールドとストリームパラメーターCRCフィールドの両方とも廃棄されてよい。2バイトのストリームデータCRCフィールドはストリームデータだけのCRCを含む。このCRCが適切にチェックできない場合には、ストリームデータの使用は、応用例の要件に応じてオプションとなる。CRCが良好であることを条件としたストリームデータの使用は、通常、CRCが良好であると確認されるまで、ストリームデータをバッファに入れることを必要とする。CRCエラーカウントは、CRCがチェックしない場合に増分される。
D.カラーマップパケットの場合
2バイトのhClientIDフィールドは、過去に使用されたようにクライアントIDに予約される情報又は値を含む。このフィールドは通常将来の使用に予約されるので、現在の値はビットを「0」に設定することによってゼロに設定される。
2バイトのカラーマップアイテムカウントフィールドは、カラーマップデータフィールドに含まれる3バイトのカラーマップアイテム又はこのパケットの中のカラーマップデータに存在するカラーマップテーブルエントリの総数を指定するために値を使用する。この実施形態では、カラーマップデータのバイト数はカラーマップアイテムカウントの3倍である。カラーマップアイテムカウントは、カラーマップデータを送信しないためにゼロに等しく設定される。カラーマップサイズがゼロである場合には、カラーマップオフセット値は通常依然として送信されるが、それはディスプレイによって無視される。カラーマップオフセットフィールド(4バイト)は、クライアントデバイスのカラーマップテーブルの始まりからのこのパケット内のカラーマップデータのオフセットを指定する。
2バイトのパラメーターCRCフィールドは、パケット長から音声コーディングバイトまでのすべてのバイトのCRCを含む。このCRCがチェックできない場合、パケット全体が廃棄される。
カラーマップデータフィールドの場合、各カラーマップロケーションの幅はカラーマップアイテムサイズフィールドによって指定され、一実施形態では、第1の部分が青の規模を指定し、第2の部分が緑の規模を指定し、第3の部分が赤の規模を指定する。カラーマップサイズフィールドは、カラーマップデータフィールドに存在する3バイトのカラーマップテーブルアイテムの数を指定する。単一のカラーマップが1つのビデオデータフォーマットとカラーマップパケットの中に適合できない場合、カラーマップ全体が各パケット内に異なるカラーマップデータとカラーマップオフセットがある複数のパケットを送信することによって指定されてよい。各カラーマップデータアイテム内の青、緑及び赤のビット数は、一般的に表示機能パケットのカラーマップRGB幅フィールドに指定されるのと同じである。
2バイトのカラーマップデータCRCフィールドは、カラーマップデータだけのCRCを含む。このCRCがチェックできない場合、カラーマップデータは依然として使用できるが、CRCエラーカウントは増分される。
各カラーマップデータアイテムは、以下の順序で送信されなければならない。つまり、青、緑、赤で、各成分の最下位ビットが最初に送信される。各カラーマップアイテムの個々の赤、緑及び青の成分はパックされ、各カラーマップアイテム(青の成分の最下位ビット)はバイト位置合わせされる必要がある。図97は、6ビットの青、8ビットの緑、及び7ビットの赤のあるカラーマップデータアイテムの例を示す。この例の場合、カラーマップパケットのカラーマップアイテムサイズは21に等しく、クライアント機能パケットのカラーマップRGB幅フィールドは0x0786に等しい。
E.逆方向リンクカプセル化パケットの場合
パラメーターCRCフィールド(2バイト)は、パケット長から方向転換長までのすべてのバイトの16ビットCRCを含む。このCRCがチェックできない場合、パケット全体が廃棄される。
一実施形態では、逆方向リンクフラグフィールド(1バイト)は、クライアントから情報を要求するためにフラグのセットを含み、逆方向リンクタイプを指定する。ビット(例えばビット0)がロジック1レベルに設定されるなら、ホストはクライアントから指定された情報を要求するが、ビットがロジックゼロレベルに設定されるなら、ホストは、クライアントからの情報を必要としない。ビット0はホストがクライアント機能パケットを所望するときを示し、これは、一般的には、逆方向データパケットフィールでクライアントにより送信される。ビット1は、逆方向データパケットフィールドでクライアントによりホストに送信されるクライアント要求およびステータスパケットをホストが所望するときを示す。残りのビット(ここではビット1から7)は将来の使用のために予約され、ゼロに設定されている。しかしながら、逆方向リンクのためにフラグを設定するために所望されるようにさらに多くのビットを使用できる。
逆方向レート除数フィールド(1バイト)は、逆方向リンクデータクロックに関連して発生するMDDI_Stbサイクルの数を指定する。逆方向リンクデータクロックは、逆方向レート除数の2倍で除算される順方向リンクデータクロックに等しい。逆方向リンクデータレートは、逆方向リンクデータクロック関連し、逆方向リンクでのインターフェースタイプである。この実施形態において、タイプ1インターフェースの場合、逆方向データレートは逆方向リンクデータクロックに等しく、タイプ2、タイプ3及びタイプ4インターフェースの場合、逆方向データレートはそれぞれ逆方向リンクデータクロックの2倍、4倍及び8倍に等しい。
全ゼロ1フィールドは、ロジックゼロレベルでビットを設定することによって値の中のゼロに等しく設定されるバイトのグループ、ここでは8を含み、すべてのMDDI_Data信号が、クライアントが、方向転換1フィールドの間にホストのラインドライバーをディスエーブルする前にMDDI_Stbだけを使用してクロックの回復を開始できるほど十分な時間ロジックゼロレベルにあることを保証するために使用される。一実施形態では、全ゼロ1フィールドの長さはケーブルの往復遅延における順方向リンクバイト伝送回数以上である。
方向転換1長フィールド(1バイト)は、方向転換1に割り当てられるバイト総数を指定し、第1の方向転換期間を確立する。方向転換1フィールドは、方向転換1長パラメーターにより指定されるバイト数を採用し、ホスト内のラインドライバーがディスエーブルされる前に、クライアント内のMDDI_Dataラインドライバーイネーブル可能にするように割り当てられる。クライアントは、方向転換1のビット0の期間にMDDI_Dataラインドライバーをイネーブルにし、ホストは、方向転換1の最後のビットの前に完全にディスエーブルするようにその出力をディスエーブルする。MDDI_Stb信号は、あたかもMDDI_Data0が方向転換1期間全体でロジックゼロレベルにあるかのように動作する。方向転換1の設定のさらに完全な説明は前記に示されている。
逆方向データパケットフィールドはクライアントからホストへ転送される一連のデータパケットを含む。クライアントは、ホストに送信するデータがないときには、フィラーパケットを送信してよい、あるいはMDDI_Data線路をロジック−ゼロ状態またはレベルに駆動してよい。この実施形態において、MDDI_Data線路がゼロに駆動されると、ホストはこれをゼロ長(有効長ではない)のパケットとして解釈し、ホストは現在の逆方向リンクカプセル化パケットの持続期間中クライアントから追加のパケットを受け入れない。
方向転換2長フィールド(1バイト)は、第2の方向転換期間を確立するために方向転換2に割り当てられるバイトの総数を指定する。方向転換2の推奨される長さは、往復遅延のために要求されるバイト数プラスホストがMDDI_Dataドライバーをイネーブルにするのに必要な時間である。また方向転換2の長さは、ホスト内の逆方向リンクパケットを処理するための十分な時間を許容可能にするための最小の必要とされる値または計算された値より大きな値であってもよい。
方向転換2フィールドは、方向転換長パラメーターにより指定されるバイト数で構成される。ホストは、方向転換2の期間中にMDDI_Dataラインドライバーをイネーブルにする前に少なくとも往復遅延時間待つ。ホストはMDDI_Dataラインドライバーをイネーブルにし、それによりラインドライバーは一般的に方向転換2の最後のビットより前に完全にイネーブルになり、クライアントはその出力をディスエーブルにするので、出力は、方向転換2の最後のビットより前に一般的に完全にディスエーブルされる。方向転換2フィールドの目的は、逆方向データパケットフィールドからの残りのデータ量をクライアントから送信または転送可能にすることである。インターフェースを採用する異なるシステムの変化および割り当てられた安全マージンの量に対して、ホスト内のまたはホストにおけるラインドライバーにより見られるように、ホストまたはクライアントは、方向転換2フィールド期間のある部分の期間MDDI_Data信号をロジックレベルに駆動しないであろうことが可能である。MDDI_Stb信号は、あたかも実質的に全体の方向転換2期間にMDDI_data0がロジックゼロレベルであるかのように動作する。方向転換2の設定の記載は上述した。
逆データパケットフィールドは、クライアントからホストに転送される一連のデータパケットを含む。前述されたように、フィラーパケットは他のパケットタイプによって使用されていない残りの空間を充填するために送信される。
全ゼロ2フィールドは、ロジックゼロレベルでビットを設定することによって値のゼロに等しく設定されるバイトのグループ(この実施形態では8)を含み、すべてのMDDI_Data信号が、方向転換2フィールドの後にホストのラインドライバーをイネーブルしてから、MDDI_Data0とMDDIStbの両方を使用してクロックを回復できるほど十分な時間、ロジックゼロレベルとなることを保証するために使用される。
F.クライアント機能パケット用
一実施形態のために説明されているように、プロトコルバージョンフィールドは、クライアントによって使用されるプロトコルバージョンを指定する2バイトを使用する。最小プロトコルバージョンフィールドはクライアントが利用する又は解釈する最小プロトコルバージョンを指定するために2バイトを使用するが、初期のバージョンは現在1に等しく設定され、そして周知のように新しいバージョンが生成された場合、その時間にわたって変更されるであろう。この場合、0値はまた有効な値である。データレート機能フィールド(2バイト)は、クライアントがインターフェースの順方向リンクの各データ対上で受信できる最大データレートを指定し、毎秒メガバイト(Mbps)の形式で指定される。インターフェースタイプ機能フィールド(1バイト)は、順方向リンクと逆方向リンクでサポートされているインターフェースタイプを指定する。ビットを'1'に設定することは特定されたインターフェースタイプがサポートされることを示し、ビットを'0'に設定することは特定されたインターフェースタイプがサポートされないことを示す。ホストおよびクライアントは順方向および逆方向リンクにおいて少なくともタイプ1をサポートするであろう。インターフェースタイプの接続範囲をサポートする必要はない。例えばインターフェースにおいてタイプ3およびタイプ4ではなく、タイプ1およびタイプ3のみをサポートすることは完全に有効である。順方向および逆方向リンクについて、同じインターフェースタイプによって動作させることは必要としない。しかしながら、リンクはハイバネーションから出る場合、ホストおよびクライアントの両方により使用するために他のモードがネゴシエートされ、選択され、またはそうでなければ承認されるまでは、順方向および逆方向リンクの双方はタイプ1モードで動作を開始すべきである。
サポートされたインターフェースは一実施の形態において、順方向リンクにおいてそれぞれタイプ2(2ビット)、タイプ3(4ビット)またはタイプ4(8ビット)モードのいずれかを選択するために、ビット0、ビット1またはビット2を選択することにより、そして逆方向リンクにおいてそれぞれタイプ2、タイプ3またはタイプ4モードのいずれかを選択するためにビット3、ビット4またはビット5を選択することにより指示され、ビット6およびビット7は留保されそしてこの時点では通常0に設定される。Bitmap Width Heightフィールドはここではそれぞれ2バイトであり、ピクセル内のビットマップの幅と高さがそれぞれ特定される。
白黒機能フィールド(1バイト)は、一実施形態において、白黒フォーマットで表示できる解像度のビット数を指定するために使用される。ディスプレイが白黒フォーマットを使用できない場合は、この値はゼロで設定される。ビット7から4は将来の使用のために予約され、したがってゼロとして設定される。ビット3から0は、ピクセルごとに存在できるグレイスケールの最大ビット数を定義する。これらの4ビットにより、ピクセルごとに1から15の値を指定できるようになる。値がゼロである場合には、白黒フォーマットはディスプレイによってサポートされていない。
Bayer機能フィールドは、解像度、ピクセルグループ、及びBayerフォーマットで転送できるピクセル順序のビット数を指定するために1バイトを使用する。クライアントがBayerフォーマットを使用できない場合、この値はゼロである。Bayer機能フィールドは、以下の値から構成される。ビット5から4は必要とされるピクセルグループパターンを定義するが、ビット3から0は、各ピクセルに存在する輝度の最大ビット数を定義し、ビット8から6は必要とされるピクセル順序を定義し、ビット14から19は将来の使用ために予約されており、通常、当面ゼロに設定されている。ビット15は、ロジック−1レベルに設定されるとき、クライアントがパックフォーマット又はアンパックフォーマットのどちらかでBayerピクセルデータを受け入れることができることを示す。ビット15がゼロに設定されると、これはクライアントがアンパックフォーマットでのみBayerピクセルデータを受け入れることができることを示す。
カラーマップ機能フィールド(3バイト)は、ディスプレイのカラーマップテーブルに存在するテーブルアイテムの最大数を指定する。ディスプレイがカラーマップフォーマットを使用できない場合は、この値はゼロに設定される。
RGB機能フィールド(2バイト)は、RGBフォーマットで表示できる解像度のビット数を指定する。ディスプレイがRGBフォーマットを使用できない場合、この値はゼロに等しい。RGB機能ワードは3つの別々の符号なし値から構成され、ビット3から0は青の最大ビット数を定義し、ビット7から4は緑の最大ビット数を定義し、ビット11から8は各ピクセルの赤の最大ビット数を定義する。現在、ビット14から12は将来の使用のために予約され、通常ゼロに設定されている。ビット14から12は将来の使用のために予約され、通常ゼロに設定されている。ビット15は、ロジック−1レベルに設定されると、クライアントがパックフォーマット又はアンパックフォーマットのどちらかでカラーマップピクセルデータを受け入れることができることを示す。ビット15がロジック−ゼロレベルに設定されている場合、これは、クライアントがアンパックフォーマットでのみRGBピクセルデータを受け入れることができることを示す。
Y Cr Cb機能フィールド(2バイト)は、Y Cr Cbフォーマットで表示できる解像度のビット数を指定する。ディスプレイがY Cr Cbフォーマットを使用できない場合、この値はゼロに等しく設定される。Y Cr Cb機能ワードは3つの別々の符号なし値から構成され、ビット3から0は、Cbサンプルの最大ビット数を定義し、ビット7から4はCrサンプルの最大ビット数を定義し、ビット11から8はYサンプルの最大ビット数を定義し、ビット15から12は将来の使用のために予約され、ゼロに設定されている。
一実施形態において、クライアント特徴機能フィールドは、一実施形態においてサポートされているクライアントでの特定の特徴を示すフラグのセットを含む4バイトを使用する。ロジック1レベルに設定されたビットは機能がサポートされていることを示し、ロジックゼロレベルに設定されたビットは機能がサポートされていないことを示す。一実施形態において、ビット0の値は、ビットマップブロック転送パケット(パケットタイプ71)がサポートされているか否かを示す。ビット1、2、及び3の値は、ビットマップ領域塗りつぶしパケット(パケットタイプ72)、ビットマップパターン塗りつぶしパケット(パケットタイプ73)、又はリードフレームバッファパケット(パケットタイプ74)がそれぞれサポートされているかどうかを示す。ビット4の値は、透明カラーイネーブルパケットを使用し1つの色を透明にする機能がクライアントにあるかどうかを示す。ビット5と6の値は、クライアントがそれぞれアンパックまたはパックフォーマットで音声データを受け入れることができるかどうかを示し、ビット7の値は、クライアントがカメラから逆方向リンクビデオストリームを送信できるかどうかを示している。ビット8の値は、クライアントがピクセルデータの完全行を受信し、ビデオストリームパケットのピクセルデータ属性のビット5によって指定されるディスプレイアドレス指定を無視する能力を有するかどうかを示し、クライアントはピクセルデータ属性フィールドのビット15を介してビデオフレームデータのフレーム同期又は最後も検出できる。
ビット9の値は、クライアントが要求特定ステータスパケットを解釈し、有効ステータス応答リストパケットに応答する能力を有するか否かを示す。クライアントは、上述したように、有効ステータス応答リストパケットの有効パラメーター応答リストフィールドにさらなるステータスを戻す能力を示すことができる。ビット10の値は、クライアントがディスプレイ電力状態01をサポートする能力を有するか否かを示す。ディスプレイ電力状態は、上述したディスプレイ電力状態パケットの電力状態フィールドのビット[3:2]を用いて設定される。ディスプレイ電力状態01は、選択されたディスプレイが照射されず、もしあれば最小の電力量を消費している状態である。フレームバッファの内容は、一般的にこの状態の期間中維持されるように保証される。
ビット11と12の値は、いつクライアントがポインティングデバイスと通信中で、ポインティングデバイスデータパケットを送信、受信できるのか、あるいはキーボードを用いてそれぞれキーボードデータパケットを送信、受信できるのかを示す。ビット13の値は、VCP特徴パケットをサポートすることにより、クライアントが音声又はビデオパラメーターの1つ又は複数を設定する能力を有するかどうかを示す。つまりVCP特徴要求パケット、VCP特徴応答パケット、VCP設定特徴パケット、有効パラメーター要求パケット、及び有効パラメーター応答パケットである。ビット14の値は、クライアントがピクセルデータを図88Aに示すオフラインのディスプレイフレームバッファに書き込む能力を有するかどうかを示す。このビットがロジック1レベルに設定されると、表示更新ビット(ビデオストリームパケットのピクセルデータ属性のビット7と6)は01に設定されてよい。
ビット15の値は、クライアントがピクセルデータをディスプレイ画像を更新するために現在使用されているディスプレイフレームバッファにのみ書き込む能力を有する場合を示す。これは図88Bに示されている。このビットが1に設定された場合には、続いてDisplay Update Bit(ビデオストリームパケットのピクセルデータアトリビュートフィールドのビット7および6)は値'00'に設定することができる。ビット16に係る値は、何時クライアントが単一のビデオストリームパケットから図88Cに示す全てのディスプレイフレームバッファにピクセルデータを書き込む能力を有するかについて示す。このビットが1に設定された場合、Diplay Update Bit(ビデオストリームパケットのピクセルデータアトリビュートフィールドのビット7および6)を値'11'に設定することができる。
一実施形態において、ビット17の値は何時クライアントが要求特定状態パケットに応答する能力を有するかについて示し、 ビット18の値は何時クライアントが往復遅延測定パケットに応答する能力を有するかについて示し、ビット19の値は何時クライアントが順方向リンクスキュー較正パケットに応答する能力を有するかについて示し、そしてビット19の値は何時クライアントがVESA MCCS バーチャル制御パネル(VCP)パケットに応答する能力を有するかについて示す。一実施形態において、ビット20の値は、クライアントがディスプレイ電力状態パケットに応答する能力を持つときを示す。
一実施形態において、ビット21の値は、ビット0、1、および2またはこのフィールドにより指定されるクライアントによりこれらのパケットがサポートされるなら、ビットマップブロック転送パケット(パケットタイプ71)、ビットマップ塗りつぶしパケット(パケットタイプ72)およびビットマップパターン塗りつぶしパケット(パケットタイプ73)のラスタ演算を使用する能力を有するときを示す。一実施形態において、ビット21がロジックゼロレベルまたはゼロ値を有し、パケットがサポートされているなら、クライアントは、ラスタ演算を使用する能力を有しておらず、クライアントは、これらのパケットにより指定されるピクセルロケーションにコピーするまたは書き込む能力を有するにすぎない。
ビット22の値は、クライアントが登録アクセスパケットに応答する能力を有するか否か示す。ビット23乃至31は将来の使用またはシステム設計者に有用な代替指定の現在予約され、一般的にゼロ値またはロジックゼロレベルに等しく設定されている。
表示ビデオフレーム機能フィールドは、1バイトを使うこの実施形態において、毎秒フレーム単位でディスプレイの最大ビデオフレーム更新機能を指定する。ホストは、このフィールドで指定される値より低速で画像の更新を選んでよい。
音声バッファ深度フィールド(2バイト)は、各音声ストリーム専用であるディスプレイ内の弾性バッファの深度を指定する。
音声チャネル機能フィールドは、2バイトを使うこの実施形態において、どの音声チャネルがクライアントまたはクライアント接続装置によってサポートされるのかを示すフラグのグループを含む。1に設定されるビットは、チャネルがサポートされていることを示し、ゼロに設定されているビットは、そのチャネルがサポートされていないことを示す。ビット位置は様々なチャネルに割り当てられる。例えば、一実施形態におけるビット位置0、1、2、3、4、5、6、及び7は、左前チャネル、右前チャネル、左後チャネル、右後チャネル、前中心チャネル、サブウーファーチャネル、サラウンド左チャネルとサラウンド右チャネルを示している。ビット8から14は、将来の使用のために現在予約されており、通常ゼロに設定されている。一実施の形態において、ビット15はクライアントが順方向音声チャネルイネーブルパケットに関するサポートを提供するかどうかを示すために使用される。もし係る状態の場合、ビット15はロジック1レベルに設定される。しかしながらクライアントが、順方向音声チャネルイネーブルパケットの結果として、オーディオチャンネルを機能させないようにする能力が無い場合、またはクライアントが如何なるオーディオ機能についてもサポートしない場合、このビットはロジック0レベルまたは0値に設定される。
順方向リンク用の2バイトの音声サンプルレート機能フィールドは、クライアントデバイスの音声サンプルレート機能を示すためにフラグのセットを含む。ビット位置は、さまざまな速度に相応して割り当てられ、例えばビット0、1、2、3、4、5、6、7及び8は、それぞれ8,000、16,000、24,000、32,000、40,000、48,000、11,025、22,050及び44,100毎秒サンプル(SPS)であり、ビット9から15は将来の又は代替レートの使用のために予約されているので、それらは現在「0」に設定されている。これらのビットの内の1つの値を「1」に設定すると、その特定のサンプルレートがサポートされていることを示し、ビットを「0」に設定すると、そのサンプルレートはサポートされていないことを示す。
最小サブフレームレートフィールド(2バイト)は、毎秒フレーム単位で最小サブフレームレートを指定する。最小サブフレームレートは、クライアントステータス更新レートをクライアント内の特定のセンサ又はポインティングデバイスを読み取るのに十分に保つ。
2バイトのマイクサンプルレート機能フィールドは、逆方向リンクの場合、クライアントデバイス内のマイクの音声サンプルレート機能を示すフラグのセットを含む。MDDIのために、クライアントデバイスマイクは少なくとも毎秒8,000サンプルレートを最小でサポートするように構成される。このフィールドのビット位置は、例えばそれぞれ8,000、16,000、24,000、32,000、40,000、48,000、11,025、22,050、及び44,100毎秒サンプル(SPS)を表すために使用されているビット位置0、1、2、3、4、5、6、7及び8の様々な速度に割り当てられ、ビット9から15は、所望されるように将来又は代替レートの使用のために予約されているため、現在は「0」に設定されている。これらのビットの1つのビット値を「1」に設定すると、その特定のサンプルレートがサポートされていることを示し、ビットを「0」に設定すると、そのサンプルレートがサポートされていないことを示している。マイクが接続されていない場合、マイクサンプルレート機能ビットのそれぞれはゼロに等しく設定される。
キーボードデータフォーマットフィールド(ここでは1バイト)はキーボードがクライアントシステムに接続されているか否かおよび接続されているキーボードの型式について指定する。一実施の形態において、ビット6乃至0によって設定された値は接続されているキーボードの型式を規定するために使用される。値がゼロ(0)の場合キーボードの型式は知られていないと考えられる。1の値に関しては、キーボードデータフォーマットは標準のPS−2スタイルと考えられる。現時点において2乃至125の範囲の値は使用されておらず、MDDIおよび対応するクライアントまたはホストの使用のための特有のキーボードまたは入力装置について規定するため、システム設計者およびインターフェース設立者または製品開発者の使用のために留保される。126の値はキーボードデータフォーマットが使用者によって定義されることを示すために使用され、一方127の値はキーボードがこのクライアントに接続することができないことを示すために使用される。加えて、ビット7はキーボードがクライアントと通信することができるか否かを示すために使用することができる。このビットについて意図される使用は、何時キーボードは無線リンクを使用するクライアントと通信可能であるかを示すことにある。ビット6乃至0がキーボードがクライアントに接続できないことを示す場合、ビット7は0レベルに設定されるであろう。それ故に、一実施の形態において、ビット7の値が0のとき、キーボードとクライアントは通信できず、一方、ビット7の値が1のとき、キーボードとクライアントはこれらが互いに通信できることを確認する。
ポインティングデバイスデータフォーマットフィールド(ここでは1バイト)はポインティングデバイスがクライアントシステムに接続されるか否か、および接続されるポインティングデバイスの型式を規定する。一実施の形態において、ビット6によって設定される値は接続されるポインティングデバイスの型式を規定するために使用される。値がゼロ(0)の場合、ポインティングデバイスの型式は知られていないと考えられる。1の値に関し、ポインティングデバイスデータフォーマットは標準のPS−2スタイルであると考えられる。現時点において2乃至125の範囲の値は使用されておらず、MDDインターフェースおよび対応するクライアントまたはホストの使用のための特有のポインティングデバイスまたは入力装置について規定するため、システム設計者およびインターフェース設立者または製品開発者の使用のために留保される。126の値はポインティングデバイスデータフォーマットが使用者によって定義されることを示すために使用され、一方127の値はポインティングデバイスはこのクライアントに接続することができないことを示すために使用される。加えて、ビット7は、ポインティングデバイスがクライアントと通信できるか否かを示すために使用することができる。このビットの意図する使用は何時キーボードはクライアントと無線リンクを使用して通信できるかを示すことにある。ビット6乃至0がポインティングデバイスがクライアントに接続できないことを示す場合、ビット7はゼロレベルに設定されるであろう。それ故に一実施の形態において、ビット7の値が0の場合、ポインティングデバイスとクライアントは通信することができず、一方ビット7の値が1の場合、ポインティングデバイスとクライアントはこれらが互いに通信できることを確認する。
コンテンツ保護タイプフィールド(2バイト)は、ディスプレイによってサポートされるデジタルコンテンツ保護のタイプを示すフラグのセットを含む。現在、ビット位置0は、いつDTCPがサポートされているのかを示すために使用され、ビット位置1はいつHDCPがサポートされているのかを示すために使用され、ビット位置2から15は所望されるように、又は使用可能なように他の保護方式での使用のために予約されているため、それらは現在ゼロに設定されている。
Mfr Name−2バイトは、VESA EDID仕様と同様の方法で、3つの5ビットキャラクタにパックされた製品のEISA3−キャラクタIDを含む。キャラクタ'A'は00001バイナリとして表現される。キャラクタ'Z'は11010バイナリとして表現される。そして'A'と'Z'との間の全ての文字は'A'および'Z'間のアルファベットのシーケンスに対応する連続する2進値として表現される。Mfr Nameフィールドの最上位のビットは使用されず、そして一般に将来の実施において使用がなされるまでロジック−0に設定される。例えば、ストリング"XYZ"によって表現される製造業者は0x633aのMfr Name値を有するであろう。このフィールドがクライアントによってサポートされていない場合は、これはゼロに設定されるであろう。製品コードフィールドはディスプレイ製造業者によって割り当てられた製品コードを含むため2バイトを使用する。このフィールドがクライアントによってサポートされない場合、これは一般にロジック−ゼロレベルに設定される。
留保された1、留保された2、そして留保された3フィールド(ここではそれぞれ2バイト)は情報を伝えるための将来の使用のために設定される。このフィールドの全てのビットは一般にゼロに設定される。かかるフィールドの目的は一般に、全ての後で生ずる2バイトフィールドを16−ビットワードアドレスに位置合わせさせることであり、そして4−バイトフィールドを32−ビットワードアドレスに位置合わせさせることである。
この実施形態において、連続番号フィールドは4バイトを使用し、これはディスプレイの連続番号を数字の形式で特定する。このフィールドがクライアントによってサポートされない場合、これは一般にゼロに設定される。製造の週フィールドは、ディスプレイの製造の週を特定するために1バイトを使用する。これがクライアントによってサポートされた場合、この値は1乃至53の範囲とされる。もしこれがクライアントによってサポートされない場合、この値はゼロに設定される。製造の年フィールドは1バイトであり、これはディスプレイの製造の年を規定する。この値は1990年からのオフセットである。1991乃至2245の範囲の年はこのフィールドによって表現できる。例:2003年は製造値13年に対応する。このフィールドがクライアントによってサポートされない場合は、これはゼロに設定される。
CRCフィールドは(ここでは2バイト)パケット長を含むパケット内の全バイトの16−ビットCRCを含む。
G.クライアント要求及びステータスパケット
逆方向リンク要求フィールド(3バイト)は、クライアントが、ホストに情報を送信するために次のサブフレームの逆方向リンクで必要とするバイト数を指定する。
CRCエラーカウントフィールド(1バイト)は、メディアフレームの開始以来どのくらいの数のCRCエラーが発生したのかを示す。CRCカウントは、ゼロというサブフレームカウントを有するサブフレームヘッダーパケットが送信されるとリセットされる。CRCエラーの実際の数が255を超えると、この値は通常255で飽和する。
機能変更フィールドは、クライアントの機能の変化を示すために1バイトを使用する。これは、ユーザが、マイク、キーボード、又はディスプレイ、あるいは何らかの他の理由から周辺装置を接続する場合に発生するであろう。ビット「7:0」が0に等しいときには、機能は最後のクライアント機能パケットが送信されて以来変化しなかった。しかしながら、ビット[7:0]が1から255に等しいとき、機能は変更した。クライアント機能パケットは、新しい表示特性を決定するために調べられる。
クライアントビジーフラッグフィールドは、2バイトを用いて、クライアントが特定の機能を実行しており、その機能に関連する別のパケットを受け入れるための準備がまだできていないことを示す。ロジック1レベルまたは値に設定されるビットは、特定の機能が現在実行されており、クライアント内の関連する機能はビジーであることを示す。クライアント内の関連機能がレディ状態なら、ビットはロジックゼロに設定される。クライアントは、クライアント内でサポートされていないすべての機能に対してビジー状態(1に設定されたビット)を戻さなければならない。
一実施形態において、これらのバイトは、以下の関係に従って解釈される。ビット0が「1」なら、ビットマップブロック転送機能はビジーであり、一方、ビット1が「1」であるなら、ビットマップエリア塗りつぶし機能はビジーであり、ビット2が「1」であるなら、ビットマップパターン塗りつぶし機能はビジーである。同時にビット3が「1」なら、グラフィックサブシステムは、ビジーであり、クライアント内のフレームバッファの使用を必要とする動作を実行する。フレームバッファの使用を必要とする他のグラフィック機能は、このビットがロジック1に設定されるまで開始しないかもしれない。
現在ビット4乃至15は、将来の使用のために予約され、一般的にロジック1レベルまたは状態に設定され、これらのビットが将来割り当てられる場合にビジー状態を示す。
H.ビットブロック転送パケットの場合
ウィンドウ左上座標X値フィールドとY値フィールドは、移動するウィンドウの左上角の座標のX値とY値を指定するために、それぞれ2バイトを使用する。ウィンドウ幅フィールドとウィンドウ高さフィールドは、移動するウィンドウの幅と高さを指定するためにそれぞれ2バイトを使用する。ウィンドウX移動フィールドとY移動フィールドは、ウィンドウがそれぞれ水平と垂直に移動されるピクセル数を指定するために、それぞれ2バイトを使用する。Yの正の値はウィンドウを下方に移動させ、負の値は上方に移動させるが、通常、これらの座標は、Xの正の値によりウィンドウが右に移動し、負の値により左に移動するように構成されている。
I.ビットマップ領域塗りつぶしパケット
一実施形態において、2バイトピクセルデータ属性フィールドは、ピクセルデータが更新される場所を指定する値を有する。ビット1および0は、ピクセルデータが更新されるディスプレイを選択する。クライアント内の一次ディスプレイがステレオ画像をサポートしないなら、クライアントは、ビットの組み合わせ01、10、または11の1つに対して一次ディスプレイ内のピクセルデータに影響を及ぼすことができる。ステレオ表示機能をサポートしないクライアント内の一次ディスプレイをアドレスするために値11を使用することが推奨される。ビット「1:0」が値11(ロジック1、ロジック1)を有するとき、ピクセルデータは、左目および右目の両方のフレームバッファ内で更新される。ビット「1:0」値10(ロジック1、ロジックゼロ)を有するなら、左目だけのフレームバッファ内でピクセルデータが更新される。ビット「1:0」が値01(ロジックゼロ、ロジック1)を有するとき、右目だけのフレームバッファにおいてピクセルデータが更新される。ビット[1:0]が値00(ダブルロジックゼロ)を有するとき、以下のビット8乃至11により指定される代替ディスプレイのフレームバッファにおいてピクセルデータが更新される。
一実施形態において、ピクセルデータ属性フィールドのビット2は、左目または右目のためのバッファがこの演算のための画像のソースであるか否かを指定する。ビット「1:0」が00に等しくないとき、ビット2のみが適用される。これは、画像のデスティネーションが代替ディスプレイの1つであるときこれは、メイン画像からのソースデータをサポートしないことを意味するように一般的に実施される。ビット2は、データソースとして左目フレームバッファまたは右目フレームバッファ間で区別化または指定するために使用される。ビット2がロジック0(ロジックゼロレベル)に等しいとき、左目フレームバッファは、データソースであるが、ビット2が1(ロジック1レベル)に等しいとき、右目フレームバッファはデータソースである。
ピクセルデータ属性フィールドのビット3は、ディスプレイをリフレッシュするために使用されるバッファまたはオフライン画像バッファがこの演算のための画像のソースになるかどうかを指定する。代替ディスプレイがオフライン画像バッファを利用するなら、ビット3はまた代替ディスプレイに適用されてもよい。しかしながら、これは、画像のデスティネーションが代替ディスプレイであるとき、逆の場合も同じであるとき、メイン画像バッファからのソースデータをサポートしない。ビット3が0の値またはロジックゼロレベルであるとき、ディスプレイをリフレッシュするために使用される画像バッファは、データソースである。ビット3が1の値またはロジック1レベルに等しいとき、オフライン画像バッファはデータソースである。
ピクセルデータ属性フィールドのビット7および6は、ピクセルデータが更新されるまたは書かれるフレームバッファを指定するディスプレイ更新ビットとして作用する。フレーム更新ビットの効果は、上により詳細に記載されている。ビット「7:6」が「01」(ロジックゼロ、ロジック1)であるとき、ピクセルデータは、オフライン画像バッファに書かれる。ビット[7:6]が「00」(ダブルロジックゼロ)であるとき、ピクセルデータは、ディスプレイをリフレッシュするために使用される画像バッファに書かれる。ビット「7:6」が「11」(ダブルロジック1)であるとき、ピクセルデータは、すべての画像バッファに書かれる。ビット「7:6」が「10」なら、これは無効な値として取り扱われる。これらのビットは現在、将来の使用のために予約される。この状況で、全体のコマンドは無視され、フレームバッファは更新されない。
ピクセルデータ属性フィールドのビット11乃至8は、ピクセルデータが更新される代替ディスプレイまたは代替クライアントロケーションを指定する4ビットの符号なしの整数を形成する。ビット0および1は、クライアントがビット11乃至8を代替ディスプレイ番号として解釈するために00(ダブルロジックゼロ)の値に等しく設定される。ビット1およびビット0が00に等しくないなら、ビット8乃至11は、一般的にロジックゼロ値またはロジックゼロレベルに等しく設定される。ビット4乃至5およびビット12乃至15は、将来の使用のために予約され、一般的にロジックゼロレベルまたはロジックゼロ値に設定される。
一実施形態において、2バイトラスタ演算フィールドは、どのようにしてソースおよびデスティネーションロケーションにおけるピクセルを結合してデスティネーショ画像ロケーションに書かれる新しいピクセル値を形成する。ラスタ演算は、どのようにしてフレームバッファ内における等しいサイズの2つの異なる矩形領域が一緒にマージされるのかを定義する。また、デスティネーション画像領域は、一緒にマージされる2つの画像の1つでもある。2つの画像の2番目は、ソース画像と呼ばれる。クライアントが、クライアント機能パケット内で指定されたラスタ演算フィールドをサポートしないなら、ホストは一般的に3に等しいビット3乃至0を有したパケットを送信し、クライアントはビット3乃至0を無視する。
一実施形態において、ビット3乃至0は、その値の次に示される対応する演算を選択するために以下の表XVIに示される値の1つに等しいビット3乃至0を用いてまたは設定することにより実際のラスタ演算を指定するために使用される。すなわち、第1列にリストアップされた各指定されたビット[3:0]は、第2列で指定された演算を結果として生じる。さらにここでは、明確化のために第3列に定義される。
Figure 2014053920
ビット5乃至4は、デスティネーションピクセルが、透明色に関連するデスティネーションロケーションに書かれるか否かを指定するために使用される。ビット5乃至4により指定される演算は、ラスタ演算がクライアント装置によりサポートされるか否かに適用される。クライアントがラスタ演算をサポートしないなら、ビット5乃至4により定義される演算に対して考慮される結果として生じるデスティネーションピクセル値は、ソースピクセル値のみに等しい。
ビット「5:4」の値が00に等しいなら、透明色は使用されない。結果として生じるデスティネーションピクセルは、透明色イネーブルパケットにより定義される透明色の値を考慮することなしに、デスティネーションピクセルロケーションに書かれる。01に等しいビット[5:4]の値は、現在、将来の使用のために予約され、典型的には、使用されていない。だけれども、そのための関連した使用を確立することは当業者に利用可能である。ビット[5:4]の値が10に等しいとき、ラスタ演算により計算された結果として生じるデスティネーションピクセルが透明色に等しいなら、結果として生じるピクセルは、デスティネーションピクセルロケーションに書かれない。さもなければ、それはデスティネーションピクセルロケーションに書かれる。ビット[5:4]の値が11に等しいとき、ラスタ演算により計算された結果として生じるデスティネーションピクセルが透明色に等しいなら、結果として生じるピクセルはデスティネーションピクセルロケーションに書かれない。さもなければ、結果として生じるピクセルはデスティネーションピクセルロケーションに書かれない。
ビット15乃至16は将来の使用のために予約され、それゆえ一般的には、ロジックゼロ値またはレベルに等しく設定される。
J.ビットマップパターン塗りつぶしパケットの場合
一実施形態において、ビットマップパターン塗りつぶしパケット内の左上座標X値とY値は2バイトを使用し、各バイトは、塗りつぶすウィンドウの左上隅の座標のXおよびY値を指定する。ウィンドウ幅フィールドおよびウィンドウ高さフィールド(各々2バイト)は、塗りつぶすウィンドウの幅と高さを指定する。パターン幅フィールドおよびパターン高さフィールド(各々2バイト)は、それぞれ塗りつぶしパターンの幅と高さを指定する。水平パターンオフセットフィールド(2バイト)は、塗りつぶす指定されたウィンドウの左端縁からのピクセルデータパターンの水平オフセットを指定する。指定されている値は、パターン幅フィールド内の値未満である。垂直パターンオフセットフィールド(2バイト)は、塗りつぶす指定されたウィンドウの上端縁からのピクセルデータパターンの垂直オフセットを指定する。指定されている値はパターン高さフィールド内の値未満である。
一実施形態において、2バイトピクセルデータ属性フィールドは、ピクセルデータが更新される場所を指定する値を有し、ビット1および0はピクセルデータが更新されるディスプレイを選択する。クライアント内の一次ディスプレイはステレオ画像をサポートしないなら、クライアントは、ビットの組み合わせ01、10または11の1つのための一次ディスプレイ内のピクセルデータに影響を及ぼすことができる。ステレオ表示能力をサポートしないクライアント内の一次ディスプレイをアドレスするために値11を使用することが推奨される。ビット[1:0]が値11(ロジック1、ロジック1)を有するとき、左目と右目の両方のフレームバッファ内でピクセルデータが更新され、ビット[1:0]は値10(ロジック1、ロジック0)を有するなら、ピクセルデータは、左目のみのフレームバッファ内で更新される。ビット[1:0]が値01(ロジックゼロ、ロジック1)を有するとき、ピクセルデータは右目のみのフレームバッファ内で更新される。ビット[1:0]が値00(ダブルロジックゼロ)を有するとき、ピクセルデータは、以下のビット8乃至11により指定される代替ディスプレイのフレームバッファ内で更新される。
一実施形態において、ピクセルデータ属性フィールドのビット2は、左目または右目のためのバッファがこの演算のための画像のソースであるか否かを指定する。ビット[1:0]が00に等しくないとき、ビット2のみが適用される。これは一般的に、画像のデスティネーションが代替ディスプレイの1つであるとき、これは、メイン画像からのソースデータをサポートしないことを意味するために実施される。ビット2は、データソースとして、左目フレームバッファおよび右目フレームバッファの間として区別するまたは指定するために使用される。ビット2が0(ロジックゼロレベル)に等しいとき、左目フレームバッファがデータソースであるが、ビット2が1(ロジック1レベル)に等しいとき、右目フレームバッファがデータソースである。
ピクセルデータ属性フィールドのビット3は、ディスプレイをリフレッシュするために使用されるディスプレイまたはオフライン画像バッファがこの演算のための画像のソースであるかどうかを指定する。また、ビット3は、代替ディスプレイがオフライン画像バッファを利用するなら代替ディスプレイに適用される。しかしながら、これは、画像のデスティネーションが代替ディスプレイであるときまたはその逆も同様のとき、メイン画像バッファからのソースデータをサポートしない。ビット3が0の値またはロジックゼロレベルに等しいとき、ディスプレイをリフレッシュするために使用される画像バッファはデータソースである。ビット3が1の値またはロジック1レベルに等しいとき、オフライン画像バッファはデータソースである。
ピクセルデータ属性フィールドのビット7および6は、ピクセルデータが更新されるまたは書かれるフレームバッファを指定するディスプレイ更新ビットとして作用する。フレーム更新ビットの効果は、より詳細に上に記載されている。ビット[7:6]が「01」(ロジックゼロ、ロジック1)であるとき、ピクセルデータは、オフライン画像バッファに更新される。ビット「7:6]が(ダブルロジックゼロ)であるとき、ピクセルデータはディスプレイをリフレッシュするために使用される画像バッファに書かれる。ビット[7:6]が「11」(ダブルロジック1)であるとき、ピクセルデータは、すべての画像バッファにおいて更新される。ビット[7:6]が「10」なら、これは無効値として取り扱われる。これらのビットは現在、将来の使用のために予約される。この状況において、全体のコマンドは無視されフレームバッファは更新されない。
ピクセルデータ属性フィールドのビット11乃至8は、ピクセルデータが更新されるディスプレイまたは代替クライアントロケーションを指定する。ビット0と1は、クライアントがビット11乃至8を代替ディスプレイ番号として解釈するように00(ダブルロジックゼロ)の値に等しく設定される。ビット1および0が00に等しくないなら、ビット8乃至11は、一般的にロジックゼロ値またはレベルに等しく設定される。ビット4乃至5および12乃至15は、将来のために予約され、一般的には、ロジックゼロレベルまたは値に設定される。
一実施形態において、2バイトラスタ演算フィールドは、どのようにしてソースロケーションおよびデスティネーションロケーションにおいてピクセルを結合し、デスティネーション画像ロケーションに書かれる新しいピクセル値を形成するかを指定する。ラスタ演算は、どのようにしてフレームバッファ内の等しいサイズの2つの異なる矩形の領域を一緒にマージするかを定義する。また、デスティネーション画像領域は、一緒にマージされた2つの画像の一方である。
2つの画像の2番目はソース画像と呼ばれる。クライアントが、クライアント機能パケットで指定されるラスタ演算をサポートしないなら、ホストは3に等しいビット3乃至0を有するこのパケットを一般的に送信し、クライアントはビット3乃至0を無視する。
一実施形態において、その値の次に示される対応する演算を選択するために表XVIIに示される値の1つに等しくビット3乃至0を用いてまたは設定することにより実際のラスタ演算を指定するためにビット3乃至0が使用される。すなわち、第1列にリストアップされたビット[3:0]は、第2列で指定される演算を生じ、第3列において明確化のためにさらに定義される。
Figure 2014053920
ビット5乃至4は、透明色に関連しているので、デスティネーションピクセルがデスティネーションロケーションに書かれるか否かを指定するために使用される。ビット5乃至4により指定される演算は、ラスタ演算がクライアント装置によりサポートされるにせよされないにせよ適用される。クライアントがラスタ演算をサポートしないなら、ビット5乃至4により定義される演算に対して考慮される結果として生じるデスティネーションピクセル値はソースピクセル値のみに等しい。
ピクセルデータ属性フィールドのビット[5:4]の値が00に等しいとき、透明色は使用されない。結果として生じるデスティネーションピクセルは、透明色イネーブルパケットにより定義される透明色の値を考慮せずにデスティネーションピクセルロケーションに書かれる。01に等しいビット[5:4]の値は現在、将来の使用のために予約され、典型的に使用されていない。しかし、関連する使用を確立するために当業者により利用可能である。ビット[5:4]の値が10に等しいとき、ラスタ演算により計算された結果として生じたデスティネーションピクセルが透明色に等しいなら、結果として生じるピクセルはデスティネーションピクセルロケーションに書かれない。さもなければ、それはデスティネーションピクセルロケーションに書かれる。ビット[5:4]の値が11に等しいとき、ラスタ演算により計算された結果として生じるデスティネーションピクセルが透明色に等しいなら、結果として生じるピクセルはデスティネーションピクセルロケーションに書かれない。さもなければ、結果として生じるピクセルは、デスティネーションピクセルロケーションに書かれない。
ビット15乃至6は将来の使用のために予約され、それゆえ、一般的には、ロジックゼロ値またはレベルに等しく設定される。
一実施形態において、ビットマップ塗りつぶしパケット内の2バイトパラメーターCRCフィールドは、パケット長からビデオフォーマットディスクリプタまでのすべてのバイトのCRCを含む。このCRCがチェックに失敗するなら、全体のパケットが破棄される。パターンピクセルデータフィールドは、ビデオデータフォーマットディスクリプタにより指定されるフォーマットで塗りつぶしパターンを指定する生のビデオ情報を含む。データはバイトにパックされ、各行の第1ピクセルはバイト合わせされている。塗りつぶしパターンデータは一度に1行の割合で送信される。ビットマップパターン塗りつぶしパケットのためのパターンピクセルデータCRCフィールドは、パターンピクセルデータのみのCRCを含む2バイトを使用する。このCRCがチェックに失敗するなら、パターンピクセルデータは、依然として使用することができるが、CRCエラーカウントはインクリメントされる。
K.順方向音声チャネルイネーブルパケット
音声チャネルイネーブルマスクフィールド(1バイト)は、どの音声チャネルがクライアントでイネーブルされなければならないのかを示すフラグのグループを含む。1に設定されるビットは、対応するチャネルをイネーブルし、ゼロに設定されるビットは対応するチャネルをディスエーブルする。ビット0から5は、それぞれ左前チャネル、右前チャネル、左後チャネル、右後チャネル、前中心チャネル、及びサブウーファーチャネルをアドレス指定するチャネル0から5を指定する。ビット6と7は、将来の使用のために予約されており、当面は通常ゼロに等しく設定されている。
L. 逆方向音声サンプルレートパッケージ
音声サンプルレートフィールド(1バイト)はデジタル音声サンプルレートを指定する。このフィールドの値は様々な速度に割り当てられ、0、1、2、3、4、5、6、7、及び8という値は8,000、16,000、24,000、32,000、40,000、48,000、11,025、22,050、及び44,100毎秒サンプル(SPS)を示すために使用され、9から254という値は、所望されるように代替速度を使用するために予約されているため、それらは現在は「0」に設定されている。255という値は逆方向リンク音声ストリームをディスエーブルするために使用される。
サンプルフォーマットフィールド(1バイト)は、デジタル音声サンプルのフォーマットを指定する。ビット[1:0]が[0]に等しいとき、デジタル音声サンプルは線形フォーマットを取り、それらが1に等しい時には、デジタル音声サンプルはμ法則フォーマットを取る。それらが2に等しいとき、デジタル音声サンプルはA−法則フォーマットである。ビット[7:2]は、所望されるように、音声フォーマットを指定する上での代替使用に予約されており、通常はゼロに等しく設定されている。
M. デジタルコンテンツ保護オーバヘッドパケット用
コンテンツ保護タイプフィールド(1バイト)は、使用されるデジタルコンテンツ保護方法を指定する。1という値は高帯域幅デジタルコンテンツ保護システム(HDCP)を示すが、「0」という値はデジタル伝送コンテンツ保護(DTCP)を示す。2から255という値は、現在指定されていいないが、所望されるように代替保護方式との使用のために予約されている。コンテンツ保護オーバヘッドメッセージフィールドは、ホストとクライアントの間で送信されるコンテンツ保護メッセージを含む可変長のフィールドである。N.往復遅延測定パケット2バイトのパケット長フィールドは、パケット長フィールドを含まないパケット内のバイト総数を指定し、一実施形態では、159という固定長を有するように選択されている。このパケットタイプを82という値で識別する2バイトのパケットタイプフィールドは、往復遅延測定パケットとしてパケットを識別する。hClient IDフィールドは、前記のように、クライアントIDとして将来使用するために予約されており、通常ゼロに設定されている。
一実施形態では、パラメーターCRCフィールド(2バイト)は、パケット長からパケットタイプまでのすべてのバイトの16ビットCRCを含む。このCRCがチェックできない場合、パケット全体が廃棄される。
ガード時間1フィールド(ここでは64バイト)は、クライアントのMDDI_Dataラインドライバーが、ホストのラインドライバーがディスエーブルされる前にイネーブルできるようにするために使用される。クライアントは、ガード時間1のビット0の間にそのMDDI_Dataラインドライバーをイネーブルにし、ホストはガード時間1の最後のビットの前に完全にディスエーブルされるようにそのラインドライバーをディスエーブルする。
ホストとクライアントは、それらがディスエーブルされていないとき、共にガード時間1の間にロジックゼロレベルを駆動する。このフィールドの別の目的は、すべてのMDDI_Data信号が、クライアントが、ホストのラインドライバーをディスエーブルする前にMDDI_Stbだけを使用して、クロック又はクロック信号の回復を開始できるほど十分な時間ロジックゼロレベルにあることを保証することである。
測定期間フィールドは、クライアントが、順方向リンクで使用されるデータレートの半分で、0xffという2つのバイト、及び0x0という30バイトに応答できるようにするために使用される64バイトのウィンドウである。
このデータレートは1という逆方向リンクレート除数に相当する。クライアントは、それが測定期間の始まりであると知覚するとただちにこの応答を返す。このクライアントからの応答は、正確にリンクの往復遅延に、ホストでの測定期間の第1のビットの開始後のクライアントのロジック遅延を加えたもので、ホストで受信される。
全ゼロフィールド(2バイト)は、ホストとクライアント内のMDDI_Dataラインドライバーが、MDDI_Dataが常に駆動されるように重複できるようにするためにゼロを含んでいる。ホストは、オールゼロ1フィールドのビット0の期間MDDIデータラインドライバーをイネーブルにし、また、クライアントは、測定期間の終わりで行ったように信号をロジックゼロレベルに駆動し続ける。
ガード時間2フィールド(64バイト)の値は、往復遅延が測定期間で測定できる最大量であるときにクライアントによって駆動される測定期間の重複を可能にする。クライアントはそのラインドライバーをガード時間2のビット0の間にディスエーブルし、ホストはガード時間2の最後のビットの直後にそのラインドライバーをイネーブルする。ホストとクライアントの両者とも、それらがディスエーブルされていないときガード時間2の間にロジックゼロレベルを駆動する。このフィールドの別の目的は、すべてのMDDI_Data信号が、クライアントが、ホストのラインドライバーをイネーブルした後に、MDDI_Data0とMDDI_Stbの両方を使用してクロック信号の回復を開始できるほど十分な時間ロジックゼロレベルにいることを保証することである。
O.順方向リンクスキュー校正パケット
一実施形態では、パラメーターCRCフィールド(2バイト)は、パケット長からパケットタイプまでのすべてのバイトの16ビットCRCを含む。このCRCがチェックできないと、パケット全体が廃棄される。
オールゼロ1フィールドは8バイトを使用して、較正データシーケンスフィールドの始めでMDDI Stb上に遷移があることを保証する。一般に、これらのバイトは8ビットの符号なしのゼロに等しい整数を採用する。それはまた、クライアントコアロジックがMDDI_0およびMDDI_StbのXORを使用することからクロックリカバリ回路のモードを変化させる、または他のリカバーされたクロックとしてMDDI_StbまたはMDDI_Stb信号を用いるための十分な時間を提供する。
校正データシーケンスフィールドは、MDDI_Data信号をデータ期間ごとにトグルさせるデータシーケンスを含む。校正データシーケンスフィールドの長さは順方向リンクにおいて使用されるインターフェースにより決定される。校正データシーケンスの処理中、MDDIホストコントローラーはすべてのMDDI_Data信号をストローブ信号に等しく設定する。校正データシーケンスフィールドはクライアントによって受信されているが、クライアントクロック回復回路は、データクロックを回復するためにMDDI_Stb XorMDDI_Data0よりむしろMDDI_Stbだけを使用するべきである。校正データシーケンスフィールドの始まりのMDDI_Stb信号の正確な位相に応じて、校正データシーケンスは通常、このパケットが送信されるときに使用されるインターフェースタイプに基づいて、以下の1つとなる。
タイプI−(64バイトデータシーケンス)0xaa,oxaa...or0x55,0x55...
タイプII−(128バイトデータシーケンス)0xcc,0xcc...or0x33,0x33...
タイプIII−(256バイトデータシーケンス)0xf0,0xf0...or0x0f,0xf0...
タイプIV−(512バイトデータシーケンス)0xff,0x00,0xff,0x00...0r0x00,0xff,0x00,0xff
オールゼロ2フィールドは8バイトを用いて、クライアントコアロジックが、リカバーされたクロックとしてMDDI_Stb信号を使用することから、MDDI_0とMDDI_StbのXORを使用することまで、クロックリカバリ回路のモードをオリジナルの状態に戻すのに十分な時間を提供する。一般的に、これらのバイトは、8ビットの符号なしのゼロに等しい整数を採用する。
タイプ1インターフェースとタイプ2インターフェース両方のためのMDDI_Data波形とMDDI_Stb波形の例は、それぞれ図62Aと図62Bに示されている。
XIX. 結論
本発明の多様な実施形態は前述されてきたが、それらが例証としてのみ提示され、制限ではないことが理解されるべきである。したがって、本発明の幅及び範囲は、前述された例示的な実施形態のいずれによっても制限されるべきではなく、添付請求項及びその同等物に従ってのみ定義されるべきである。
図1Aは、ポータブルコンピューター又は他のデータ処理装置と関連する、マイクロディスプレイ装置又はプロジェクターの使用を含む、本発明の実施形態が動作する可能性がある基本的な環境を示す図である。 図1Bは、マイクロディスプレイ装置又はプロジェクター、及び無線トランシーバと関連して使用される音声プレゼンテーション要素の使用を含む、本発明の実施形態が動作する可能性のある基本的な環境を示す図である。 図2Aは、ポータブルコンピューターで使用される内蔵ディスプレイ又は音声プレゼンテーション装置の使用を含む、本発明の実施形態が動作する可能性のある基本的な環境を示す図である。 図2Bは、無線トランシーバで使用される内蔵ディスプレイ要素又は音声プレゼンテーション要素の使用を含む、本発明が動作する可能性のある基本的な環境を示す図である。 図3は、ホストとクライアント相互接続のMDDIの全体的な概念を示す図である。 図4は、クライアントデバイスからホストデバイスへのデータ転送を実現するために有効なパケットの構造を示す図である。 図5は、MDDIリンクコントローラーの使用、及びタイプ1インターフェース用物理データリンク導線上でのホストとクライアント間で受け渡される信号の種類を示す図である。 図6は、MDDIリンクコントローラーの使用、及びタイプ2インターフェース、タイプ3インターフェース、及びタイプ4インターフェース用の物理データリンク導線上で、ホストとクライアントの間で受け渡される信号の種類を示す図である。 図7は、インターフェースプロトコルを実現するために使用されるフレームとサブフレームの構造を示す図である。 図8は、インターフェースプロトコルを実現するために使用されるパケットの一般構造を示す図である。 図9は、サブフレームヘッダーパケットのフォーマットを示す図である。 図10は、フィラーパケットのフォーマット及びコンテンツを示す図である。 図11は、ビデオストリームパケットのフォーマットを示す図である。 図12Aは、図11で使用されるビデオデータフォーマットディスクリプタのフォーマットとコンテンツを示す図である。 図12Bは、図11で使用されるビデオデータフォーマットディスクリプタのフォーマットとコンテンツを示す図である。 図12Cは、図11で使用されるビデオデータフォーマットディスクリプタのフォーマットとコンテンツを示す図である。 図12Dは、図11で使用されるビデオデータフォーマットディスクリプタのフォーマットとコンテンツを示す図である。 図12Eは、図11で使用されるビデオデータフォーマットディスクリプタのフォーマットとコンテンツを示す図である。 図13は、データのパックフォーマットとアンパックフォーマットの使用を示す図である。 図14は、音声ストリームパケットのフォーマットを示す図である。 図15は、データのためのバイト位置合わせされたPCMフォーマットとパックされたPCMフォーマットの使用を示す図である。 図16は、ユーザにより定義されるストリームパケットのフォーマットを示す図である。 図17は、カラーマップパケットのフォーマットを示す図である。 図18は、逆方向リンクカプセル化パケットのフォーマットを示す図である。 図19クライアント機能パケットのフォーマットを示す図である。 図20は、キーボードデータパケットのフォーマットを示す図である。 図21は、ポインティングデバイスデータパケットのフォーマットを示す図である。 図22は、リンクシャットダウンパケットのフォーマットを示す図である。 図23は、クライアント要求ステータスパケットのフォーマットを示す図である。 図24は、ビットマップブロック転送パケットのフォーマットを示す図である。 図25は、ビットマップ領域塗りつぶしパケットのフォーマットを示す図である。 図26は、ビットマップパターン塗りつぶしパケットのフォーマットを示す図である。 図27は、リードフレームバッファパケットのフォーマットを示す図である。 図28は、ディスプレイ電力状態パケットのフォーマットを示す図である。 図29は、実行型ハンドオフパケットのフォーマットを示す図である。 図30は、順方向音声チャネルイネーブルパケットのフォーマットを示す図である。 図31は、逆方向音声サンプルレートパケットのフォーマットを示す図である。 図32は、デジタルコンテンツ保護オーバヘッドパケットのフォーマットを示す図である。 図33は、透明色イネーブルパケットのフォーマットを示す図である。 図34は、往復遅延測定パケットのフォーマットを示す図である。 図35は、往復遅延測定パケットの間のイベントのタイミングを示す図である。 図36は、本発明を実現するために有効なCRCジェネレータ及びチェッカのサンプルインプリメンテーションを示す図である。 図37Aは、データパケットを送信するときの図36の装置のCRC信号のタイミングを示す図である。 図37Bは、データパケットを受信するときの図36の装置のCRC信号のタイミングを示す図である。 図38は、競合のない典型的なサービス要求のための処理ステップを示す図である。 図39は、リンク起動を競合する、リンク再起動シーケンスが開始した後に確かめられた典型的なサービス要求の処理ステップを示す図である。 図40は、DATA−STB符号化を使用してどのようにしてデータシーケンスを送信できるかを示す図である。 図41は、ホストで入力データからDATA信号とSTB信号を発生させ、その後クライアントでデータを回復するために有効な回路網を示す図である。 図42は一実施形態を実現するために有効なドライバーと終端レジスタを示す図である。 図43Aは、ホストからサービスを保証するためにクライアントによって、及びこのようなサービスを提供するためにホストによって利用されるステップ及び信号レベルを示す図である。 図43Bは、ホストからサービスを保証するためにクライアントによって、及びこのようなサービスを提供するためにホストによって利用されるステップ及び信号レベルを示す図である。 図43Cは、ホストからサービスを保証するためにクライアントによって、及びこのようなサービスを提供するためにホストによって利用されるステップ及び信号レベルを示す図である。 図44は、Data0、他のデータライン(DataX)、及びストローブライン(Stb)での遷移間の相対的な間隔を示す図である。 図45は、ホストが、パケット転送後にホストドライバーをディスエーブルするときに発生することがある応答の遅延の存在を示す図である。 図46は、ホストが、ホストドライバーがパケットを転送できるようにイネーブルするときに発生することがある応答の遅延の存在を示す図である。 図47は漏れ電流解析を示す図である。 図48は、スイッチング特性およびホストとクライアントの出力イネーブルおよびディスエーブル時間のための相対的関係を示す図である。 図49は、状態機械を使用して同期を実現できる信号処理ステップと条件の高水準図である。 図50は、MDDIを利用するシステムでの順方向経路と逆方向経路での信号処理について遭遇される典型的な遅延量を示す図である。 図51は境界の往復遅延測定を示す図である。 図52Aは逆方向リンクデータレート変化を示す図である。 図52Bは、進歩した逆方向データサンプルの一例を示す図である。 図53は、逆方向速度除数対順方向リンクデータレートの値のグラフィック表現を示す図である。 図54Aは、インターフェースの動作で講じられるステップを示す図である。 図54Bは、インターフェースの動作で講じられるステップを示す図である。 図55は、インターフェース装置処理パケットの概要を示す図である。 図56は、順方向リンクパケットのフォーマットを示す図である。 図57は、タイプ1リンクインターフェースの伝搬遅延及びスキューの典型的な値を示す図である。 図58は、インターフェースを通じた例示的な信号処理のためのタイプ1リンクのData、Stb、及びクロック回復タイミングを示す図である。 図59は、タイプ2、タイプ3又はタイプ4リンクインターフェースの伝搬遅延及びスキューのための典型的な値を示す図である。 図60Aは、互いに関して2つのデータ信号とMDDI_Stbがそれぞれ理想的、早い、遅い場合の異なる可能性を示す図である。 図60Bは、互いに関して2つのデータ信号とMDDI_Stbがそれぞれ理想的、早い、遅い場合の異なる可能性を示す図である。 図60Cは、互いに関して2つのデータ信号とMDDI_Stbがそれぞれ理想的、早い、遅い場合の異なる可能性を示す図である。 図61はタイプ1/タイプ2インターフェースと共に使用されるインターフェースピン割り当て例示コネクタを示す図である。 図62Aは、タイプ1インターフェースのための考えられるMDDI_Data波形とMDDI_Stb波形を示す図である。 図62Bは、タイプ2インターフェースのための考えられるMDDI_Data波形とMDDI_Stb波形を示す図である。 図63は、状態機械を使用して同期を実現できる代替の信号処理ステップと条件の高水準図を示す図である。 図64は、一連のクロックサイクルの間の相対的なタイミングと、多様な逆方向リンクパケットビットと除数値のタイミングとを示す図である。 図65は、例示的なエラーコード転送処理を示す図である。 図66は、エラーコード転送処理に有効な装置を示す図である。 図67Aは、コード過負荷のためのエラーコード転送処理を示す図である。 図67Bは、コード受信のためのエラーコード転送処理を示す図である。 図68Aは、ホストによって起動されるウェイクアップのための処理ステップを示す図である。 図68Bは、クライアントによって起動されるウェイクアップのための処理ステップを示す図である。 図68Cは、ホストと、競合状態のあるクライアントによって起動されるウェイクアップのための処理ステップを示す図である。 図69は、要求バーチャルコントロールパネル(VCP)特徴パケットのフォーマットを示す図である。 図70は、VCP特徴応答パケットのフォーマットを示す図である。 図71は、VCP特徴応答パケットリストのフォーマットを示す図である。 図72は、セットVCP特徴応答パケットのフォーマットを示す図である。 図73は、要求有効パラメーターパケットのフォーマットを示す図である。 図74は、有効パラメーター応答パケットのフォーマットを示す図である。 図75は、スケーリング済みのビデオストリーム機能パケットのフォーマットを示す図である。 図76は、スケーリング済みのビデオストリームセットアップパケットのフォーマットを示す図である。 図77は、スケーリング済みのビデオストリームアクノレッジパケットのフォーマットを示す図である。 図78は、スケーリング済みのビデオストリームパケットのフォーマットを示す図である。 図79は、特殊ステータス要求パケットのフォーマットを示す図である。 図80は、有効ステータス応答リストパケットのフォーマットを示す図である。 図81は、パーソナルディスプレイ機能パケットのフォーマットを示す図である。 図82は、フィールド屈曲のポイントリスト内のエレメントを示す図である。 図83は、クライアントエラーレポートパケットのフォーマットを示す図である。 図84は、エラーレポートリストアイテムのフォーマットを示す図である。 図85は、クライアント識別パケットのフォーマットを示す図である。 図86は、代替表示機能パケットのフォーマットを示す図である。 図87は、レジスタアクセスパケットのフォーマットを示す図である。 図88Aは、可視アーチファクトを削減するための2つのディスプレイバッファの使用を示す図である。 図88Bは、可視アーチファクトを削減するための2つのディスプレイバッファの使用を示す図である。 図88Cは、可視アーチファクトを削減するための2つのディスプレイバッファの使用を示す図である。 図89は、画像転送より高レートのディスプレイリフレッシュ付きの2つのバッファを示す図である。 図90は、画像転送より低速のディスプレイリフレッシュ付きの2つのバッファを示す図である。 図91は、画像転送よりはるかに高レートのディスプレイリフレッシュ付きの2つのバッファを示す図である。 図92は、画像転送より高レートのディスプレイリフレッシュ付きの3つのバッファを示す図である。 図93は、画像転送より低速のディスプレイリフレッシュ付きの3つのバッファを示す図である。 図94は、画像転送より高レートのディスプレイリフレッシュ付きの1つのバッファを示す図である。 図95は、デイジーチェーンとハブを介するホスト−クライアント接続を示す図である。 図96は、ハブとデイジーチェーンの組み合わせを介して接続されるクライアントデバイスを示す図である。 図97は、カラーマップを示す図である。
XIX. 結論
本発明の多様な実施形態は前述されてきたが、それらが例証としてのみ提示され、制限ではないことが理解されるべきである。したがって、本発明の幅及び範囲は、前述された例示的な実施形態のいずれによっても制限されるべきではなく、添付請求項及びその同等物に従ってのみ定義されるべきである。
以下に、出願当初の特許請求の範囲に記載された発明を付記する。
[C1]
通信路を介してホスト装置とクライアント装置との間で高レートでデジタルプレゼンテーションデータを転送するためのデジタルデータインターフェースにおいて、
前記通信路を介してホストとクライアントとの間であらかじめ選択されたデジタル制御およびプレゼンテーションデータのセットを通信するための通信プロトコルを形成するために一緒にリンクされた複数のパケット構造と、
前記通信路を介して前記クライアントに接続された前記ホスト装置内に常駐する少なくとも1つのリンクコントローラーであって、前記通信プロトコルを形成するパケットを発生し、送信し、受信するように、およびプレゼンテーションデータを1つ以上のタイプのデータパケットに形成するように構成された少なくとも1つのリンクコントローラーと、
を備えたデジタルデータインターフェース。
[C2]
前記ホストとクライアントの間で通信され、異なる可変長を有する所定数の前記パケットを備える、所定の固定長を有する、メディアフレーム内で共にグループ化される前記パケットをさらに備える、C1に記載のインターフェース。
[C3]
前記ホストからのパケットの転送の始めに配置されるサブフレームヘッダーパケットをさらに備える、C1に記載のインターフェース。
[C4]
特定のクライアントに関連するハードウェアを低電力状態に設定するためのディスプレイ電力状態パケットをさらに備えた、C1のインターフェース。
[C5]
前記リンクコントローラーはホストリンクコントローラーであって、前記通信路を介して前記ホストに接続される前記クライアントデバイスに常駐する少なくとも1つのクライアントリンクコントローラーであって、前記通信プロトコルを形成するパケットを生成し、送信し及び受信し、デジタルプレゼンテーションデータを1つ以上のタイプのデータパケットに形成するように構成される少なくとも1つのクライアントリンクコントローラーをさらに備えた、C1に記載のインターフェース。
[C6]
それぞれが既定の期間に並列でデータの異なる最大数のビットの転送を可能にする複数の転送モードであって、各モードが前記ホストリンクドライバーとクライアントリンクドライバーの間の交渉により選択可能である、複数の転送モードをさらに備え、
前記転送モードはデータの転送中に前記モードの間で動的に調整可能である、C2に記載のインターフェース。
[C7]
前記通信路上、どちらかの方向でデータの転送を終了するために、前記ホストによる前記クライアントに対する伝送のためのリンクシャットダウンタイプパケットをさらに備える、C1に記載のインターフェース。
[C8]
前記クライアントがハイバネーション状態から前記ホストをウェイクアップするための手段をさらに備える、C1に記載のインターフェース。
[C9]
ユーザへのプレゼンテーションのために通信路上、ホストデバイスとクライアントデバイスの間において高レートでデジタルデータを転送する方法であって、
複数の所定のパケット構造の内の1つ又は複数を生成し、所定の通信プロトコルを形成するためにそれらを共にリンクすることと、
前記通信プロトコルを使用して、前記通信路上、前記ホストデバイスと前記クライアントデバイスの間で、デジタル制御データとデジタルプレゼンテーションデータの事前に選択されたセットを通信することと、
前記通信プロトコルを形成するパケットを生成、送信及び受信し、1つ又は複数のタイプのデータパケットにデジタルプレゼンテーションデータを形成するように構成される、前記ホストデバイスに常駐する少なくとも1台のホストリンクコントローラーを、前記通信路を介して前記クライアントデバイスに接続することと、
前記リンクコントローラーを使用して前記通信路上でパケットの形を取るデータを転送することと、
を備える方法。
[C10]
前記ホストとクライアント間の通信のために、異なる可変長を有する所定数の前記パケットを備える、所定の固定長を有するメディアフレーム内で、前記パケットを共にグループ化することをさらに備える、C9に記載の方法。
[C11]
サブフレームヘッダタイプパケットを用いる前記ホストからのパケットの転送を開始することをさらに備える、C9に記載の方法。
[C12]
前記通信路を介して前記ホスト装置に接続された前記クライアント装置に常駐する少なくとも1つのクライアントリンクコントローラーを介して前記通信プロトコルを形成するパケットを生成し、送信し、受信することをさらに備えた、C9の方法。
[C13]
前記ホストリンクドライバーと前記クライアントリンクドライバーの間で、それぞれが既定の期間において並列で異なる最大ビット数のデータの転送を可能にする、各方向での複数の転送モードの1つの使用を交渉することと、
データの転送中、前記転送モードの間で動的に調整することと、
をさらに備える、C12に記載の方法。
[C14]
前記クライアントへの前記ホストによる伝送のために、リンクシャットダウンタイプのパケットを使用して前記通信路においてどちらかの方向でデータの転送を終了することをさらに備える、C12に記載の方法。
[C15]
前記クライアントとの通信によりハイバネーション状態から前記ホストをウェイクアップすることをさらに備える、C9に記載の方法。
[C16]
特定のクライアントハードウェアを低電力状態に設定するためにディスプレイ電力状態パケットを生成することをさらに備えた、C9の方法。
[C17]
ユーザへのプレゼンテーションのために通信路上、ホストデバイスとクライアントデバイスの間において高レートでデジタルデータを転送するための装置において、
複数の所定のパケット構造の1つ又は複数を生成し、所定の通信プロトコルを形成するためにそれらを共にリンクするために、及び前記通信プロトコルを使用して前記通信路上、前記ホストデバイスと前記クライアントデバイスの間でデジタル制御データとデジタルプレゼンテーションデータの事前に選択されたセットを通信するために、前記ホストデバイス内に配置される少なくとも1つのホストリンクコントローラーと、
前記クライアントデバイスに配置され、前記通信路を介して前記ホストリンクコントローラーに接続される、少なくとも1つのクライアントコントローラーと、
前記通信プロトコルを形成するパケットを生成、送信及び受信し、デジタルプレゼンテーションデータを1つ又は複数のタイプのデータパケットに形成するように構成される、各リンクコントローラーと、
を備える、装置。
[C18]
前記ホストコントローラーは状態機械を備える、C17に記載の装置。
[C19]
前記ホストコントローラーは汎用信号プロセッサを備える、C17に記載の装置。
[C20]
前記ホストからのパケットの転送の開始時にサブフレームヘッダタイプパケットをさらに備える、C17に記載の装置。
[C21]
前記ホストコントローラーは1台又は複数台の差動ラインドライバーを備え、前記クライアントレシーバは前記通信路に接続される1台又は複数台の差動ラインレシーバを備える、C17に記載の装置。
[C22]
前記ホストリンクコントローラーとクライアントリンクコントローラーは、それぞれが既定の期間において、並列で異なる最大ビット数のデータの転送を可能にする、各方向での複数の転送モードの1つを使用するように構成され、データの転送中、前記転送モードの間で動的に調整することができる、C17に記載の装置。
[C23]
前記ホストコントローラーは、前記通信路上、どちらかの方向でデータの転送を終了するために、前記クライアント手段にリンクシャットダウンタイプのパケットを送信するように構成される、C17に記載の装置。
[C24]
前記ホストコントローラーは、特定のディスプレイコントローラーハードウェアを低電力状態に設定するためにディスプレイ電力状態パケットを生成するように構成される、C17の装置。
[C25]
ユーザに対するプレゼンテーションのために通信路上、ホストデバイスとクライアントデバイスの間において、高レートでデジタルデータを転送するための電子システムでの使用のために、
アプリケーションプログラムを前記コンピューターシステム上で実行させるために、前記媒体で具現化されるコンピューター読み取り可能プログラムコード手段を有するコンピューター使用可能な媒体を備える、コンピュータープログラム製品であって、前記コンピューター読み取り可能プログラムコード手段は、
コンピューターシステムに複数の所定のパケット構造の1つ又は複数を生成させ、所定の通信プロトコルを形成するために、それらを共にリンクさせるためのコンピューター読み取り可能第1プログラムコード手段と、
前記コンピューターシステムに、前記通信プロトコルを使用して前記通信路上、前記ホストデバイスと前記クライアントデバイスの間で、デジタル制御データとデジタルプレゼンテーションデータの事前に選択されたセットを通信させるための、コンピューター読み取り可能第2プログラムコード手段と、
前記コンピューターシステムに、前記通信路を通して、前記ホストデバイスに配置される少なくとも1台のホストリンクコントローラーを、前記クライアントデバイスに配置される少なくとも1台のクライアントコントローラーに結合させるようにするための、コンピューター読み取り可能第3プログラムコード手段であって、前記リンクコントローラーは、前記通信プロトコルを形成するパケットを生成、送信及び受信し、1つ又は複数のタイプのデータパケットにデジタルプレゼンテーションデータを形成するように構成される、コンピューター読み取り可能第3プログラムコード手段と、
前記リンクコントローラーを使用して前記通信路上、パケットの形をしたデータをコンピューターシステムに転送させるためのコンピューター読み取り可能第4プログラムコード手段と、
を備える、コンピュータープログラムプロダクト。
[C26]
コンピューターシステムに所定のパケット構造を生成させ、それらを一緒にリンクさせ所定の通信プロトコルを形成させるためのコンピューター読み取り可能プログラムコード手段を備えた、C25のコンピュータープログラムプロダクト。
[C27]
ユーザに対するプレゼンテーションのために、通信路上、ホストデバイスとクライアントデバイスの間において、高レートでデジタルデータを転送するための装置において、
複数の所定のパケット構造の1つ又は複数を生成し、所定の通信プロトコルを形成するためにそれらを共にリンクするための手段と、
前記通信プロトコルを使用して前記通信路で前記ホストデバイスと前記クライアントデバイスの間で、事前に選択されたデジタル制御データ及びデジタルプレゼンテーションデータを通信するための手段と、
前記ホストとクライアントのそれぞれに1つ、それぞれが前記通信プロトコルを形成するパケットを生成、送信及び受信し、デジタルプレゼンテーションデータを1つ又は複数のタイプのデータパケットに形成するように構成される、少なくとも2台のリンクコントローラーを、前記通信路を介して共に接続するための手段と、
前記リンクコントローラーを使用して前記通信路上、パケットの形をとるデータを転送するための手段と、
を備える、装置。
[C28]
サブフレームヘッダタイプパケットを用いて、前記ホストからパケットの転送を開始するための手段をさらに備えた、C27に記載の装置。
[C29]
特定のハードウェアを低電力状態に設定するように構成されたディスプレイ電力状態パケットを生成する手段をさらに備えた、C27の装置。
[C30]
前記クライアントが前記インターフェースを介してどのようなタイプのデータとデータレートに対処できるのかを決定するために、ホストリンクコントローラーによってクライアントから表示機能情報を要求するための手段をさらに備えた、C27に記載の装置。
[C31]
通信路上、ホストデバイスとクライアントデバイスの間において、高レートでデジタルデータを転送するための電子システムで使用するためのプロセッサであって、複数の所定のパケット構造の1つ又は複数を生成し、所定の通信プロトコルを形成するためにそれらを共にリンクし、デジタルプレゼンテーションデータを1つ又は複数のタイプのデータパケットに形成し、前記通信プロトコルを使用して前記通信路上、前記ホストデバイスと前記クライアントデバイスの間で、デジタル制御データとデジタルプレゼンテーションデータの事前に選択されたセットを通信し、前記通信路上でパケットの形をしたデータを転送するように構成された、プロセッサ。
[C32]
通信路上、ホストデバイスとクライアントデバイスの間において、高レートでデジタルデータを転送するための電子システムで使用するための状態機械であって、前記状態機械は、少なくとも1つのAsync Frames State同期化状態と、少なくとも2つのAcquiring Sync State同期状態と、少なくとも3つのIn-Sync States同期状態を有するように構成される状態機械。
[C33]
通信路上、ホストデバイスとクライアントデバイスの間において、高レートでデジタルデータを転送するための電子システムで使用するための状態機械であって、前記状態機械は、少なくとも1つのAcquiring Sync States同期状態と、少なくとも2つのIn-Sync States同期状態を有するように構成される状態機械。

Claims (33)

  1. 通信路を介してホスト装置とクライアント装置との間で高レートでデジタルプレゼンテーションデータを転送するためのデジタルデータインターフェースにおいて、
    前記通信路を介してホストとクライアントとの間であらかじめ選択されたデジタル制御およびプレゼンテーションデータのセットを通信するための通信プロトコルを形成するために一緒にリンクされた複数のパケット構造と、
    前記通信路を介して前記クライアントに接続された前記ホスト装置内に常駐する少なくとも1つのリンクコントローラーであって、前記通信プロトコルを形成するパケットを発生し、送信し、受信するように、およびプレゼンテーションデータを1つ以上のタイプのデータパケットに形成するように構成された少なくとも1つのリンクコントローラーと、
    を備えたデジタルデータインターフェース。
  2. 前記ホストとクライアントの間で通信され、異なる可変長を有する所定数の前記パケットを備える、所定の固定長を有する、メディアフレーム内で共にグループ化される前記パケットをさらに備える、請求項1に記載のインターフェース。
  3. 前記ホストからのパケットの転送の始めに配置されるサブフレームヘッダーパケットをさらに備える、請求項1に記載のインターフェース。
  4. 特定のクライアントに関連するハードウェアを低電力状態に設定するためのディスプレイ電力状態パケットをさらに備えた、請求項1のインターフェース。
  5. 前記リンクコントローラーはホストリンクコントローラーであって、前記通信路を介して前記ホストに接続される前記クライアントデバイスに常駐する少なくとも1つのクライアントリンクコントローラーであって、前記通信プロトコルを形成するパケットを生成し、送信し及び受信し、デジタルプレゼンテーションデータを1つ以上のタイプのデータパケットに形成するように構成される少なくとも1つのクライアントリンクコントローラーをさらに備えた、請求項1に記載のインターフェース。
  6. それぞれが既定の期間に並列でデータの異なる最大数のビットの転送を可能にする複数の転送モードであって、各モードが前記ホストリンクドライバーとクライアントリンクドライバーの間の交渉により選択可能である、複数の転送モードをさらに備え、
    前記転送モードはデータの転送中に前記モードの間で動的に調整可能である、請求項2に記載のインターフェース。
  7. 前記通信路上、どちらかの方向でデータの転送を終了するために、前記ホストによる前記クライアントに対する伝送のためのリンクシャットダウンタイプパケットをさらに備える、請求項1に記載のインターフェース。
  8. 前記クライアントがハイバネーション状態から前記ホストをウェイクアップするための手段をさらに備える、請求項1に記載のインターフェース。
  9. ユーザへのプレゼンテーションのために通信路上、ホストデバイスとクライアントデバイスの間において高レートでデジタルデータを転送する方法であって、
    複数の所定のパケット構造の内の1つ又は複数を生成し、所定の通信プロトコルを形成するためにそれらを共にリンクすることと、
    前記通信プロトコルを使用して、前記通信路上、前記ホストデバイスと前記クライアントデバイスの間で、デジタル制御データとデジタルプレゼンテーションデータの事前に選択されたセットを通信することと、
    前記通信プロトコルを形成するパケットを生成、送信及び受信し、1つ又は複数のタイプのデータパケットにデジタルプレゼンテーションデータを形成するように構成される、前記ホストデバイスに常駐する少なくとも1台のホストリンクコントローラーを、前記通信路を介して前記クライアントデバイスに接続することと、
    前記リンクコントローラーを使用して前記通信路上でパケットの形を取るデータを転送することと、
    を備える方法。
  10. 前記ホストとクライアント間の通信のために、異なる可変長を有する所定数の前記パケットを備える、所定の固定長を有するメディアフレーム内で、前記パケットを共にグループ化することをさらに備える、請求項9に記載の方法。
  11. サブフレームヘッダタイプパケットを用いる前記ホストからのパケットの転送を開始することをさらに備える、請求項9に記載の方法。
  12. 前記通信路を介して前記ホスト装置に接続された前記クライアント装置に常駐する少なくとも1つのクライアントリンクコントローラーを介して前記通信プロトコルを形成するパケットを生成し、送信し、受信することをさらに備えた、請求項9の方法。
  13. 前記ホストリンクドライバーと前記クライアントリンクドライバーの間で、それぞれが既定の期間において並列で異なる最大ビット数のデータの転送を可能にする、各方向での複数の転送モードの1つの使用を交渉することと、
    データの転送中、前記転送モードの間で動的に調整することと、
    をさらに備える、請求項12に記載の方法。
  14. 前記クライアントへの前記ホストによる伝送のために、リンクシャットダウンタイプのパケットを使用して前記通信路においてどちらかの方向でデータの転送を終了することをさらに備える、請求項12に記載の方法。
  15. 前記クライアントとの通信によりハイバネーション状態から前記ホストをウェイクアップすることをさらに備える、請求項9に記載の方法。
  16. 特定のクライアントハードウェアを低電力状態に設定するためにディスプレイ電力状態パケットを生成することをさらに備えた、請求項9の方法。
  17. ユーザへのプレゼンテーションのために通信路上、ホストデバイスとクライアントデバイスの間において高レートでデジタルデータを転送するための装置において、
    複数の所定のパケット構造の1つ又は複数を生成し、所定の通信プロトコルを形成するためにそれらを共にリンクするために、及び前記通信プロトコルを使用して前記通信路上、前記ホストデバイスと前記クライアントデバイスの間でデジタル制御データとデジタルプレゼンテーションデータの事前に選択されたセットを通信するために、前記ホストデバイス内に配置される少なくとも1つのホストリンクコントローラーと、
    前記クライアントデバイスに配置され、前記通信路を介して前記ホストリンクコントローラーに接続される、少なくとも1つのクライアントコントローラーと、
    前記通信プロトコルを形成するパケットを生成、送信及び受信し、デジタルプレゼンテーションデータを1つ又は複数のタイプのデータパケットに形成するように構成される、各リンクコントローラーと、
    を備える、装置。
  18. 前記ホストコントローラーは状態機械を備える、請求項17に記載の装置。
  19. 前記ホストコントローラーは汎用信号プロセッサを備える、請求項17に記載の装置。
  20. 前記ホストからのパケットの転送の開始時にサブフレームヘッダタイプパケットをさらに備える、請求項17に記載の装置。
  21. 前記ホストコントローラーは1台又は複数台の差動ラインドライバーを備え、前記クライアントレシーバは前記通信路に接続される1台又は複数台の差動ラインレシーバを備える、請求項17に記載の装置。
  22. 前記ホストリンクコントローラーとクライアントリンクコントローラーは、それぞれが既定の期間において、並列で異なる最大ビット数のデータの転送を可能にする、各方向での複数の転送モードの1つを使用するように構成され、データの転送中、前記転送モードの間で動的に調整することができる、請求項17に記載の装置。
  23. 前記ホストコントローラーは、前記通信路上、どちらかの方向でデータの転送を終了するために、前記クライアント手段にリンクシャットダウンタイプのパケットを送信するように構成される、請求項17に記載の装置。
  24. 前記ホストコントローラーは、特定のディスプレイコントローラーハードウェアを低電力状態に設定するためにディスプレイ電力状態パケットを生成するように構成される、請求項17の装置。
  25. ユーザに対するプレゼンテーションのために通信路上、ホストデバイスとクライアントデバイスの間において、高レートでデジタルデータを転送するための電子システムでの使用のために、
    アプリケーションプログラムを前記コンピューターシステム上で実行させるために、前記媒体で具現化されるコンピューター読み取り可能プログラムコード手段を有するコンピューター使用可能な媒体を備える、コンピュータープログラム製品であって、前記コンピューター読み取り可能プログラムコード手段は、
    コンピューターシステムに複数の所定のパケット構造の1つ又は複数を生成させ、所定の通信プロトコルを形成するために、それらを共にリンクさせるためのコンピューター読み取り可能第1プログラムコード手段と、
    前記コンピューターシステムに、前記通信プロトコルを使用して前記通信路上、前記ホストデバイスと前記クライアントデバイスの間で、デジタル制御データとデジタルプレゼンテーションデータの事前に選択されたセットを通信させるための、コンピューター読み取り可能第2プログラムコード手段と、
    前記コンピューターシステムに、前記通信路を通して、前記ホストデバイスに配置される少なくとも1台のホストリンクコントローラーを、前記クライアントデバイスに配置される少なくとも1台のクライアントコントローラーに結合させるようにするための、コンピューター読み取り可能第3プログラムコード手段であって、前記リンクコントローラーは、前記通信プロトコルを形成するパケットを生成、送信及び受信し、1つ又は複数のタイプのデータパケットにデジタルプレゼンテーションデータを形成するように構成される、コンピューター読み取り可能第3プログラムコード手段と、
    前記リンクコントローラーを使用して前記通信路上、パケットの形をしたデータをコンピューターシステムに転送させるためのコンピューター読み取り可能第4プログラムコード手段と、
    を備える、コンピュータープログラムプロダクト。
  26. コンピューターシステムに所定のパケット構造を生成させ、それらを一緒にリンクさせ所定の通信プロトコルを形成させるためのコンピューター読み取り可能プログラムコード手段を備えた、請求項25のコンピュータープログラムプロダクト。
  27. ユーザに対するプレゼンテーションのために、通信路上、ホストデバイスとクライアントデバイスの間において、高レートでデジタルデータを転送するための装置において、
    複数の所定のパケット構造の1つ又は複数を生成し、所定の通信プロトコルを形成するためにそれらを共にリンクするための手段と、
    前記通信プロトコルを使用して前記通信路で前記ホストデバイスと前記クライアントデバイスの間で、事前に選択されたデジタル制御データ及びデジタルプレゼンテーションデータを通信するための手段と、
    前記ホストとクライアントのそれぞれに1つ、それぞれが前記通信プロトコルを形成するパケットを生成、送信及び受信し、デジタルプレゼンテーションデータを1つ又は複数のタイプのデータパケットに形成するように構成される、少なくとも2台のリンクコントローラーを、前記通信路を介して共に接続するための手段と、
    前記リンクコントローラーを使用して前記通信路上、パケットの形をとるデータを転送するための手段と、
    を備える、装置。
  28. サブフレームヘッダタイプパケットを用いて、前記ホストからパケットの転送を開始するための手段をさらに備えた、請求項27に記載の装置。
  29. 特定のハードウェアを低電力状態に設定するように構成されたディスプレイ電力状態パケットを生成する手段をさらに備えた、請求項27の装置。
  30. 前記クライアントが前記インターフェースを介してどのようなタイプのデータとデータレートに対処できるのかを決定するために、ホストリンクコントローラーによってクライアントから表示機能情報を要求するための手段をさらに備えた、請求項27に記載の装置。
  31. 通信路上、ホストデバイスとクライアントデバイスの間において、高レートでデジタルデータを転送するための電子システムで使用するためのプロセッサであって、複数の所定のパケット構造の1つ又は複数を生成し、所定の通信プロトコルを形成するためにそれらを共にリンクし、デジタルプレゼンテーションデータを1つ又は複数のタイプのデータパケットに形成し、前記通信プロトコルを使用して前記通信路上、前記ホストデバイスと前記クライアントデバイスの間で、デジタル制御データとデジタルプレゼンテーションデータの事前に選択されたセットを通信し、前記通信路上でパケットの形をしたデータを転送するように構成された、プロセッサ。
  32. 通信路上、ホストデバイスとクライアントデバイスの間において、高レートでデジタルデータを転送するための電子システムで使用するための状態機械であって、前記状態機械は、少なくとも1つのAsync Frames State同期化状態と、少なくとも2つのAcquiring Sync State同期状態と、少なくとも3つのIn-Sync States同期状態を有するように構成される状態機械。
  33. 通信路上、ホストデバイスとクライアントデバイスの間において、高レートでデジタルデータを転送するための電子システムで使用するための状態機械であって、前記状態機械は、少なくとも1つのAcquiring Sync States同期状態と、少なくとも2つのIn-Sync States同期状態を有するように構成される状態機械。
JP2013209726A 2004-03-24 2013-10-04 高データレートインターフェース装置および方法 Pending JP2014053920A (ja)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US55634504P 2004-03-24 2004-03-24
US60/556,345 2004-03-24

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
JP2010178120A Division JP5453197B2 (ja) 2004-03-24 2010-08-06 高データレートインターフェース装置および方法

Publications (1)

Publication Number Publication Date
JP2014053920A true JP2014053920A (ja) 2014-03-20

Family

ID=34963464

Family Applications (3)

Application Number Title Priority Date Filing Date
JP2007505205A Expired - Fee Related JP5032301B2 (ja) 2004-03-24 2005-03-24 高データレートインターフェース装置および方法
JP2010178120A Expired - Fee Related JP5453197B2 (ja) 2004-03-24 2010-08-06 高データレートインターフェース装置および方法
JP2013209726A Pending JP2014053920A (ja) 2004-03-24 2013-10-04 高データレートインターフェース装置および方法

Family Applications Before (2)

Application Number Title Priority Date Filing Date
JP2007505205A Expired - Fee Related JP5032301B2 (ja) 2004-03-24 2005-03-24 高データレートインターフェース装置および方法
JP2010178120A Expired - Fee Related JP5453197B2 (ja) 2004-03-24 2010-08-06 高データレートインターフェース装置および方法

Country Status (13)

Country Link
US (1) US8645566B2 (ja)
EP (1) EP1735988A1 (ja)
JP (3) JP5032301B2 (ja)
KR (1) KR101019935B1 (ja)
CN (1) CN1961560B (ja)
AU (1) AU2005227500B2 (ja)
BR (1) BRPI0509147A (ja)
CA (1) CA2560744C (ja)
IL (1) IL178256A0 (ja)
MX (1) MXPA06010873A (ja)
RU (1) RU2006137364A (ja)
TW (1) TWI375436B (ja)
WO (1) WO2005096594A1 (ja)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10554761B2 (en) 2015-12-12 2020-02-04 At&T Intellectual Property I, Lp Methods and apparatus to improve transmission of a field data set to a network access point via parallel communication sessions

Families Citing this family (41)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6760772B2 (en) 2000-12-15 2004-07-06 Qualcomm, Inc. Generating and implementing a communication protocol and interface for high data rate signal transfer
US8812706B1 (en) 2001-09-06 2014-08-19 Qualcomm Incorporated Method and apparatus for compensating for mismatched delays in signals of a mobile display interface (MDDI) system
KR101168839B1 (ko) 2003-06-02 2012-07-26 퀄컴 인코포레이티드 고속 데이터 레이트를 위한 신호 프로토콜 및 인터페이스의 생성 및 구현
KR101178080B1 (ko) 2003-08-13 2012-08-30 퀄컴 인코포레이티드 더 높은 데이터 레이트를 위한 신호 인터페이스
KR100951158B1 (ko) 2003-09-10 2010-04-06 콸콤 인코포레이티드 고속 데이터 인터페이스
US8694652B2 (en) 2003-10-15 2014-04-08 Qualcomm Incorporated Method, system and computer program for adding a field to a client capability packet sent from a client to a host
CN1902880A (zh) 2003-10-29 2007-01-24 高通股份有限公司 高数据速率接口
CN101729205A (zh) 2003-11-12 2010-06-09 高通股份有限公司 具有改进链路控制的高数据速率接口
BRPI0416895A (pt) 2003-11-25 2007-03-06 Qualcomm Inc interface de alta taxa de dados com sincronização de link melhorada
EP2247072B1 (en) 2003-12-08 2013-09-25 QUALCOMM Incorporated High data rate interface with improved link synchronization
US7599665B2 (en) * 2003-12-19 2009-10-06 Nokia Corporation Selection of radio resources in a wireless communication device
WO2005088939A1 (en) 2004-03-10 2005-09-22 Qualcomm Incorporated High data rate interface apparatus and method
JP4519903B2 (ja) 2004-03-17 2010-08-04 クゥアルコム・インコーポレイテッド 高速データレートインタフェース装置及び方法
KR101019935B1 (ko) 2004-03-24 2011-03-09 퀄컴 인코포레이티드 고 데이터 레이트 인터페이스 장치 및 방법
EP1978692B1 (en) 2004-06-04 2011-07-27 QUALCOMM Incorporated High data rate interface apparatus and method
US8650304B2 (en) 2004-06-04 2014-02-11 Qualcomm Incorporated Determining a pre skew and post skew calibration data rate in a mobile display digital interface (MDDI) communication system
US8699330B2 (en) 2004-11-24 2014-04-15 Qualcomm Incorporated Systems and methods for digital data transmission rate control
US8692838B2 (en) 2004-11-24 2014-04-08 Qualcomm Incorporated Methods and systems for updating a buffer
US8539119B2 (en) 2004-11-24 2013-09-17 Qualcomm Incorporated Methods and apparatus for exchanging messages having a digital data interface device message format
US8667363B2 (en) 2004-11-24 2014-03-04 Qualcomm Incorporated Systems and methods for implementing cyclic redundancy checks
US8873584B2 (en) 2004-11-24 2014-10-28 Qualcomm Incorporated Digital data interface device
US8723705B2 (en) 2004-11-24 2014-05-13 Qualcomm Incorporated Low output skew double data rate serial encoder
US7505837B2 (en) * 2004-12-30 2009-03-17 Spx Corporation Method and apparatus for linking to a vehicle diagnostic system
KR100685664B1 (ko) * 2005-08-12 2007-02-26 삼성전자주식회사 호스트 및 클라이언트로 구성된 데이터 통신 시스템 및데이터 통신 시스템의 작동 방법
US8692839B2 (en) 2005-11-23 2014-04-08 Qualcomm Incorporated Methods and systems for updating a buffer
US8730069B2 (en) 2005-11-23 2014-05-20 Qualcomm Incorporated Double data rate serial encoder
US20070258478A1 (en) * 2006-05-05 2007-11-08 Lsi Logic Corporation Methods and/or apparatus for link optimization
KR100917889B1 (ko) * 2006-11-01 2009-09-16 삼성전자주식회사 무선 통신 장치 및 방법
US8356331B2 (en) * 2007-05-08 2013-01-15 Qualcomm Incorporated Packet structure for a mobile display digital interface
JP5240491B2 (ja) * 2007-06-26 2013-07-17 ソニー株式会社 送信装置および受信装置
US8675068B2 (en) * 2008-04-11 2014-03-18 Nearmap Australia Pty Ltd Systems and methods of capturing large area images in detail including cascaded cameras and/or calibration features
JP2010011255A (ja) * 2008-06-30 2010-01-14 Nec Electronics Corp 無線通信装置及びそのパケット転送方法
TWI413971B (zh) * 2009-12-22 2013-11-01 Innolux Corp 驅動晶片之建立時間及保持時間調整電路
US8766940B1 (en) * 2012-01-06 2014-07-01 Google Inc. Textured linear trackpad
US9489331B2 (en) 2012-10-10 2016-11-08 Samsung Display Co., Ltd. Method and protocol for high-speed data channel detection control
US9088445B2 (en) * 2013-03-07 2015-07-21 Qualcomm Incorporated Method and apparatus for selectively terminating signals on a bidirectional bus based on bus speed
KR102237026B1 (ko) * 2014-11-05 2021-04-06 주식회사 실리콘웍스 디스플레이 장치
US9819575B2 (en) * 2015-03-10 2017-11-14 Dell Products Lp Path selection based on error analysis
EP3550748B1 (de) * 2018-04-05 2021-08-11 Siemens Aktiengesellschaft Verfahren zur erkennung von datenverfälschungen bei einer datenübertragung über eine fehlersichere kommunikationsverbindung
JPWO2020250727A1 (ja) * 2019-06-14 2020-12-17
US11184264B2 (en) 2020-02-21 2021-11-23 Rohde & Schwarz Gmbh & Co. Kg Error rate test method and test system for testing a device under test

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2002049314A2 (en) * 2000-12-15 2002-06-20 Qualcomm Incorporated Generating and implementing a communication protocol and interface for high data rate signal transfer

Family Cites Families (420)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7274652B1 (en) 2000-06-02 2007-09-25 Conexant, Inc. Dual packet configuration for wireless communications
US3594304A (en) 1970-04-13 1971-07-20 Sun Oil Co Thermal liquefaction of coal
US4042783A (en) 1976-08-11 1977-08-16 International Business Machines Corporation Method and apparatus for byte and frame synchronization on a loop system coupling a CPU channel to bulk storage devices
US4393444A (en) 1980-11-06 1983-07-12 Rca Corporation Memory addressing circuit for converting sequential input data to interleaved output data sequence using multiple memories
US4363123A (en) 1980-12-01 1982-12-07 Northern Telecom Limited Method of and apparatus for monitoring digital transmission systems in which line transmission errors are detected
JPS57136833A (en) * 1981-02-17 1982-08-24 Sony Corp Time-division multiplex data transmitting method
US4660096A (en) * 1984-12-11 1987-04-21 Rca Corporation Dividing high-resolution-camera video signal response into sub-image blocks individually raster scanned
DE3531809A1 (de) * 1985-09-06 1987-03-26 Kraftwerk Union Ag Katalysatormaterial zur reduktion von stickoxiden
US4769761A (en) 1986-10-09 1988-09-06 International Business Machines Corporation Apparatus and method for isolating and predicting errors in a local area network
JPS63226762A (ja) 1987-03-16 1988-09-21 Hitachi Ltd デ−タ処理方式
US4764805A (en) 1987-06-02 1988-08-16 Eastman Kodak Company Image transmission system with line averaging preview mode using two-pass block-edge interpolation
US4821296A (en) * 1987-08-26 1989-04-11 Bell Communications Research, Inc. Digital phase aligner with outrigger sampling
US5227783A (en) 1987-10-13 1993-07-13 The Regents Of New Mexico State University Telemetry apparatus and method with digital to analog converter internally integrated within C.P.U.
US5155590A (en) 1990-03-20 1992-10-13 Scientific-Atlanta, Inc. System for data channel level control
US4891805A (en) * 1988-06-13 1990-01-02 Racal Data Communications Inc. Multiplexer with dynamic bandwidth allocation
US5167035A (en) 1988-09-08 1992-11-24 Digital Equipment Corporation Transferring messages between nodes in a network
US5136717A (en) 1988-11-23 1992-08-04 Flavors Technology Inc. Realtime systolic, multiple-instruction, single-data parallel computer system
US5079693A (en) * 1989-02-28 1992-01-07 Integrated Device Technology, Inc. Bidirectional FIFO buffer having reread and rewrite means
US6014705A (en) * 1991-10-01 2000-01-11 Intermec Ip Corp. Modular portable data processing terminal having a higher layer and lower layer partitioned communication protocol stack for use in a radio frequency communications network
US5224213A (en) 1989-09-05 1993-06-29 International Business Machines Corporation Ping-pong data buffer for transferring data from one data bus to another data bus
US5495482A (en) 1989-09-29 1996-02-27 Motorola Inc. Packet transmission system and method utilizing both a data bus and dedicated control lines
US5543939A (en) 1989-12-28 1996-08-06 Massachusetts Institute Of Technology Video telephone systems
US5138616A (en) 1990-03-19 1992-08-11 The United States Of America As Represented By The Secretary Of The Army Continuous on-line link error rate detector utilizing the frame bit error rate
US5111455A (en) 1990-08-24 1992-05-05 Avantek, Inc. Interleaved time-division multiplexor with phase-compensated frequency doublers
US5131012A (en) 1990-09-18 1992-07-14 At&T Bell Laboratories Synchronization for cylic redundancy check based, broadband communications network
GB2249460B (en) 1990-09-19 1994-06-29 Intel Corp Network providing common access to dissimilar hardware interfaces
GB2250668B (en) 1990-11-21 1994-07-20 Apple Computer Tear-free updates of computer graphical output displays
IL100213A (en) 1990-12-07 1995-03-30 Qualcomm Inc Mikrata Kedma phone system and its antenna distribution system
US5359595A (en) 1991-01-09 1994-10-25 Rockwell International Corporation Skywave adaptable network transceiver apparatus and method using a stable probe and traffic protocol
US5345542A (en) 1991-06-27 1994-09-06 At&T Bell Laboratories Proportional replication mapping system
US5231636A (en) 1991-09-13 1993-07-27 National Semiconductor Corporation Asynchronous glitchless digital MUX
DE69233608T2 (de) * 1991-10-01 2007-03-01 Broadcom Corp., Irvine Lokales Funkfrequenznetzwerk
US5396636A (en) * 1991-10-21 1995-03-07 International Business Machines Corporation Remote power control via data link
US5751445A (en) 1991-11-11 1998-05-12 Canon Kk Image transmission system and terminal device
CA2064541C (en) 1992-03-31 1998-09-15 Thomas A. Gray Cycling error count for link maintenance
US5331642A (en) 1992-09-01 1994-07-19 International Business Machines Corporation Management of FDDI physical link errors
JP3305769B2 (ja) 1992-09-18 2002-07-24 株式会社東芝 通信装置
JPH06124147A (ja) 1992-10-13 1994-05-06 Sanyo Electric Co Ltd 情報処理装置
GB9222282D0 (en) * 1992-10-22 1992-12-09 Hewlett Packard Co Monitoring network status
US5513185A (en) * 1992-11-23 1996-04-30 At&T Corp. Method and apparatus for transmission link error rate monitoring
US5867501A (en) * 1992-12-17 1999-02-02 Tandem Computers Incorporated Encoding for communicating data and commands
US5619650A (en) * 1992-12-31 1997-04-08 International Business Machines Corporation Network processor for transforming a message transported from an I/O channel to a network by adding a message identifier and then converting the message
GB9304638D0 (en) * 1993-03-06 1993-04-21 Ncr Int Inc Wireless data communication system having power saving function
JPH06332664A (ja) 1993-03-23 1994-12-02 Toshiba Corp 表示制御システム
US5418452A (en) 1993-03-25 1995-05-23 Fujitsu Limited Apparatus for testing integrated circuits using time division multiplexing
WO1994024200A1 (en) 1993-04-16 1994-10-27 Akzo Nobel N.V. Liquid stabilizer comprising metal soap and solubilized metal perchlorate
JP3197679B2 (ja) 1993-04-30 2001-08-13 富士写真フイルム株式会社 写真撮影システムおよび方法
US5420858A (en) 1993-05-05 1995-05-30 Synoptics Communications, Inc. Method and apparatus for communications from a non-ATM communication medium to an ATM communication medium
US5519830A (en) 1993-06-10 1996-05-21 Adc Telecommunications, Inc. Point-to-multipoint performance monitoring and failure isolation system
JP2768621B2 (ja) 1993-06-25 1998-06-25 沖電気工業株式会社 分散送信される畳み込み符号の復号装置
US5477534A (en) 1993-07-30 1995-12-19 Kyocera Corporation Acoustic echo canceller
US5430486A (en) 1993-08-17 1995-07-04 Rgb Technology High resolution video image transmission and storage
US5426694A (en) 1993-10-08 1995-06-20 Excel, Inc. Telecommunication switch having programmable network protocols and communications services
US5490247A (en) 1993-11-24 1996-02-06 Intel Corporation Video subsystem for computer-based conferencing system
US5510832A (en) * 1993-12-01 1996-04-23 Medi-Vision Technologies, Inc. Synthesized stereoscopic imaging system and method
US5583562A (en) * 1993-12-03 1996-12-10 Scientific-Atlanta, Inc. System and method for transmitting a plurality of digital services including imaging services
US5724536A (en) * 1994-01-04 1998-03-03 Intel Corporation Method and apparatus for blocking execution of and storing load operations during their execution
US5844606A (en) 1994-03-03 1998-12-01 Fuji Photo Film Co., Ltd. Videocamera having a multiconnector connectable to a variety of accessories
JP2790034B2 (ja) 1994-03-28 1998-08-27 日本電気株式会社 非運用系メモリ更新方式
US5483185A (en) * 1994-06-09 1996-01-09 Intel Corporation Method and apparatus for dynamically switching between asynchronous signals without generating glitches
JP3329076B2 (ja) 1994-06-27 2002-09-30 ソニー株式会社 ディジタル信号伝送方法、ディジタル信号伝送装置、ディジタル信号受信方法及びディジタル信号受信装置
US5560022A (en) 1994-07-19 1996-09-24 Intel Corporation Power management coordinator system and interface
US5748891A (en) 1994-07-22 1998-05-05 Aether Wire & Location Spread spectrum localizers
CN1124039C (zh) 1994-07-25 2003-10-08 西门子公司 可视电话通信建立连接和控制的方法
US5664948A (en) 1994-07-29 1997-09-09 Seiko Communications Holding N.V. Delivery of data including preloaded advertising data
US5733131A (en) * 1994-07-29 1998-03-31 Seiko Communications Holding N.V. Education and entertainment device with dynamic configuration and operation
JP3592376B2 (ja) 1994-08-10 2004-11-24 株式会社アドバンテスト 時間間隔測定装置
EP0735490A4 (en) 1994-09-27 1998-01-21 Sega Enterprises Kk DATA TRANSFER DEVICE AND VIDEO GAME WITH THIS DEVICE
GB2296123B (en) * 1994-12-13 1998-08-12 Ibm Midi playback system
US5559459A (en) 1994-12-29 1996-09-24 Stratus Computer, Inc. Clock signal generation arrangement including digital noise reduction circuit for reducing noise in a digital clocking signal
GB2298109B (en) 1995-02-14 1999-09-01 Nokia Mobile Phones Ltd Data interface
US5530704A (en) 1995-02-16 1996-06-25 Motorola, Inc. Method and apparatus for synchronizing radio ports in a commnuication system
US5646947A (en) 1995-03-27 1997-07-08 Westinghouse Electric Corporation Mobile telephone single channel per carrier superframe lock subsystem
US6117681A (en) 1995-03-29 2000-09-12 Bavarian Nordic Research Inst. A/S Pseudotyped retroviral particles
KR100411372B1 (ko) 1995-04-11 2004-05-06 마츠시타 덴끼 산교 가부시키가이샤 비디오정보조정장치,비디오정보송신장치및비디오정보수신장치
US5521907A (en) 1995-04-25 1996-05-28 Visual Networks, Inc. Method and apparatus for non-intrusive measurement of round trip delay in communications networks
US5963564A (en) 1995-06-13 1999-10-05 Telefonaktiebolaget Lm Ericsson Synchronizing the transmission of data via a two-way link
SE506540C2 (sv) 1995-06-13 1998-01-12 Ericsson Telefon Ab L M Synkronisering av överföring av data via en dubbelriktad länk
US6055247A (en) * 1995-07-13 2000-04-25 Sony Corporation Data transmission method, data transmission apparatus and data transmission system
JPH0936871A (ja) 1995-07-17 1997-02-07 Sony Corp データ伝送システムおよびデータ伝送方法
US5604450A (en) * 1995-07-27 1997-02-18 Intel Corporation High speed bidirectional signaling scheme
JPH0955667A (ja) * 1995-08-10 1997-02-25 Mitsubishi Electric Corp マルチプレクサ,及びデマルチプレクサ
US5742840A (en) 1995-08-16 1998-04-21 Microunity Systems Engineering, Inc. General purpose, multiple precision parallel operation, programmable media processor
KR100272472B1 (ko) * 1995-09-19 2000-11-15 씨. 필립 채프맨 디지탈 프로그램가능 임계 레벨을 가진 마이크로컨트롤러 재작동 기능
US5748642A (en) 1995-09-25 1998-05-05 Credence Systems Corporation Parallel processing integrated circuit tester
US5732352A (en) * 1995-09-29 1998-03-24 Motorola, Inc. Method and apparatus for performing handoff in a wireless communication system
US5818255A (en) 1995-09-29 1998-10-06 Xilinx, Inc. Method and circuit for using a function generator of a programmable logic device to implement carry logic functions
US5550489A (en) 1995-09-29 1996-08-27 Quantum Corporation Secondary clock source for low power, fast response clocking
US5751951A (en) 1995-10-30 1998-05-12 Mitsubishi Electric Information Technology Center America, Inc. Network interface
EP0772119A3 (en) 1995-10-31 1997-12-29 Cirrus Logic, Inc. Automatic graphics operation
US5958006A (en) 1995-11-13 1999-09-28 Motorola, Inc. Method and apparatus for communicating summarized data
US7003796B1 (en) * 1995-11-22 2006-02-21 Samsung Information Systems America Method and apparatus for recovering data stream clock
US5790551A (en) 1995-11-28 1998-08-04 At&T Wireless Services Inc. Packet data transmission using dynamic channel assignment
US5844918A (en) 1995-11-28 1998-12-01 Sanyo Electric Co., Ltd. Digital transmission/receiving method, digital communications method, and data receiving apparatus
US6865610B2 (en) * 1995-12-08 2005-03-08 Microsoft Corporation Wire protocol for a media server system
EP0781068A1 (en) 1995-12-20 1997-06-25 International Business Machines Corporation Method and system for adaptive bandwidth allocation in a high speed data network
JP3427149B2 (ja) 1996-01-26 2003-07-14 三菱電機株式会社 符号化信号の復号回路及びその同期制御方法, 同期検出回路及び同期検出方法
US5903281A (en) 1996-03-07 1999-05-11 Powertv, Inc. List controlled video operations
US6243596B1 (en) 1996-04-10 2001-06-05 Lextron Systems, Inc. Method and apparatus for modifying and integrating a cellular phone with the capability to access and browse the internet
US5815507A (en) 1996-04-15 1998-09-29 Motorola, Inc. Error detector circuit for digital receiver using variable threshold based on signal quality
US6130602A (en) 1996-05-13 2000-10-10 Micron Technology, Inc. Radio frequency data communications device
JPH09307457A (ja) 1996-05-14 1997-11-28 Sony Corp パラレルシリアル変換回路
US5982362A (en) 1996-05-30 1999-11-09 Control Technology Corporation Video interface architecture for programmable industrial control systems
US5983261A (en) 1996-07-01 1999-11-09 Apple Computer, Inc. Method and apparatus for allocating bandwidth in teleconferencing applications using bandwidth control
GB9614561D0 (en) 1996-07-11 1996-09-04 4Links Ltd Communication system with improved code
US6298387B1 (en) 1996-07-12 2001-10-02 Philips Electronics North America Corp System for detecting a data packet in a bitstream by storing data from the bitstream in a buffer and comparing data at different locations in the buffer to predetermined data
KR100221028B1 (ko) 1996-07-23 1999-09-15 윤종용 그래픽 가속기 및 이를 이용한 메모리 프리패치 방법
US6886035B2 (en) 1996-08-02 2005-04-26 Hewlett-Packard Development Company, L.P. Dynamic load balancing of a network of client and server computer
US6185601B1 (en) * 1996-08-02 2001-02-06 Hewlett-Packard Company Dynamic load balancing of a network of client and server computers
US5969750A (en) 1996-09-04 1999-10-19 Winbcnd Electronics Corporation Moving picture camera with universal serial bus interface
CA2214743C (en) 1996-09-20 2002-03-05 Ntt Mobile Communications Network Inc. A frame synchronization circuit and communications system
US5990852A (en) 1996-10-31 1999-11-23 Fujitsu Limited Display screen duplication system and method
US5864546A (en) * 1996-11-05 1999-01-26 Worldspace International Network, Inc. System for formatting broadcast data for satellite transmission and radio reception
US6308239B1 (en) 1996-11-07 2001-10-23 Hitachi, Ltd. Interface switching apparatus and switching control method
US6078361A (en) 1996-11-18 2000-06-20 Sage, Inc Video adapter circuit for conversion of an analog video signal to a digital display image
US6002709A (en) 1996-11-21 1999-12-14 Dsp Group, Inc. Verification of PN synchronization in a direct-sequence spread-spectrum digital communications system
KR100211918B1 (ko) 1996-11-30 1999-08-02 김영환 비동기식전송모드셀 경계 식별장치
US5862160A (en) * 1996-12-31 1999-01-19 Ericsson, Inc. Secondary channel for communication networks
US5995512A (en) 1997-01-17 1999-11-30 Delco Electronics Corporation High speed multimedia data network
US6064649A (en) 1997-01-31 2000-05-16 Nec Usa, Inc. Network interface card for wireless asynchronous transfer mode networks
US6081513A (en) 1997-02-10 2000-06-27 At&T Corp. Providing multimedia conferencing services over a wide area network interconnecting nonguaranteed quality of services LANs
EP0859326A3 (en) 1997-02-14 1999-05-12 Canon Kabushiki Kaisha Data transmission apparatus, system and method, and image processing apparatus
US6584144B2 (en) 1997-02-24 2003-06-24 At&T Wireless Services, Inc. Vertical adaptive antenna array for a discrete multitone spread spectrum communications system
US6359923B1 (en) 1997-12-18 2002-03-19 At&T Wireless Services, Inc. Highly bandwidth efficient communications
DE19733005B4 (de) 1997-03-12 2007-06-21 Storz Endoskop Gmbh Einrichtung zur zentralen Überwachung und/oder Steuerung wenigstens eines Gerätes
US6480521B1 (en) 1997-03-26 2002-11-12 Qualcomm Incorporated Method and apparatus for transmitting high speed data in a spread spectrum communications system
US7143177B1 (en) 1997-03-31 2006-11-28 West Corporation Providing a presentation on a network having a plurality of synchronized media types
US5963557A (en) 1997-04-11 1999-10-05 Eng; John W. High capacity reservation multiple access network with multiple shared unidirectional paths
US6405111B2 (en) 1997-05-16 2002-06-11 Snap-On Technologies, Inc. System and method for distributed computer automotive service equipment
JP3143079B2 (ja) 1997-05-30 2001-03-07 松下電器産業株式会社 辞書索引作成装置と文書検索装置
US5867510A (en) * 1997-05-30 1999-02-02 Motorola, Inc. Method of and apparatus for decoding and processing messages
KR100550190B1 (ko) * 1997-06-03 2006-04-21 소니 가부시끼 가이샤 휴대용정보처리장치의제어방법,및휴대용정보처리장치
US6236647B1 (en) 1998-02-24 2001-05-22 Tantivy Communications, Inc. Dynamic frame size adjustment and selective reject on a multi-link channel to improve effective throughput and bit error rate
US6314479B1 (en) 1997-08-04 2001-11-06 Compaq Computer Corporation Universal multi-pin plug and display connector for standardizing signals transmitted between a computer and a display for a PC theatre interconnectivity system
WO1999010719A1 (en) 1997-08-29 1999-03-04 The Regents Of The University Of California Method and apparatus for hybrid coding of speech at 4kbps
US6288739B1 (en) 1997-09-05 2001-09-11 Intelect Systems Corporation Distributed video communications system
US6377993B1 (en) 1997-09-26 2002-04-23 Mci Worldcom, Inc. Integrated proxy interface for web based data management reports
AU9806098A (en) 1997-10-14 1999-05-03 Alation Digital radio-frequency transceiver
US6574211B2 (en) 1997-11-03 2003-06-03 Qualcomm Incorporated Method and apparatus for high rate packet data transmission
US6894994B1 (en) * 1997-11-03 2005-05-17 Qualcomm Incorporated High data rate wireless packet data communications system
TW408315B (en) 1997-11-07 2000-10-11 Sharp Kk Magnetic recording device, magnetic recording and reproducing device, and magnetic recording method
US6246876B1 (en) 1997-11-13 2001-06-12 Telefonaktiebolaget L M Ericsson (Publ) Synchronization messages for hand-off operations
US6091709A (en) 1997-11-25 2000-07-18 International Business Machines Corporation Quality of service management for packet switched networks
US20010012293A1 (en) 1997-12-02 2001-08-09 Lars-Goran Petersen Simultaneous transmission of voice and non-voice data on a single narrowband connection
US6049837A (en) * 1997-12-08 2000-04-11 International Business Machines Corporation Programmable output interface for lower level open system interconnection architecture
US6393008B1 (en) 1997-12-23 2002-05-21 Nokia Movile Phones Ltd. Control structures for contention-based packet data services in wideband CDMA
KR100286080B1 (ko) 1997-12-30 2001-04-16 윤종용 데이터링크를이용한데이터송신및수신방법
KR100251963B1 (ko) * 1997-12-31 2000-04-15 윤종용 종합정보통신망과 연동 가능한 비동기전송모드 망 접속영상전화 단말장치
TW459184B (en) 1998-01-23 2001-10-11 Shiu Ming Wei Multimedia message processing system
IL137628A (en) 1998-02-20 2005-09-25 Deep Video Imaging Ltd Multi-layer display and a method for displaying images on such a display
JP3004618B2 (ja) 1998-02-27 2000-01-31 キヤノン株式会社 画像入力装置及び画像入力システム及び画像送受信システム及び画像入力方法及び記憶媒体
JPH11249987A (ja) 1998-03-05 1999-09-17 Nec Corp メッセージ処理装置およびその方法ならびにメッセージ処理制御プログラムを格納した記憶媒体
PL343258A1 (en) 1998-03-16 2001-07-30 Jazio High speed signaling for interfacing vlsi cmos circuits
KR100566040B1 (ko) 1998-03-19 2006-03-30 가부시끼가이샤 히다치 세이사꾸쇼 방송 정보 공급 시스템
US6201811B1 (en) * 1998-03-24 2001-03-13 Telefonaktiebolaget Lm Ericsson (Publ) Transferring Identifier information in a telecommunications system
US6243761B1 (en) 1998-03-26 2001-06-05 Digital Equipment Corporation Method for dynamically adjusting multimedia content of a web page by a server in accordance to network path characteristics between client and server
US6199169B1 (en) * 1998-03-31 2001-03-06 Compaq Computer Corporation System and method for synchronizing time across a computer cluster
EP1341339A3 (en) 1998-04-01 2004-01-02 Matsushita Graphic Communication Systems, Inc. Activation of multiple xDSL modems with implicit channel probe
US6252888B1 (en) 1998-04-14 2001-06-26 Nortel Networks Corporation Method and apparatus providing network communications between devices using frames with multiple formats
US6101601A (en) 1998-04-20 2000-08-08 International Business Machines Corporation Method and apparatus for hibernation within a distributed data processing system
US6430196B1 (en) 1998-05-01 2002-08-06 Cisco Technology, Inc. Transmitting delay sensitive information over IP over frame relay
KR100413417B1 (ko) 1998-05-04 2004-02-14 엘지전자 주식회사 이동통신시스템에서 단말기의 호 접속 제어 방법.
US6611503B1 (en) 1998-05-22 2003-08-26 Tandberg Telecom As Method and apparatus for multimedia conferencing with dynamic bandwidth allocation
JP3792894B2 (ja) 1998-05-27 2006-07-05 キヤノン株式会社 固体撮像素子及び固体撮像装置
US6043693A (en) 1998-06-01 2000-03-28 3Dfx Interactive, Incorporated Multiplexed synchronization circuits for switching frequency synthesized signals
US6850282B1 (en) * 1998-06-02 2005-02-01 Canon Kabushiki Kaisha Remote control of image sensing apparatus
JP3475081B2 (ja) 1998-06-03 2003-12-08 三洋電機株式会社 立体映像再生方法
US6092231A (en) 1998-06-12 2000-07-18 Qlogic Corporation Circuit and method for rapid checking of error correction codes using cyclic redundancy check
JP4267092B2 (ja) 1998-07-07 2009-05-27 富士通株式会社 時刻同期方法
US6510503B2 (en) 1998-07-27 2003-01-21 Mosaid Technologies Incorporated High bandwidth memory interface
US6359479B1 (en) * 1998-08-04 2002-03-19 Juniper Networks, Inc. Synchronizing data transfers between two distinct clock domains
US6532506B1 (en) * 1998-08-12 2003-03-11 Intel Corporation Communicating with devices over a bus and negotiating the transfer rate over the same
US6728263B2 (en) 1998-08-18 2004-04-27 Microsoft Corporation Dynamic sizing of data packets
JP2002525913A (ja) 1998-09-11 2002-08-13 シェアウェーブ・インコーポレーテッド コンピュータ・ネットワーク内の通信を制御するための方法および装置
US6513085B1 (en) 1998-10-13 2003-01-28 Texas Instruments Incorporated Link/transaction layer controller with integral microcontroller emulation
US7180951B2 (en) * 1998-10-30 2007-02-20 Broadcom Corporation Reduction of aggregate EMI emissions of multiple transmitters
WO2000027079A1 (en) 1998-10-30 2000-05-11 Broadcom Corporation Internet gigabit ethernet transmitter architecture
US6421735B1 (en) 1998-10-30 2002-07-16 Advanced Micro Devices, Inc. Apparatus and method for automatically selecting a network port for a home network station
US6836829B2 (en) 1998-11-20 2004-12-28 Via Technologies, Inc. Peripheral device interface chip cache and data synchronization method
TW466410B (en) 2000-06-16 2001-12-01 Via Tech Inc Cache device inside peripheral component interface chipset and data synchronous method to externals
US6545979B1 (en) 1998-11-27 2003-04-08 Alcatel Canada Inc. Round trip delay measurement
CN1240198C (zh) 1998-12-07 2006-02-01 三星电子株式会社 在码分多址移动通信系统中用于选通发送的设备和方法
US6791379B1 (en) 1998-12-07 2004-09-14 Broadcom Corporation Low jitter high phase resolution PLL-based timing recovery system
US6363439B1 (en) * 1998-12-07 2002-03-26 Compaq Computer Corporation System and method for point-to-point serial communication between a system interface device and a bus interface device in a computer system
US6252526B1 (en) 1998-12-14 2001-06-26 Seiko Epson Corporation Circuit and method for fast parallel data strobe encoding
JP3557975B2 (ja) 1998-12-14 2004-08-25 セイコーエプソン株式会社 信号切り替え回路及び信号切り替え方法
US6297684B1 (en) 1998-12-14 2001-10-02 Seiko Epson Corporation Circuit and method for switching between digital signals that have different signal rates
JP2000196986A (ja) 1998-12-25 2000-07-14 Olympus Optical Co Ltd 電子的撮像装置
US6950428B1 (en) 1998-12-30 2005-09-27 Hewlett-Packard Development Company, L.P. System and method for configuring adaptive sets of links between routers in a system area network (SAN)
US6549538B1 (en) 1998-12-31 2003-04-15 Compaq Information Technologies Group, L.P. Computer method and apparatus for managing network ports cluster-wide using a lookaside list
US6836469B1 (en) 1999-01-15 2004-12-28 Industrial Technology Research Institute Medium access control protocol for a multi-channel communication system
JP2000216843A (ja) 1999-01-22 2000-08-04 Oki Electric Ind Co Ltd デジタル復調器
US6636508B1 (en) 1999-02-12 2003-10-21 Nortel Networks Limted Network resource conservation system
US6493824B1 (en) 1999-02-19 2002-12-10 Compaq Information Technologies Group, L.P. Secure system for remotely waking a computer in a power-down state
US6199099B1 (en) 1999-03-05 2001-03-06 Ac Properties B.V. System, method and article of manufacture for a mobile communication network utilizing a distributed communication network
EP1163607A2 (en) 1999-03-05 2001-12-19 Accenture LLP Method and apparatus for creating an information summary
JP4181685B2 (ja) * 1999-03-12 2008-11-19 富士通株式会社 電力制御方法及び電子機器並びに記録媒体
US6429867B1 (en) 1999-03-15 2002-08-06 Sun Microsystems, Inc. System and method for generating and playback of three-dimensional movies
US6636922B1 (en) 1999-03-17 2003-10-21 Adaptec, Inc. Methods and apparatus for implementing a host side advanced serial protocol
US6609167B1 (en) 1999-03-17 2003-08-19 Adaptec, Inc. Host and device serial communication protocols and communication packet formats
FI107424B (fi) 1999-03-22 2001-07-31 Nokia Mobile Phones Ltd Menetelmä ja järjestelmä multimediaan liittyvän informaation välittämiseen valmistautumiseksi pakettikytkentäisessä solukkoradioverkossa
JP2000278141A (ja) 1999-03-26 2000-10-06 Mitsubishi Electric Corp マルチプレクサ
KR100350607B1 (ko) 1999-03-31 2002-08-28 삼성전자 주식회사 음성 및 화상 송수신을 위한 휴대용 복합 통신단말기 및 그 동작방법과 통신시스템
US6222677B1 (en) 1999-04-12 2001-04-24 International Business Machines Corporation Compact optical system for use in virtual display applications
JP2000358033A (ja) 1999-06-14 2000-12-26 Canon Inc データ通信システム及びデータ通信方法
US6618360B1 (en) 1999-06-15 2003-09-09 Hewlett-Packard Development Company, L.P. Method for testing data path of peripheral server devices
US6457090B1 (en) 1999-06-30 2002-09-24 Adaptec, Inc. Structure and method for automatic configuration for SCSI Synchronous data transfers
JP2001025010A (ja) 1999-07-09 2001-01-26 Mitsubishi Electric Corp マルチメディア情報通信装置およびその方法
US6865609B1 (en) * 1999-08-17 2005-03-08 Sharewave, Inc. Multimedia extensions for wireless local area network
US6597197B1 (en) 1999-08-27 2003-07-22 Intel Corporation I2C repeater with voltage translation
KR20010019734A (ko) 1999-08-30 2001-03-15 윤종용 유무선 통신을 이용한 컴퓨터 교육용 시스템
US7010607B1 (en) * 1999-09-15 2006-03-07 Hewlett-Packard Development Company, L.P. Method for training a communication link between ports to correct for errors
JP3116090B1 (ja) 1999-09-17 2000-12-11 郵政省通信総合研究所長 通信システム、送信装置、受信装置、送信方法、受信方法、および、情報記録媒体
JP4207329B2 (ja) * 1999-09-20 2009-01-14 富士通株式会社 フレーム同期回路
US6782277B1 (en) 1999-09-30 2004-08-24 Qualcomm Incorporated Wireless communication system with base station beam sweeping
US6643787B1 (en) 1999-10-19 2003-11-04 Rambus Inc. Bus system optimization
US6662322B1 (en) * 1999-10-29 2003-12-09 International Business Machines Corporation Systems, methods, and computer program products for controlling the error rate in a communication device by adjusting the distance between signal constellation points
AU6458399A (en) 1999-11-11 2001-06-06 Ascom Powerline Communications Ag Communication system, especially for indoors
US6438363B1 (en) 1999-11-15 2002-08-20 Lucent Technologies Inc. Wireless modem alignment in a multi-cell environment
GB2372606B (en) 1999-11-22 2004-06-02 Seagate Technology Llc Peer to peer interconnect diagnostics
TW513636B (en) 2000-06-30 2002-12-11 Via Tech Inc Bus data interface for transmitting data on PCI bus, the structure and the operating method thereof
US6804257B1 (en) 1999-11-25 2004-10-12 International Business Machines Corporation System and method for framing and protecting variable-lenght packet streams
JP4058888B2 (ja) * 1999-11-29 2008-03-12 セイコーエプソン株式会社 Ram内蔵ドライバ並びにそれを用いた表示ユニットおよび電子機器
JP4191869B2 (ja) 1999-12-20 2008-12-03 富士フイルム株式会社 ディジタルカメラを用いたコンピュータシステム
US7383350B1 (en) 2000-02-03 2008-06-03 International Business Machines Corporation User input based allocation of bandwidth on a data link
US6778493B1 (en) 2000-02-07 2004-08-17 Sharp Laboratories Of America, Inc. Real-time media content synchronization and transmission in packet network apparatus and method
JP3490368B2 (ja) 2000-02-07 2004-01-26 インターナショナル・ビジネス・マシーンズ・コーポレーション 信号出力装置、ドライバ回路、信号伝送システム、および信号伝送方法
JP2001236304A (ja) 2000-02-21 2001-08-31 Mitsubishi Electric Corp マイクロコンピュータ
JP4449141B2 (ja) 2000-02-22 2010-04-14 ソニー株式会社 電源制御装置、電源制御システム
EP2259652B1 (en) 2000-03-03 2012-02-29 Qualcomm Incorporated Method, system and apparatus for participating in group communication services in an existing communication system
US6477150B1 (en) 2000-03-03 2002-11-05 Qualcomm, Inc. System and method for providing group communication services in an existing communication system
JP2001282714A (ja) 2000-03-30 2001-10-12 Olympus Optical Co Ltd マルチカメラデータ転送方式及びデータ転送方式
JP2001292146A (ja) 2000-04-07 2001-10-19 Sony Corp 電子機器およびディジタルシリアルデータのインタフェース装置のバス初期化フェーズにおける処理方法
US6882361B1 (en) 2000-04-19 2005-04-19 Pixelworks, Inc. Imager linked with image processing station
JP2001306428A (ja) 2000-04-25 2001-11-02 Canon Inc ネットワーク機器、ネットワークシステム、通信方法及び記録媒体
JP2001319745A (ja) 2000-05-08 2001-11-16 Honda Tsushin Kogyo Co Ltd 変換用アダプタ
JP2001320280A (ja) 2000-05-10 2001-11-16 Mitsubishi Electric Corp 並列−直列変換回路
US6760722B1 (en) 2000-05-16 2004-07-06 International Business Machines Corporation Computer implemented automated remote support
JP4292685B2 (ja) 2000-05-23 2009-07-08 日本電気株式会社 データ転送システム、データ送受信システム、データ送受信方法、フォーマット変換装置、フォーマット変換方法およびフォーマット変換プログラムを記録したコンピュータ読み取り可能な記録媒体
KR100360622B1 (ko) 2000-06-12 2002-11-13 주식회사 문화방송 엠펙 데이터 프레임과 이를 이용한 송수신 시스템
US6754179B1 (en) 2000-06-13 2004-06-22 Lsi Logic Corporation Real time control of pause frame transmissions for improved bandwidth utilization
JP3415567B2 (ja) 2000-06-21 2003-06-09 エヌイーシーマイクロシステム株式会社 Usb転送制御方法およびusbコントローラ
US6714233B2 (en) * 2000-06-21 2004-03-30 Seiko Epson Corporation Mobile video telephone system
US6999432B2 (en) 2000-07-13 2006-02-14 Microsoft Corporation Channel and quality of service adaptation for multimedia over wireless networks
TW522306B (en) 2000-08-08 2003-03-01 Replaytv Inc Method and system for remote television replay control
US6784941B1 (en) 2000-08-09 2004-08-31 Sunplus Technology Co., Ltd. Digital camera with video input
US6892071B2 (en) 2000-08-09 2005-05-10 Sk Telecom Co., Ltd. Handover method in wireless telecommunication system supporting USTS
JP2002062990A (ja) 2000-08-15 2002-02-28 Fujitsu Media Device Kk インターフェイス装置
GB2366926A (en) 2000-09-06 2002-03-20 Sony Uk Ltd Combining material and data
US7138989B2 (en) 2000-09-15 2006-11-21 Silicon Graphics, Inc. Display capable of displaying images in response to signals of a plurality of signal formats
US6747964B1 (en) 2000-09-15 2004-06-08 Qualcomm Incorporated Method and apparatus for high data rate transmission in a wireless communication system
JP4146991B2 (ja) * 2000-09-18 2008-09-10 キヤノン株式会社 電子カメラシステム、電子カメラ及び電子カメラシステムの制御方法
US7466978B1 (en) 2000-09-18 2008-12-16 International Business Machines Corporation Telephone network node device
US6760882B1 (en) 2000-09-19 2004-07-06 Intel Corporation Mode selection for data transmission in wireless communication channels based on statistical parameters
US6738344B1 (en) 2000-09-27 2004-05-18 Hewlett-Packard Development Company, L.P. Link extenders with link alive propagation
US7336613B2 (en) * 2000-10-17 2008-02-26 Avaya Technology Corp. Method and apparatus for the assessment and optimization of network traffic
US6690655B1 (en) 2000-10-19 2004-02-10 Motorola, Inc. Low-powered communication system and method of operation
US7869067B2 (en) 2000-10-20 2011-01-11 Visioneer, Inc. Combination scanner and image data reader system including image management and software
US7278069B2 (en) 2000-10-31 2007-10-02 Igor Anatolievich Abrosimov Data transmission apparatus for high-speed transmission of digital data and method for automatic skew calibration
WO2002041540A1 (en) 2000-11-17 2002-05-23 Samsung Electronics Co., Ltd Apparatus and method for measuring propagation delay in an nb-tdd cdma mobile communication system
US7464877B2 (en) * 2003-11-13 2008-12-16 Metrologic Instruments, Inc. Digital imaging-based bar code symbol reading system employing image cropping pattern generator and automatic cropped image processor
GB2397734B (en) 2000-12-06 2004-09-29 Fujitsu Ltd Data recovery circuitry
US6973039B2 (en) 2000-12-08 2005-12-06 Bbnt Solutions Llc Mechanism for performing energy-based routing in wireless networks
US6760772B2 (en) * 2000-12-15 2004-07-06 Qualcomm, Inc. Generating and implementing a communication protocol and interface for high data rate signal transfer
US7023924B1 (en) 2000-12-28 2006-04-04 Emc Corporation Method of pausing an MPEG coded video stream
JP2002208844A (ja) 2001-01-12 2002-07-26 Nec Eng Ltd グリッチ除去回路
US6947436B2 (en) 2001-02-01 2005-09-20 Motorola, Inc. Method for optimizing forward link data transmission rates in spread-spectrum communications systems
US7301968B2 (en) 2001-03-02 2007-11-27 Pmc-Sierra Israel Ltd. Communication protocol for passive optical network topologies
KR20020071226A (ko) * 2001-03-05 2002-09-12 삼성전자 주식회사 이동통신 시스템에서 역방향 링크 송신 제어 장치 및 방법
JP4106226B2 (ja) 2001-03-26 2008-06-25 松下電器産業株式会社 電源制御装置
CN1165141C (zh) 2001-03-27 2004-09-01 华为技术有限公司 路由器接口驱动数据转发过程的方法
JP2002300299A (ja) 2001-03-29 2002-10-11 Shunichi Toyoda 携帯電話材のメモリを利用した情報端末装置による教育システム
JP2002359774A (ja) 2001-03-30 2002-12-13 Fuji Photo Film Co Ltd 電子カメラ
CN1159935C (zh) 2001-03-30 2004-07-28 华为技术有限公司 一种提高市区环境下蜂窝移动台定位精度的方法和装置
JP3497834B2 (ja) 2001-03-30 2004-02-16 株式会社東芝 ルートリピータ、usb通信システム、usb通信制御方法
US20030189927A1 (en) 2001-04-27 2003-10-09 Foster Michael S. Method and system for multiframe buffering in a routing device
US6889056B2 (en) 2001-04-30 2005-05-03 Ntt Docomo, Inc. Transmission control scheme
JP3884322B2 (ja) 2001-05-16 2007-02-21 株式会社リコー ネットワークインターフェース
US7392541B2 (en) 2001-05-17 2008-06-24 Vir2Us, Inc. Computer system architecture and method providing operating-system independent virus-, hacker-, and cyber-terror-immune processing environments
US7420602B2 (en) 2001-05-29 2008-09-02 Samsung Semiconductor Israel R&D Center (Sirc) Cmos imager for cellular applications and methods of using such
JP2002351689A (ja) 2001-05-30 2002-12-06 Nec Corp データ転送システム
US7191281B2 (en) * 2001-06-13 2007-03-13 Intel Corporation Mobile computer system having a navigation mode to optimize system performance and power management for mobile applications
US7165112B2 (en) * 2001-06-22 2007-01-16 Motorola, Inc. Method and apparatus for transmitting data in a communication system
JP2003006143A (ja) 2001-06-22 2003-01-10 Nec Corp バス共有化システムと装置及び方法
US6745364B2 (en) 2001-06-28 2004-06-01 Microsoft Corporation Negotiated/dynamic error correction for streamed media
JP2003046595A (ja) 2001-07-06 2003-02-14 Texas Instruments Inc データ通信の方法および装置
US7051218B1 (en) 2001-07-18 2006-05-23 Advanced Micro Devices, Inc. Message based power management
WO2003013080A1 (en) * 2001-07-31 2003-02-13 Comverse Ltd. Email protocol for a mobile environment and gateway using same
US7184408B2 (en) * 2001-07-31 2007-02-27 Denton I Claude Method and apparatus for programmable generation of traffic streams
JP2003044184A (ja) 2001-08-01 2003-02-14 Canon Inc データ処理装置及び電力制御方法
GB2415314B (en) * 2001-08-08 2006-05-03 Adder Tech Ltd Video switch
US6758678B2 (en) * 2001-08-14 2004-07-06 Disney Enterprises, Inc. Computer enhanced play set and method
JP4733877B2 (ja) 2001-08-15 2011-07-27 富士通セミコンダクター株式会社 半導体装置
JP2003069544A (ja) 2001-08-23 2003-03-07 Hitachi Kokusai Electric Inc 通信制御方法及び通信制御装置
JP4322451B2 (ja) 2001-09-05 2009-09-02 日本電気株式会社 Dspメモリ間あるいはdspメモリとcpu用メモリ(dpram)間データ転送方式
US8812706B1 (en) * 2001-09-06 2014-08-19 Qualcomm Incorporated Method and apparatus for compensating for mismatched delays in signals of a mobile display interface (MDDI) system
CA2459941C (en) * 2001-09-06 2013-09-17 Qiuzhen Zou Generating and implementing a communication protocol and interface for high data rate signal transfer
DE10145722A1 (de) 2001-09-17 2003-04-24 Infineon Technologies Ag Konzept zur sicheren Datenkommunikation zwischen elektronischen Bausteinen
US20030061431A1 (en) * 2001-09-21 2003-03-27 Intel Corporation Multiple channel interface for communications between devices
KR100408299B1 (ko) 2001-09-29 2003-12-01 삼성전자주식회사 모드 판단 장치 및 방법
JP3633538B2 (ja) 2001-10-02 2005-03-30 日本電気株式会社 輻輳制御システム
US7570668B2 (en) 2001-10-03 2009-08-04 Nokia Corporation Data synchronization
KR100408525B1 (ko) 2001-10-31 2003-12-06 삼성전자주식회사 네트워크에 적응적인 실시간 멀티미디어 스트리밍 시스템및 방법
US20030125040A1 (en) 2001-11-06 2003-07-03 Walton Jay R. Multiple-access multiple-input multiple-output (MIMO) communication system
US7126945B2 (en) 2001-11-07 2006-10-24 Symbol Technologies, Inc. Power saving function for wireless LANS: methods, system and program products
US6990549B2 (en) * 2001-11-09 2006-01-24 Texas Instruments Incorporated Low pin count (LPC) I/O bridge
US7536598B2 (en) 2001-11-19 2009-05-19 Vir2Us, Inc. Computer system capable of supporting a plurality of independent computing environments
US6891545B2 (en) 2001-11-20 2005-05-10 Koninklijke Philips Electronics N.V. Color burst queue for a shared memory controller in a color sequential display system
GB2382502B (en) 2001-11-23 2005-10-19 Actix Ltd Network testing systems
JP2003167680A (ja) 2001-11-30 2003-06-13 Hitachi Ltd ディスク装置
US20030112758A1 (en) 2001-12-03 2003-06-19 Pang Jon Laurent Methods and systems for managing variable delays in packet transmission
KR100450795B1 (ko) 2001-12-12 2004-10-01 삼성전자주식회사 무선 독립망에서 혼합형 자원 공유 방법과 이를 위한 단말및 데이타 포맷
US7486693B2 (en) 2001-12-14 2009-02-03 General Electric Company Time slot protocol
US6993393B2 (en) * 2001-12-19 2006-01-31 Cardiac Pacemakers, Inc. Telemetry duty cycle management system for an implantable medical device
KR100428767B1 (ko) 2002-01-11 2004-04-28 삼성전자주식회사 트래픽 정보를 이용한 가입자 라우팅 설정 방법 및 이를위한 기록매체
US20050120208A1 (en) 2002-01-25 2005-06-02 Albert Dobson Robert W. Data transmission systems
US20030144006A1 (en) 2002-01-25 2003-07-31 Mikael Johansson Methods, systems, and computer program products for determining the location of a mobile terminal based on delays in receiving data packets from transmitters having known locations
US6690201B1 (en) * 2002-01-28 2004-02-10 Xilinx, Inc. Method and apparatus for locating data transition regions
US6867668B1 (en) * 2002-03-18 2005-03-15 Applied Micro Circuits Corporation High frequency signal transmission from the surface of a circuit substrate to a flexible interconnect cable
US7145411B1 (en) 2002-03-18 2006-12-05 Applied Micro Circuits Corporation Flexible differential interconnect cable with isolated high frequency electrical transmission line
US7336139B2 (en) * 2002-03-18 2008-02-26 Applied Micro Circuits Corporation Flexible interconnect cable with grounded coplanar waveguide
US6797891B1 (en) 2002-03-18 2004-09-28 Applied Micro Circuits Corporation Flexible interconnect cable with high frequency electrical transmission line
US20030185220A1 (en) 2002-03-27 2003-10-02 Moshe Valenci Dynamically loading parsing capabilities
US7425986B2 (en) 2002-03-29 2008-09-16 Canon Kabushiki Kaisha Conversion apparatus for image data delivery
US7310535B1 (en) 2002-03-29 2007-12-18 Good Technology, Inc. Apparatus and method for reducing power consumption in a wireless device
US7430001B2 (en) 2002-04-12 2008-09-30 Canon Kabushiki Kaisha Image sensing system, communication apparatus and image sensing apparatus having remote control function, and their control method
TWI235917B (en) 2002-04-15 2005-07-11 Via Tech Inc High speed data transmitter and transmission method thereof
US7158539B2 (en) * 2002-04-16 2007-01-02 Microsoft Corporation Error resilient windows media audio coding
US7599689B2 (en) 2002-04-22 2009-10-06 Nokia Corporation System and method for bookmarking radio stations and associated internet addresses
JP4029390B2 (ja) 2002-04-23 2008-01-09 ソニー株式会社 情報処理システム、情報処理装置および方法、プログラム格納媒体、並びにプログラム
US7284181B1 (en) 2002-04-24 2007-10-16 Juniper Networks, Inc. Systems and methods for implementing end-to-end checksum
US7206516B2 (en) * 2002-04-30 2007-04-17 Pivotal Decisions Llc Apparatus and method for measuring the dispersion of a fiber span
US7574113B2 (en) 2002-05-06 2009-08-11 Sony Corporation Video and audio data recording apparatus, video and audio data recording method, video and audio data reproducing apparatus, and video and audio data reproducing method
US20050091593A1 (en) 2002-05-10 2005-04-28 General Electric Company Method and system for coordinated transfer of control of a remote controlled locomotive
US6886067B2 (en) 2002-05-23 2005-04-26 Seiko Epson Corporation 32 Bit generic asynchronous bus interface using read/write strobe byte enables
US7036066B2 (en) 2002-05-24 2006-04-25 Sun Microsystems, Inc. Error detection using data block mapping
US7269153B1 (en) 2002-05-24 2007-09-11 Conexant Systems, Inc. Method for minimizing time critical transmit processing for a personal computer implementation of a wireless local area network adapter
JP2003098583A (ja) 2002-06-10 2003-04-03 Nikon Corp 書換え可能なメモリを使用するカメラ
US7543326B2 (en) 2002-06-10 2009-06-02 Microsoft Corporation Dynamic rate control
JP2004021613A (ja) * 2002-06-17 2004-01-22 Seiko Epson Corp データ転送制御装置、電子機器及びデータ転送制御方法
DE60212104T2 (de) 2002-06-18 2006-10-19 Matsushita Electric Industrial Co., Ltd., Kadoma Auf Empfänger basierte Umlaufzeitmessung in TCP
KR100469427B1 (ko) * 2002-06-24 2005-02-02 엘지전자 주식회사 이동통신 시스템의 동영상 재생 방법
US7486696B2 (en) 2002-06-25 2009-02-03 Avaya, Inc. System and method for providing bandwidth management for VPNs
JP4175838B2 (ja) 2002-07-09 2008-11-05 三菱電機株式会社 待機モード付情報処理装置およびその待機モード開始方法と待機モード解除方法
DE10234991B4 (de) * 2002-07-31 2008-07-31 Advanced Micro Devices, Inc., Sunnyvale Hostcontrollerdiagnose für einen seriellen Bus
US7403511B2 (en) 2002-08-02 2008-07-22 Texas Instruments Incorporated Low power packet detector for low power WLAN devices
US6611221B1 (en) 2002-08-26 2003-08-26 Texas Instruments Incorporated Multi-bit sigma-delta modulator employing dynamic element matching using adaptively randomized data-weighted averaging
US7876821B2 (en) * 2002-09-05 2011-01-25 Agency For Science, Technology And Research Method and an apparatus for controlling the rate of a video sequence; a video encoding device
US20040140459A1 (en) 2002-09-13 2004-07-22 Haigh Scott D. Enhanced shadow reduction system and related techniques for digital image capture
US7257087B2 (en) 2002-10-04 2007-08-14 Agilent Technologies, Inc. System and method to calculate round trip delay for real time protocol packet streams
CN1266976C (zh) 2002-10-15 2006-07-26 华为技术有限公司 一种移动台定位方法及其直放站
US20040082383A1 (en) 2002-10-24 2004-04-29 Motorola, Inc Methodology and wireless device for interactive gaming
US7949777B2 (en) 2002-11-01 2011-05-24 Avid Technology, Inc. Communication protocol for controlling transfer of temporal data over a bus between devices in synchronization with a periodic reference signal
US7336667B2 (en) * 2002-11-21 2008-02-26 International Business Machines Corporation Apparatus, method and program product to generate and use CRC in communications network
US7327735B2 (en) * 2002-11-27 2008-02-05 Alcatel Canada Inc. System and method for detecting lost messages transmitted between modules in a communication device
US6765506B1 (en) 2003-01-06 2004-07-20 Via Technologies Inc. Scrambler, de-scrambler, and related method
GB2397709B (en) 2003-01-27 2005-12-28 Evangelos Arkas Period-to-digital converter
US7047475B2 (en) 2003-02-04 2006-05-16 Hewlett-Packard Development Company, L.P. CRC encoding scheme for conveying status information
US20040176065A1 (en) 2003-02-20 2004-09-09 Bo Liu Low power operation in a personal area network communication system
US7787886B2 (en) * 2003-02-24 2010-08-31 Invisitrack, Inc. System and method for locating a target using RFID
US6944136B2 (en) 2003-02-28 2005-09-13 On-Demand Technologies, Inc. Two-way audio/video conferencing system
US20040184450A1 (en) 2003-03-19 2004-09-23 Abdu H. Omran Method and system for transport and routing of packets over frame-based networks
US7260087B2 (en) 2003-04-02 2007-08-21 Cellco Partnership Implementation methodology for client initiated parameter negotiation for PTT/VoIP type services
JP4288994B2 (ja) * 2003-04-10 2009-07-01 株式会社日立製作所 端末装置、配信サーバ、映像データの受信方法及び映像データの送信方法
WO2004093451A2 (en) * 2003-04-17 2004-10-28 Thomson Licensing Data requesting and transmitting devices and processes
US20040221315A1 (en) * 2003-05-01 2004-11-04 Genesis Microchip Inc. Video interface arranged to provide pixel data independent of a link character clock
US6895410B2 (en) 2003-05-02 2005-05-17 Nokia Corporation Method and apparatus for providing a multimedia data stream
EP1645082A2 (en) 2003-05-28 2006-04-12 Artimi Ltd Ultra-wideband network, device, device controller, method and data packet for establishing a mesh network and forwarding packets on another channel
US7110420B2 (en) 2003-05-30 2006-09-19 North Carolina State University Integrated circuit devices having on-chip adaptive bandwidth buses and related methods
US6975145B1 (en) 2003-06-02 2005-12-13 Xilinx, Inc. Glitchless dynamic multiplexer with synchronous and asynchronous controls
KR101168839B1 (ko) * 2003-06-02 2012-07-26 퀄컴 인코포레이티드 고속 데이터 레이트를 위한 신호 프로토콜 및 인터페이스의 생성 및 구현
US20040260823A1 (en) 2003-06-17 2004-12-23 General Instrument Corporation Simultaneously transporting multiple MPEG-2 transport streams
JP3834819B2 (ja) * 2003-07-17 2006-10-18 船井電機株式会社 プロジェクタ
KR100538226B1 (ko) 2003-07-18 2005-12-21 삼성전자주식회사 복수의 아날로그 입력 신호를 고속으로 처리하는아날로그/디지털 변환 장치 및 이를 이용한 디스플레이 장치
US7526350B2 (en) * 2003-08-06 2009-04-28 Creative Technology Ltd Method and device to process digital media streams
KR101178080B1 (ko) 2003-08-13 2012-08-30 퀄컴 인코포레이티드 더 높은 데이터 레이트를 위한 신호 인터페이스
US7467202B2 (en) * 2003-09-10 2008-12-16 Fidelis Security Systems High-performance network content analysis platform
KR100951158B1 (ko) * 2003-09-10 2010-04-06 콸콤 인코포레이티드 고속 데이터 인터페이스
US7015838B1 (en) * 2003-09-11 2006-03-21 Xilinx, Inc. Programmable serializing data path
KR20050028396A (ko) 2003-09-17 2005-03-23 삼성전자주식회사 멀티 세션 방식을 이용한 데이터 기록 방법 및 그정보저장매체
JP2005107683A (ja) * 2003-09-29 2005-04-21 Sharp Corp 通信コントローラ、通信システム、通信機器、および通信方法
ATE387824T1 (de) * 2003-10-08 2008-03-15 Research In Motion Ltd Verfahren und vorrichtung zur dynamischen paketübertragung in cdma2000 netzwerken
US8694652B2 (en) 2003-10-15 2014-04-08 Qualcomm Incorporated Method, system and computer program for adding a field to a client capability packet sent from a client to a host
CN1902880A (zh) 2003-10-29 2007-01-24 高通股份有限公司 高数据速率接口
CN101729205A (zh) 2003-11-12 2010-06-09 高通股份有限公司 具有改进链路控制的高数据速率接口
US7447953B2 (en) 2003-11-14 2008-11-04 Intel Corporation Lane testing with variable mapping
US7143207B2 (en) 2003-11-14 2006-11-28 Intel Corporation Data accumulation between data path having redrive circuit and memory device
US7219294B2 (en) 2003-11-14 2007-05-15 Intel Corporation Early CRC delivery for partial frame
BRPI0416895A (pt) 2003-11-25 2007-03-06 Qualcomm Inc interface de alta taxa de dados com sincronização de link melhorada
EP2247072B1 (en) 2003-12-08 2013-09-25 QUALCOMM Incorporated High data rate interface with improved link synchronization
US7451362B2 (en) * 2003-12-12 2008-11-11 Broadcom Corporation Method and system for onboard bit error rate (BER) estimation in a port bypass controller
US7340548B2 (en) 2003-12-17 2008-03-04 Microsoft Corporation On-chip bus
US20050163085A1 (en) 2003-12-24 2005-07-28 International Business Machines Corporation System and method for autonomic wireless presence ping
US7317754B1 (en) * 2004-01-12 2008-01-08 Verizon Services Corp. Rate agile rate-adaptive digital subscriber line
US7158536B2 (en) * 2004-01-28 2007-01-02 Rambus Inc. Adaptive-allocation of I/O bandwidth using a configurable interconnect topology
US7868890B2 (en) 2004-02-24 2011-01-11 Qualcomm Incorporated Display processor for a wireless device
WO2005088939A1 (en) 2004-03-10 2005-09-22 Qualcomm Incorporated High data rate interface apparatus and method
JP4519903B2 (ja) 2004-03-17 2010-08-04 クゥアルコム・インコーポレイテッド 高速データレートインタフェース装置及び方法
KR101019935B1 (ko) 2004-03-24 2011-03-09 퀄컴 인코포레이티드 고 데이터 레이트 인터페이스 장치 및 방법
EP1745556A4 (en) 2004-04-21 2012-09-19 DEVICE AND METHOD FOR MULTI-DATA PROCESSING IN A WIRELESS TERMINAL
US20050265333A1 (en) 2004-06-01 2005-12-01 Texas Instruments Incorporated Method for enabling efficient multicast transmission in a packet-based network
US8650304B2 (en) * 2004-06-04 2014-02-11 Qualcomm Incorporated Determining a pre skew and post skew calibration data rate in a mobile display digital interface (MDDI) communication system
US20060034301A1 (en) * 2004-06-04 2006-02-16 Anderson Jon J High data rate interface apparatus and method
US7383399B2 (en) * 2004-06-30 2008-06-03 Intel Corporation Method and apparatus for memory compression
CN101041989A (zh) 2004-08-05 2007-09-26 邱则有 一种钢筋砼立体承力结构楼盖
US7161846B2 (en) * 2004-11-16 2007-01-09 Seiko Epson Corporation Dual-edge triggered multiplexer flip-flop and method
US6990335B1 (en) * 2004-11-18 2006-01-24 Charles G. Shamoon Ubiquitous connectivity and control system for remote locations
US8667363B2 (en) 2004-11-24 2014-03-04 Qualcomm Incorporated Systems and methods for implementing cyclic redundancy checks
US8692838B2 (en) 2004-11-24 2014-04-08 Qualcomm Incorporated Methods and systems for updating a buffer
US8699330B2 (en) * 2004-11-24 2014-04-15 Qualcomm Incorporated Systems and methods for digital data transmission rate control
US7315265B2 (en) * 2004-11-24 2008-01-01 Qualcomm Incorporated Double data rate serial encoder
US8873584B2 (en) 2004-11-24 2014-10-28 Qualcomm Incorporated Digital data interface device
US8723705B2 (en) * 2004-11-24 2014-05-13 Qualcomm Incorporated Low output skew double data rate serial encoder
US20060161691A1 (en) 2004-11-24 2006-07-20 Behnam Katibian Methods and systems for synchronous execution of commands across a communication link
US8539119B2 (en) 2004-11-24 2013-09-17 Qualcomm Incorporated Methods and apparatus for exchanging messages having a digital data interface device message format
US7412642B2 (en) 2005-03-09 2008-08-12 Sun Microsystems, Inc. System and method for tolerating communication lane failures
US7605837B2 (en) 2005-06-02 2009-10-20 Lao Chan Yuen Display system and method
US7302510B2 (en) * 2005-09-29 2007-11-27 International Business Machines Corporation Fair hierarchical arbiter
US8730069B2 (en) 2005-11-23 2014-05-20 Qualcomm Incorporated Double data rate serial encoder
US8692839B2 (en) 2005-11-23 2014-04-08 Qualcomm Incorporated Methods and systems for updating a buffer

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2002049314A2 (en) * 2000-12-15 2002-06-20 Qualcomm Incorporated Generating and implementing a communication protocol and interface for high data rate signal transfer

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10554761B2 (en) 2015-12-12 2020-02-04 At&T Intellectual Property I, Lp Methods and apparatus to improve transmission of a field data set to a network access point via parallel communication sessions

Also Published As

Publication number Publication date
JP5032301B2 (ja) 2012-09-26
CA2560744C (en) 2012-12-04
AU2005227500B2 (en) 2008-12-04
JP2011019255A (ja) 2011-01-27
JP5453197B2 (ja) 2014-03-26
CN1961560B (zh) 2011-11-16
IL178256A0 (en) 2006-12-31
US8645566B2 (en) 2014-02-04
KR20070026471A (ko) 2007-03-08
BRPI0509147A (pt) 2007-09-11
KR101019935B1 (ko) 2011-03-09
AU2005227500A1 (en) 2005-10-13
CA2560744A1 (en) 2005-10-13
RU2006137364A (ru) 2008-04-27
TW200620899A (en) 2006-06-16
MXPA06010873A (es) 2007-04-02
WO2005096594A1 (en) 2005-10-13
EP1735988A1 (en) 2006-12-27
TWI375436B (en) 2012-10-21
CN1961560A (zh) 2007-05-09
US20050259670A1 (en) 2005-11-24
JP2007531120A (ja) 2007-11-01

Similar Documents

Publication Publication Date Title
JP5453197B2 (ja) 高データレートインターフェース装置および方法
JP4519903B2 (ja) 高速データレートインタフェース装置及び方法
JP5043968B2 (ja) 改良されたリンク同期を備えた高速データレートインタフェース
JP5237319B2 (ja) 高速データレートインタフェース
JP5275284B2 (ja) 高速データレートインタフェース装置及び方法
JP4782694B2 (ja) 改善されたリンク制御を有する高速データレートインタフェース
JP5129318B2 (ja) 高速データレートインタフェース
JP5795403B2 (ja) さらに高速なデータレート用の信号インタフェース
KR100919761B1 (ko) 고 데이터 레이트 인터페이스 장치 및 방법
JP2007512785A (ja) 改良されたリンク同期を備えた高速データレートインタフェース
KR100882166B1 (ko) 고 데이터 레이트 인터페이스 장치 및 방법

Legal Events

Date Code Title Description
A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20140408

A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20140924