コンピュータ・アーキテクチャ

コンピュータ(特にハードウェア)における基本設計や設計思想

コンピュータ・アーキテクチャ: computer architecture)は、基本的には、コンピュータ(特にハードウェア)の論理的な構成(法)のことであり、構成要素[注釈 1]として何があるか、各構成要素がどのような機能・役割を与えられ、相互にどのような連絡をして全体としてひとつのコンピュータとして機能しているか、に関する記述やとり決めのことである。[1] 他の語と組み合わせる場合は通常「方式」と訳す。意訳して「設計思想」とも。

1プロセッサのCPUのコンピュータの基本的なアーキテクチャを表すブロックダイアグラム。黒い線はデータフローを表し、赤い線は制御フローを表す。矢印はフローの向きを示している。

概説 編集

アーキテクチャはもともと建築関連用語で、単に「建築物」以外に、設計や様式という意味があるが、それが転じて、コンピュータ分野においても使われるようになった。「設計思想」などと意訳されることもある[2][3][4]。技術者や研究者の用語としては(企業ごとの用語の違いにもよるが)「方式」という語が使われることもある。

1964年のSystem/360で最初に使われた用語で、その際の意味としては、入出力インタフェースを含むコンピュータシステムのハードウェア全体(周辺機器は含まない)の、ユーザー(プログラマオペレーティングシステム (OS) を設計するプログラマも含む)から見た構成要素とそのインタフェースの定義であり、具体的には使用できるレジスタの構成、命令セット入出力(チャネルコントロールワード)などである。各構成要素の実装(つまり各構成要素が具体的にどのような電子部品の組み合わせや集積回路で実現されるか)に関する記述・とりきめは含まない。つまりここでアーキテクチャはソフトウェア側から見たコンピュータの構成要素とその動作の外形的な定義であるので、アーキテクチャが同一・一定であれば、ソフトウェアの互換性が原則として保証されることになり、同一のソフトウェアを使い続けつつ上位互換のアーキテクチャを持つコンピュータへ移行することや、上位互換の周辺機器へ変更することも可能となる。また定義されたアーキテクチャを守り各構成要素の外形的な動作を記述どおりに実現しさえすれば、その内部設計や実装は技術の進歩などに応じて自由に変更・更新できる、ということになった。この結果、コンピュータ・ファミリー(シリーズ)が形成可能となった。

また、エンタープライズアーキテクチャソフトウェアアーキテクチャARMアーキテクチャなどの用語も増えている。

分類 編集

この分野で評価の高いヘネシーとパターソンの2003年の書では、コンピュータ・アーキテクチャは少なくとも次の3つに分類される、とされた[5]

命令セットアーキテクチャ(ISA)
機械語(またはアセンブリ言語プログラマ、ただしOSのそれも含む)から見たプロセッサの抽象化されたイメージであり、命令セットアドレッシングモードレジスタ、アドレスとデータの形式などが含まれる。すなわち、プロセッサをソフトウェア側から見たときのインタフェース定義である。
マイクロアーキテクチャ
さらに下位でのより具体的なシステムに関する記述であり、ISAを実装するためにシステムの構成部品をどのように接続し、それらがどのように相互にやりとりするかを示す[6]。例えば、(内蔵の1次)キャッシュの大きさは、ISAには通常何の関係もないが、その下位レベルの実装においては重要な問題である。
システムアーキテクチャ(「システム設計」とも)
上述したもの以外の、コンピュータシステムのハードウェア全般に関するもの。以下のようなものが含まれる。
  1. バスクロスバースイッチなどのシステムのインターコネクト
  2. メモリコントローラやメモリ階層
  3. ダイレクト・メモリー・アクセス などのCPUオフロード機構
  4. マルチプロセッシングに関わる部分
  5. 複数のコンピュータによるシステム構成に関するもの(コンピュータ・クラスターNUMAアーキテクチャなど)

前者2つはプロセッサのアーキテクチャである。3番目のシステムアーキテクチャは、プロセッサ以外の要素も含めコンピュータ全体のアーキテクチャである。

なお、もともとのSystem/360の「厳密に定義された」アーキテクチャには、ISAが含まれマイクロアーキテクチャが含まれず、3番目のシステムアーキテクチャのいくつかに相当するものが含まれるという相違点があるが、これは、System/360のようにまだ集積回路すら使わず単体のトランジスタやダイオードや抵抗を基板上で組み合わせて[注釈 2]実装していた当時の大型コンピュータと現在のマイクロプロセッサベースのコンピュータとでは、実装技術が大きく異なり、またビジネスモデルが変化し(周辺機器を含む)コンピュータシステム全体のレイヤの分けかたも変化したことによる。

CPUのアーキテクチャ 編集

CPUのアーキテクチャについて説明する。

フォン・ノイマン型アーキテクチャとハーバード・アーキテクチャ 編集

フォン・ノイマン型アーキテクチャ

フォン・ノイマン型アーキテクチャは(ハーバード・アーキテクチャと対比される場合)、メモリ内の命令とデータは区別しない方式のことで、ひとつのメモリの中に命令とデータが置かれるアーキテクチャ。命令をデータとして扱うこともでき、データを命令として扱うこともできる。動作中に命令を書き換えることもできる。 最初、1944年ジョン・モークリージョン・プレスパー・エッカートEDVACのためにつくったアーキテクチャであり、後からチームに合流したフォン・ノイマンがそれを自分の名で報告書にまとめたのでフォン・ノイマンの名で呼ばれている。

なおフォン・ノイマン型アーキテクチャだと、CPUのクロック周波数が高くなり命令フェッチや命令実行が速くなると、CPUとメモリ間のデータの移動の頻度が高くなり、命令とデータで「アクセス競合」が起き、メモリから命令やデータが到着するのを待つ状態が増え、動作が遅くなってしまう「フォン・ノイマン・ボトルネック」と呼ばれる現象が発生する。

 
ハーバード・アーキテクチャ
ハーバード・アーキテクチャ

ハーバード・アーキテクチャ(Harvard Architecture)は、命令メモリとデータメモリを分離し別々に置くアーキテクチャ。メモリでの命令とデータのアクセス競合は発生せず、フォン・ノイマン・ボトルネックが解消する。ただしデータを命令として実行することはできず、動作中に命令を書き換えることもできない。1944年にIBMがハーバード大学に納入したHarvard Mark Iで最初に採用されたアーキテクチャである。

修正ハーバード・アーキテクチャ(en:Modified Harvard Architecture

ハーバード・アーキテクチャを一部修正したアーキテクチャで、基本的には命令とデータを別に置いていてボトルネックが解消しており、なおかつ命令用メモリからデータ用メモリへの移動や、データ用メモリから命令用メモリへの移動も可能な方式。ハーバード・アーキテクチャを一部、修正・改良したので「修正ハーバード・アーキテクチャ」という。マイクロコントローラで主流のアーキテクチャで、基本的には命令用のフラッシュメモリとデータ用のRAMを区別しているが、命令用フラッシュメモリからデータ用のRAMにロードできたり、RAMに置いた命令を取り出しフラッシュメモリに移動し実行することもできる。現在、マイクロコントローラ以外の多くのコンピュータもこの方式を採用している。

アキュムレータ方式と汎用レジスタ方式 編集

CPUのレジスタと演算装置(ALU)の関係性に関するアーキテクチャとしては、典型的なものとしては、アキュムレータ方式汎用レジスタ方式がある。1970年代や1980年代のCPUや現在のマイクロコントローラの一部はアキュムレータ方式を採用しているが、これは少数派であり、現在のパーソナルコンピュータスマートフォンなどのCPUは基本的に汎用レジスタ方式であり、こちらが現在の主流派である。

アキュムレータ方式

演算装置で演算した結果を、必ず「アキュムレータ(accumulator、集積装置)」と呼ばれる特別な位置づけのレジスタに送り込む方式。そしてアキュムレータの値は、次の演算でオペランド被演算子)として使われる。 1970年代や80年代など、CPUに入れられるトランジスタの数がまだかなり限られていた時代に、CPUを簡素な構造にしてトランジスタ数を減らすために考案された方式。 CPU内部では数を次々と足して総和を求める作業は頻繁に行われているが、アキュムレータ方式だと、オペランドの片方だけを次々と指定しては演算器で加算してゆくだけで総和を求めることができる。たとえばIntel 8080の「Aレジスタ」はアキュムレータである[7]
現在では、1970年代や80年代のようにCPUに収容できるトランジスタ数が限られることは無いが、現在でもマイクロコントローラの一部ではあえてアキュムレータ方式を採用してさらに(上の節で説明した、命令用メモリとデータ用メモリを別に置く)ハーバード・アーキテクチャと組み合わせることで、簡素でコストを抑えていながら高性能のマイクロコントローラを提供しているメーカーもある[8]

汎用レジスタ方式

(上で説明したアキュムレータという特別な扱いのレジスタは置かず)複数のレジスタの中から2つのレジスタを指定して、その2つの値をオペランドとして演算が可能な方式。汎用レジスタ方式だと、オペランドの組み合わせの自由度が高く、高速演算が可能になる。また、マイクロコントローラのプログラミングの際にはCコンパイラのIDE(統合開発環境)との親和性も高く、たとえばプログラムのローカル変数をマイクロコントローラの複数のレジスタに割り当てることができる。(アキュムレータ方式では割り当てられずRAMなどのメモリに割り当てなければならないのに比べて有利。)[8] 現在の技術ではCPUにトランジスタを大量に詰め込むことも容易なので、通常はこの汎用レジスタ方式を採用する。

[注釈 3]

コンピュータ全体のアーキテクチャ 編集

プロセッサだけではなく、コンピュータシステム全体の設計とアーキテクチャについて述べる。

コンピュータの設計をする際は、まず用途や制約条件を考慮し、要素の優先順位を決定する。コンピュータ・アーキテクチャは一般に、標準規格、機能、メモリ容量、レイテンシスループット消費電力、生産コストや生産性などを考慮して決められるが、また信頼性拡張性、大きさ、重さといった要素も考慮される。それらの要素のいくつかは互いにトレードオフの関係にあり、何かを優先すると何かが犠牲になる。少数の要素を最高の状態にすることを重要視して他の要素を大きく犠牲にすることもいとわない設計法と、多くの要素をほどほどの状態に保つ設計法がある。古典的な手法としては、データの処理能力を上げることを最優先し、何がボトルネックとなり最もデータ処理能力を悪化させているかを見極め、そのボトルネックを解消するというものがあった。近年のモバイルコンピュータでは、消費電力を抑えることを優先し、何が電力を消費し電力効率を下げているのか見極め、それを取り除く工夫を重ねる。

現実のコンピュータの設計には、純粋に技術的な観点だけでなく、当該開発プロジェクトのマネージャーの個人的意向や志向も影響し、またコンピュータの開発というのは企業でビジネス(商業活動)の一部として行われているので、コンピュータ市場にすでに存在している他社のコンピュータとの競合関係や棲み分けやポジショニングといった、経営者が判断するマーケティング戦略的なことも、影響を及ぼず。

コスト 編集

一般に、設計前に、システム要件やコンピュータ市場の状況(他社の競合製品の存在状況やその価格など)を考慮して、販売される台数(ロット)も予想しそれも織り込みつつ、製造コストの目標値が設定される。

処理能力 編集

コンピュータの処理能力(性能)を高める手法や、その測定法や指標はいくつもある。

パーソナルコンピュータでよく使われた手法はクロック周波数を上げることで、現在でもコンピュータ商品の仕様書(スペックシート)に「○○GHz」(かつては「○○MHz」)などと表示されているものであり、CPUのクロックが一秒間に何サイクルであるかを示したものである。しかしクロック周波数で単純に処理能力の高さを測れるかというと、必ずしもそうではない。最近のCPUはスーパースケーラ方式で1クロックサイクルで複数の命令を実行することでデータ処理能力を改善しているので、それも考慮する必要がある。また2006年1月にインテルがIntel Coreシリーズの最初のものをリリースして以降は、マルチコア化つまりひとつのプロセッサに《CPUコア》を複数持たせて処理能力を高めている製品は主流であり、コア数も指標となる。喩えるなら、クロック周波数を道路の最高速度(法定速度)のようなものだとすると、コア数は道路の車線の数に相当し、最高速度が同じでも車線数が2倍、4倍、6倍になると、単位時間あたりに通る自動車の数も2倍、4倍、6倍に増えるのと同じようなもので、クロック周波数が同じでもコア数が多ければデータ処理能力は高い。(なおクロック周波数のほうは、1990年代は右肩上がりの状態であったが、2020年代にはすでに頭打ちになっている。)

他にCPUのキャッシュメモリの容量、実行ユニットの個数を増やす方法もあり、他にもバスの速度、プログラムとして実行しようとする命令の種類と順序なども処理能力に影響し、メインメモリの容量も影響する。

特に高速に大量の計算をすることを目的としたスーパーコンピュータでは「ノード」と呼ばれる同一ユニットを非常に多数並べるアーキテクチャ(並列アーキテクチャ)を採用している[9](近年のスパコンでは、数千個から数万個ほどもノードを並べる)。スーパーコンピュータの処理能力の高さは、FLOPS(フロップス)という指標で表示する方法があり、そのほかにも処理能力の高さはランキングという手法で比較することが世界的に一般的である[10]

制御用のコンピュータでは、「速さ」を考える際に、レイテンシスループットが重要である。レイテンシとは、ある処理が開始してから完了するまでの時間である。スループットは単位時間当たりに処理できる仕事の量である。割り込みレイテンシとは、ハードウェアのイベント(例えば、ディスクドライブの読み書きの完了)通知(割り込み)に対して、システムが応答するのにかかる時間である。性能は設計上の様々な選択によって影響される。例えば、キャッシュメモリを追加するとレイテンシは悪化するが、スループットは向上する。制御用のコンピュータでは、割り込みレイテンシの短縮が求められる。そのようなコンピュータはリアルタイム環境で運用され、所定の時間以内に処理が行われないと問題が発生する。例えばコンピュータ制御のアンチロックブレーキは、ブレーキが踏まれたら即座に制動をかけ始めなければならない。 コンピュータの性能の測定法や指標は他にもある。システムは用途によってボトルネックとなる部分が異なり、CPUバウンド(例えば数値計算など)、I/Oバウンド(Webサーバなど)、メモリバウンド(ビデオ編集など)に分けられる。サーバや携帯機器では電力消費量も重要な指標である(次の節で説明)。

ベンチマークは、一連の評価プログラムを実行し、それにかかる時間を計ることで、上述の多くの観点を考慮した性能を測定するものである。しかし、ベンチマークにも不完全性や恣意性がつきまとう。ベンチマークが異なれば、性能値が異なって示される。例えば、あるアプリケーションは高速に実行できても、別のアプリケーションでは遅いかもしれない。(おまけに、システム設計段階で、特定のベンチマークの結果向上のためにハードウェアやソフトウェアにそのベンチマークだけを高速化できる機能を(こっそりと)加えるメーカーがある。だがこの機能はそのベンチマークと類似のアプリケーションでは役に立たないことが多いので、ベンチマークの数値を鵜呑みにするわけにはいかなくなる。)

消費電力 編集

電力効率が良く、低消費電力(消費電力が小さいこと)は、特にコンピュータが持ち運ばれるようになってからはコンピュータ設計する上で重要度が増してきた。またプロセッサの単位面積当たりのトランジスタ数が増えるに従い、電力効率が重要な観点となってきた。以前は、電力消費量を抑えると、性能が低下したりコストが増大してしまうことが起きた。ARMアーキテクチャは、処理性能を十分に保ったまま低消費電力を実現し、スマートフォンタブレットなどモバイルコンピューティング用途(モバイル機器)では標準的な存在となった。また、組み込みシステム用プロセッサでは、(組み込み対象となる機器にもよるが)消費する電力が小さいことが至上命題だが、性能はほどほどでよい、というものも多いので、消費電力の低減を最優先してあえて処理性能を抑える設計を行う場合もある。

歴史 編集

用語史

コンピュータ関連での「アーキテクチャ」という用語の使用は、1959年、IBMの研究所に所属していたライル・R・ジョンソン[注釈 4]フレデリック・ブルックスまで遡る。ジョンソンはStretchことIBM 7030について、研究報告を書いた。彼は、コンピュータについて詳細を省いてある水準の記述をしたものを、それまで使われていた「マシン構成」[注釈 5]ではなく「システムアーキテクチャ」[注釈 6]と称した。その後、Stretchの設計者の1人である ブルックスが、ある本[11]で、「コンピュータ・アーキテクチャは他のアーキテクチャと同様、構造の利用者のニーズを決定する技法であり、それらニーズに合った経済的にも技術的にも可能な限り最適な設計を行うことである」と書いている。ブルックスは System/360 の開発でも大きな役割を果たし、そこで「アーキテクチャ」という用語は「ユーザーが知る必要のある詳細」という定義になっていった。その後、コンピュータ業界で「アーキテクチャ」という用語が様々に使われるようになった。

論文で初めて「アーキテクチャ」という用語が使われたのは、1964年の IBM System/360 に関するものであった[12]。この論文ではアーキテクチャを「プログラマから見えるシステムの属性群。すなわち、概念的構造と機能的挙動であり、データフローや制御の構成、論理設計や物理的実装とは異なる」と定義した。この定義において、「プログラマ」から見たコンピュータの機能的挙動が鍵となっている。アーキテクチャに含まれる概念的構造は機能的挙動を理解するための補助的なものであり、ユースケースの範囲を拡大可能にする。

プロセッサ内部の処理方法やメモリアクセス方法(マイクロアーキテクチャ)がコンピュータ・アーキテクチャとされるようになったのは、もっと後のことである。

各部分要素のアーキテクチャ 編集

注釈 編集

  1. ^ 英語では通常、コンポーネント componentと言う。
  2. ^ 《単体》は英語でディスクリート(discrete)と言い、トランジスタやダイオードや抵抗など単体の半導体部品を、集積回路と区別して、ディスクリート部品と言い、単体部品を基板で組み合わせて作る回路をディスクリート回路と言う。
  3. ^ 補足情報。アーキテクチャの話ではなく、話がかなりそれてしまうが、プロセッサやCPUのアーキテクチャが決定した後の、設計工程について。 CPU設計では、ISAとマイクロアーキテクチャが決定されると、実際のハードウェアが設計される。この設計工程を一般に「実装」と呼ぶ。実装はアーキテクチャ定義には通常含まれず、ハードウェア設計に含まれる。 実装はさらに以下の3段階に分けられる。
    • 論理実装/設計 - マイクロアーキテクチャで定義されたブロックを論理式あるいは論理ゲートレベルの回路で表す。
    • 回路実装/設計 - マイクロアーキテクチャ上のブロック(あるいはそれと等価な論理式)やその論理回路をトランジスタレベルのデジタル回路で表す。
    • 物理実装/設計 - 回路図に従い、チップ上の部品配置や基板上の部品配置、基板間の接続ルートなどを設計する。
  4. ^ : Lyle R. Johnson
  5. ^ : machine organization
  6. ^ : system architecture

出典 編集

  1. ^ [1]
  2. ^ 橋本昌嗣『コンピュータは私たちをどう進化させるのか: 必要な情報技術がわかる8つの授業』株式会社ポプラ社、2016年12月8日、7頁。ISBN 978-4-591-15285-0https://books.google.co.jp/books?id=ATPMDQAAQBAJ&pg=PP7 
  3. ^ 玉田俊平太『日本のイノベーションのジレンマ 第2版 破壊的イノベーターになるための7つのステップ』翔泳社、2020年8月25日、67頁。ISBN 978-4-7981-6638-4https://books.google.com/books?id=qCj4DwAAQBAJ&pg=PA67 
  4. ^ 最上千佳子『ITIL 4の教本 ベストプラクティスで学ぶサービスマネジメントの教科書』翔泳社、2022年3月16日、226頁。ISBN 978-4-7981-7421-1https://books.google.com/books?id=oiNlEAAAQBAJ&pg=PAPT266 
  5. ^ John L. Hennessy and David A. Patterson (2003年). Computer Architecture: A Quantitative Approach (Third Edition ed.). Morgan Kaufmann Publishers, Inc. ISBN 1558605967 
  6. ^ Phillip A. Laplante (2001年). Dictionary of Computer Science, Engineering, and Technology. CRC Press. pp. 94–95. ISBN 0849326915 
  7. ^ 小松「Intel 8080」
  8. ^ a b [https://edn.itmedia.co.jp/edn/articles/1812/03/news034_3.html 菅井賢、STマイクロエレクトロニクス「マイコンのアーキテクチャって何?」
  9. ^ 理化学研究所、ソフトウェア技術チーム「スーパーコンピュータとアプリケーションの性能
  10. ^ [2]
  11. ^ Planning a Computer System: Project Stretch、1962年
  12. ^ G. M. Amdahl, G. A. Blaauw and F. P. Brooks Jr., Architecture of the IBM System/360, IBM Journal of Research and Development, April 1964

参考文献 編集

学習用の参考図書や文献 編集

関連項目 編集

外部リンク 編集