対称型マルチプロセッシング
[Wikipedia|▼Menu]
.mw-parser-output .ambox{border:1px solid #a2a9b1;border-left:10px solid #36c;background-color:#fbfbfb;box-sizing:border-box}.mw-parser-output .ambox+link+.ambox,.mw-parser-output .ambox+link+style+.ambox,.mw-parser-output .ambox+link+link+.ambox,.mw-parser-output .ambox+.mw-empty-elt+link+.ambox,.mw-parser-output .ambox+.mw-empty-elt+link+style+.ambox,.mw-parser-output .ambox+.mw-empty-elt+link+link+.ambox{margin-top:-1px}html body.mediawiki .mw-parser-output .ambox.mbox-small-left{margin:4px 1em 4px 0;overflow:hidden;width:238px;border-collapse:collapse;font-size:88%;line-height:1.25em}.mw-parser-output .ambox-speedy{border-left:10px solid #b32424;background-color:#fee7e6}.mw-parser-output .ambox-delete{border-left:10px solid #b32424}.mw-parser-output .ambox-content{border-left:10px solid #f28500}.mw-parser-output .ambox-style{border-left:10px solid #fc3}.mw-parser-output .ambox-move{border-left:10px solid #9932cc}.mw-parser-output .ambox-protection{border-left:10px solid #a2a9b1}.mw-parser-output .ambox .mbox-text{border:none;padding:0.25em 0.5em;width:100%;font-size:90%}.mw-parser-output .ambox .mbox-image{border:none;padding:2px 0 2px 0.5em;text-align:center}.mw-parser-output .ambox .mbox-imageright{border:none;padding:2px 0.5em 2px 0;text-align:center}.mw-parser-output .ambox .mbox-empty-cell{border:none;padding:0;width:1px}.mw-parser-output .ambox .mbox-image-div{width:52px}html.client-js body.skin-minerva .mw-parser-output .mbox-text-span{margin-left:23px!important}@media(min-width:720px){.mw-parser-output .ambox{margin:0 10%}}

この記事は検証可能参考文献や出典が全く示されていないか、不十分です。出典を追加して記事の信頼性向上にご協力ください。(このテンプレートの使い方
出典検索?: "対称型マルチプロセッシング" ? ニュース ・ 書籍 ・ スカラー ・ CiNii ・ J-STAGE ・ NDL ・ dlib.jp ・ ジャパンサーチ ・ TWL(2017年9月)

対称型マルチプロセッシング(たいしょうがたマルチプロセッシング、: Symmetric Multi-Processing、SMP)とは、物理メモリを共有して管理する「メモリ共有型並列コンピューティングマルチプロセッシング)方式」のこと。

対義語は非対称型マルチプロセッシング(英語版)(: Asymmetric Multi-Processing、AMP)[1]
アーキテクチャ

対称型マルチプロセッシングとは、特定のCPUに非対称的に割り付けられた処理に依存することなく、全てのCPUに対して対称的、均一的に処理が割り付けられた複数プロセッサによる並列処理方式のことを言う。1つのCPUが複数の均一コアを持つ場合や、インテルハイパースレッディング・テクノロジーなどの同時マルチスレッディング (SMT) もSMPに含まれる。

オペレーティングシステム (OS) のカーネルとCPUキャッシュ同期機構により仮想化されたシステムメモリ、および各種資源を細かく管理するロック制御方式を持ち、ソフトウェア/ハードウェアレベルの割り込み処理を均一的にCPUに割付け、その処理単位に必要な資源をロックして処理を行う。そのため、サーバの外から見るとあたかもひとつのCPUにて動作するサーバのように見える。

ただしコンピュータが行う処理のリソースが競合するような場合は逐次処理(SMPから見て非対称)とならざるをえず並列最適化は難しい。実際、多くのSMP構成サーバにおいて、ハードウェア割り込みを特定のCPUに割り付けたり、起動処理では特定のマスタブートCPUによりIPL(初期プログラムローダ)がOSのカーネルをメモリ上に展開した後、スレーブCPUが組み込まれる形をとったりするなど、完全な対称形とはならない。
歴史

当初、UNIXのSystem7やUNIVACIBMなどの汎用機にて試験的に構築/導入されたSMPだったが、汎用プロセッサの登場後、本格的な研究/開発が行われてきた。特に学術的な研究にUNIXが使用されたこともあり、UNIXのSVR4系などでの実装研究が進んでいた。

1990年代前半からMIPSR4000シリーズ、SPARCシリーズといったマルチプロセッシングを前提としたRISCプロセッサが登場し、マルチプロセッサ処理を前提としたUNIX SVR4.2MPの国産UNIX(UX/4800UXP/DSなど)および、サン・マイクロシステムズSolarisなどでの採用が急速に進み、サーバにおける処理高速化手法の主流として汎用化していた。

しかし、安価な量産系サーバにおいては、CPU/メモリ間の接続はバス方式が主体であり、速度もそれほど速いものではなかったため、SMPの最大構成は8 CPU、実効性能で単一CPUの5倍程度に留まり続けた。

1980年代後半に高価な特殊サーバにて使用されていたCPU間/メモリ間のクロスバースイッチが量産サーバにも採用され、ギガビット単位での情報速度を確保できるようになって以降、32/64/128 CPUといった大規模SMP構成がとれるようになっている[注釈 1]

この頃のSMPのバスアーキテクチャは、NUMA (Non-Uniform Memory Access) と言う、複数プロセッサが共有するメインメモリへのアクセスコストが、メモリ領域とプロセッサに依存して均一でないアーキテクチャを採用したシステムが一般的となっている。

2006年現在、ほぼ全てのUnix系OS(商用UNIX、Linuxなど)および、Windows NT系OSでSMPは採用されている。また、パーソナルコンピュータ (PC) やスマートフォン/タブレットのような一般消費者向けデバイスも、登場当初はシングルコアCPUだったが、PCは2000年代に、スマートフォン/タブレットは2010年代に、2つ以上の物理コアやSMTによる論理コアを搭載したマルチコアCPUを採用するSMP環境が主流になった。なお、当初はすべてのコアが同一の動作クロック周波数すなわちピーク処理性能を持つ対称型マルチコアが主流だったが、のちにARMアーキテクチャおよびx86アーキテクチャにおいて、big.LITTLEのような動作クロック周波数の異なる2種類のコア(Pコア、Eコア)をそれぞれ複数搭載する異種CPUトポロジー構成も登場している[2]。ただし、異種CPUトポロジーは負荷分散による電力効率向上を目的とした構成であり、完全なメモリ共有型かつ各コアのサポートする命令セットは同一であるため、分類としてはAMPではなくSMPになる。
耐障害性など

商用UNIX向けの上位クラスのサーバや基幹系Windowsサーバの一部においては、ブートCPUを固定化せず、正常に動作するCPUの何れか(故障CPUが無い場合は固定的)によりIPLが実行され、ブート処理を行う。PCや簡易なSMP構成の場合、ブートCPUが固定されているのが普通である。

全てのSMP対応OS/サーバにおいては、起動時にCPU障害が見つかった場合には、異常CPUはシステムに組み込まれず、正常なCPUのみで動作することになる。一方、商用UNIXで高機能基幹系サーバを使用する場合、OSとファームウェアレベルにてCPUやキャッシュの機能チェックが稼動時に定常的に行われ、特定レベル以上のCPU障害の場合に動的にCPUを切り離し、業務を継続する。それ以外のサーバにおいては、NMI(Non-Maskable Interrupt、マスク不可割り込み)にてUNIX系の場合はカーネルパニックを引き起こし、Windowsの場合はブルースクリーンに移行することで、システムが異常停止してしまう。

Linuxにおいても、2.6カーネル以降、NUMA/ブートCPUの移動などを組み込んだ商用大規模サーバで使用することが可能であり、富士通PrimeQuest日本電気のNX7700i、IBMのPシリーズなどが提供されている。
脚注
注釈^ 最初のクロスバー型CPUはInmos(@media screen{.mw-parser-output .fix-domain{border-bottom:dashed 1px}}現在[いつ?]のTomson Semicondactor)のTransputerシリーズ。

出典^ SMPとAMP マルチコアプロセッサの特徴について解説 - クミコミ
^ Energy Aware Scheduling ? The Linux Kernel documentation

関連項目

並列コンピューティング

NUMA

マルチプロセッシング

非対称型マルチプロセッシング(英語版)

ヘテロジニアスマルチコア

外部リンク

NAG Fortran SMPライブラリ










並列計算
総論

クラウドコンピューティング

グリッド・コンピューティング

高性能計算

コンピュータ・クラスター

分散コンピューティング


次ページ
記事の検索
おまかせリスト
▼オプションを表示
ブックマーク登録
mixiチェック!
Twitterに投稿
オプション/リンク一覧
話題のニュース
列車運行情報
暇つぶしWikipedia

Size:20 KB
出典: フリー百科事典『ウィキペディア(Wikipedia)
担当:undef