バス (コンピュータ)
表示
(パラレルバスから転送)
バス (英: bus) とは、コンピュータの内外、各回路がデータを交換するための共通の経路を指すコンピュータ用語である。
矩形がデバイス、太線部がバス。複数のデバイスで1つの通信路を共有 して信号の送受信を行なう。
コンピュータにおいて、1つの信号線・通信線に複数のデバイスがぶら下がる構造を﹁バス型トポロジー﹂と言う。︵詳細はネットワーク構成を参照。︶本項目の﹁バス﹂の由来はこれである︵もしくはそのもの︶。
そのため、1対1で接続する専用経路︵﹁ポイントツーポイント﹂︶の場合はバスと言わない。バスに似た用語としてチャネルがある。チャネルは﹁入出力チャネル﹂のように、メモリと入出力との間の通信路を指す事が多い。
バス型トポロジー[編集]
概説[編集]
多くのコンピュータは、CPUなど、コンピュータの中心機能と、周辺機器や各種制御部を繋ぐためにバスを使っている。アーキテクチャが単純だった黎明期のコンピュータでは、各要素が単一のバスに接続されていた。たとえば、サン・マイクロシステムズの初期のワークステーションでは、VMEバスやマルチバスを使っていた。しかし、コンピュータの性能が向上するにつれて、CPUと各機器とを繋ぐバスの伝送容量も向上させる必要があり、次々と新しいバスに切り替わっていった。 マイクロプロセッサのメモリバスもこれまではバス型トポロジが主流だったが、メモリの高速化に対応してチャネルへと移行しつつある。また、マルチプロセッサ構成を採るワークステーションが性能を最大化するために複数のプロセッサとメモリーとの間での多対多の同時通信を行えるようにしたクロスバースイッチを採用してきたように、マルチコアやメニーコアを備えた新世代の高性能マイクロプロセッサの内部でも、多くのコアとキャッシュメモリーや外部との高速大容量の伝送を可能にするために、チャネルに代わってクロスバースイッチやリングバスが採用されるようになっている。内部バスと外部バス[編集]
機器内部の構成要素が接続されるものを内部バス、外部機器と接続するものを外部バスという。この分類はどこに視点を置くかで、たとえばマイクロプロセッサ、コンピュータの内部基板︵マザーボード等︶、コンピュータ装置の筐体、等で分類の仕方も変わる。位置を明示した﹁CPU内部バス﹂等といった表現や、メーカーの﹁標準機器﹂と﹁拡張機器﹂といった商策上の分類などから拡張バスといったように呼ばれるものもある。シリアルバスとパラレルバス[編集]
シリアルバス[編集]
詳細は「シリアル通信」を参照
1ビットずつ順番にデータを転送するバスをシリアルバスと呼ぶ。通常はクロック信号線は存在せず、受信側での復調に必要なクロックのタイミングはデータ信号に重積して送っている。通信線路の本数が少なければシールドを充実させたり、平衡接続も比較的容易になるため高周波信号が扱いやすくなる。複数の通信線路では互いの信号間でのタイミングがずれるタイミング・スキュー問題が起きるがシリアル化によって回避できる。クロストーク︵干渉︶の問題も減少する。求められる通信容量の増大に対応してシリアルバスを複数組、束ねるものが現われているが、それぞれの伝送路に流れているのは個別のシリアル信号であって互いの信号間にクロックの同期はない。シリアルバスの多くが通信線路の両端に送信端と受信端を持つチャネルであり、物理的には本来のバス型トポロジーではない。チャネルであれば原理的には線端反射やスタブの影響を受けずにノイズの少ない高周波動作に適した通信路が得られる。初期のシリアルバスは、パラレルバスよりも遙かに低速だった。
●RS-232C
●EIA-485
●IEEE 1394
●USB
●PCI Express
●シリアルATA
●1-Wire
など
パラレルバス[編集]
シリアルバスが1ビットずつデータを転送するのに対して、元データそのものや元データから切り出した複数ビットをひとかたまりにして、同時に複数本の通信路で情報を伝送するバスである。パラレルバスが必ずバス型トポロジーを採るとは限らないが、バス型トポロジーを採用するものが多い。クロック信号の専用線がデータ線と平行して設けられており、受信側でのデータ復調の同期に使われる。 信号線の本数が多いので、一般的には不平衡接続が採用されており、シールドの不足や線路間のクロストーク、路線長・LRC特性の違いなどによるスキューによって高速伝送にはあまり向かない。 ビット数すなわち平行する線路数は、8・16・32が多い。 コンピュータで使用されるデータバスやアドレスバスに採用例が多く、外部デバイスをつなぐバスとしても用いられ、GPIB、IDE/︵パラレル︶ATA、SCSI、PCIなどがある。高速化に限界があるため、PCIの改良版PCI ExpressやパラレルATAの改良版シリアルATAでは、データラインはシリアルバスとなっている。制御[編集]
バス型トポロジーを採るバスでは、複数の送信回路が存在するために同時に送信を行わないよう、伝送路へ信号を送り出す権利を調停する回路が設けられるのが一般的である。このような回路はバス・アービターと呼ばれ、バス・アービトレーションを行う。調停回路を設けずにバスの使用権を各送信回路へ順番に与える方式もあるが、バスの伝送効率は悪くなる。信号の劣化[編集]
チャネルと異なり、複数の送受信回路が存在するバス型トポロジーを採るバスでは、仮に両端の終端処理を正しく行っても、途中の送受信回路の接続線やコネクタ類は﹁スタブ﹂と呼ばれる引き込み部分を構成してこの部分で信号波形は劣化する。仮に途中のコネクタが空のまま放置されればコネクタの引き込み線部分から反射が生じる。路線長の違いや伝送特性の違いなどを補正するために、伝送路を使用する前にトレーニングを行って平行するデータ線の信号特性を最適化するような工夫も行われたが、長い配線を引き回しながら十分なシールドを行うことは難しく、コモンモードノイズは不平衡伝送では除けず、外来ノイズやクロストークを抑えながら高速信号の波形を乱さないように扱うには限界がある。主なコンピュータ用バス[編集]
「拡張カード#拡張バス」も参照
●S-100バス - Altair 8800で採用、後のIEEE-696
●VME - 68000用汎用バス、ワークステーションで多く採用例 後のIEEE 1014-1987
●Small Computer System Interface - それまでのSASIを元に開発、略称﹁SCSI﹂
●ISA - PC/ATで採用
●Cバス - 日本電気PC-9800シリーズの拡張バス
●NuBus - 初期のAppleやNeXTで採用
●VLバス - ISA後継のグラフィクスバス用バス
●MCA - IBMが開発したISAバスの後継
●EISA - MCAに対抗して制定
●SBus - Sparc用拡張バス、VMEバスから置換、IEEE 1496
●PCI - インテルの提案で広範に普及した汎用拡張バス
●FSB - インテルのCPUバス、高速化に伴い呼称も変化している
●Direct Rambus - ラムバス社が設計したRDRAM専用のメモリインタフェースバス
●パラレルATA - ストレージ用のバス、後継のシリアルATAはスター型トポロジー
●USB - 当初はレガシー代替が目的
●IEEE 1394 - AppleのFirewireを規格化、i.LINKとも
●Low Pin Count - ISAの代替規格
●イーサネット - 現在主流となっている規格の論理上のネットワーク・トポロジーはバス型
●AGP - PCI上位互換のグラフィックス用高速バス
●PCI Express - PCI、AGPの後継
●HDMI - DVIから発展したAV機器向けインタフェースで、デイジーチェーンによるバス接続が可能
●Thunderbolt - インテルとAppleが共同開発した汎用バス、PCI ExpressとDisplayPortを基盤としている
●VMBus - Hyper-Vの仮想機械で物理デバイスへアクセスするための仮想バス
CPU内部バスの構造[編集]
CPUのマイクロチップ内部の信号線。CPUアーキテクチャ図により示されることが多い。この節の加筆が望まれています。 |
CPU外部バスの構造[編集]
CPU外部のバスあるいは単にCPUバスと言う。ここでは、CPUとメモリ・入出力装置が直接バスで接続される簡単な構成を考えてみる︵今日のパソコンはもう少し複雑である。比較的古い時代のコンピュータでは、各要素が1つのバスに接続されていた。SUNのVMEバスやMULTIBUSなど。︶
基本的な例としてのバスの構造は下記のようになる。
アドレスバス[編集]
詳細は「アドレスバス」を参照
アドレスを転送するために使われる線。使われる線の本数をアドレスバス幅と言う。メモリのアドレスや入出力装置 (I/O) のアドレスが出力される。例えば、Z80ではピン︵信号︶A00 - A15がアドレスバスである。アドレスバス幅は16bitで、64KBのメモリを扱える。
メモリアドレスバスとI/Oアドレスバスは、ピンを共用する場合も、独立している場合もある。
データバス[編集]
CPUと、メモリやI/Oとの間でデータを転送するために使われる線。基本的には双方向通信が基本だが、S100バスのように、コンピュータ→周辺機器、周辺機器→コンピュータのデータの転送を分けたバスもある。使われる線の本数をデータバス幅という。 データバスもメモリ用とI/O用とで、ピンを共用する場合も、独立している場合もある。制御線[編集]
コントロールバスとも呼ぶ。 アドレスバスやデータバスで実際に入出力を行うタイミングや、その他CPUと外部との間での必要な制御情報を遣り取りする信号線。入力・出力は用途に応じて別。 例として、各バスに有効なデータが乗っている事を示す。制御信号のエッジ︵変化点︶で実際の転送動作が行われる。例えば、Z80ではMREQピンがアクティブになる事によりメモリとの転送である事を示し、RDピンはCPUへの入力︵読み込み︶、WRピンはCPUからの出力︵書き込み︶時にアクティブになる。 単純な構成では上記のようになるが、今日のより詳細な技術についてはCPUバスを参照のこと。この節の加筆が望まれています。 |
コンピュータ内部のバス(外部バス)[編集]
コンピュータ内部、すなわちCPUの外側から装置の内部までの間では、色々なバスが使われている。上記のCPU外部バスを含めて単に﹁外部バス﹂と言うこともある。
単純なマイコンでは上記のCPU外部バスの延長線の構成を取ることが多いが、今日ではパソコンでもチップセットによりシステムバス、メモリバスや入出力バスが統合されたチャネル構成を取る。
この節の加筆が望まれています。 |
システムバス[編集]
詳細は「en:System bus」を参照
コンピュータ内の各コンポーネントが接続されるバスである。上記のCPU外部バス、すなわちCPUから直接出た信号線を指すこともある。
フロントサイドバスとも呼ばれるがこの用語には諸説ある。今日のパソコンではCPUから出たシステムバスは﹁ノースブリッジ﹂と呼ばれるチップセットに集約して接続されるのが一般的である。