JP4404373B2 - 半導体集積回路 - Google Patents

半導体集積回路 Download PDF

Info

Publication number
JP4404373B2
JP4404373B2 JP2007187978A JP2007187978A JP4404373B2 JP 4404373 B2 JP4404373 B2 JP 4404373B2 JP 2007187978 A JP2007187978 A JP 2007187978A JP 2007187978 A JP2007187978 A JP 2007187978A JP 4404373 B2 JP4404373 B2 JP 4404373B2
Authority
JP
Japan
Prior art keywords
instruction
execution
circuit
decoding
processing
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.)
Expired - Fee Related
Application number
JP2007187978A
Other languages
English (en)
Other versions
JP2007310905A (ja
Inventor
哲也 福岡
健司 宮崎
勝一 友部
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Hitachi Ltd
Original Assignee
Hitachi Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Hitachi Ltd filed Critical Hitachi Ltd
Priority to JP2007187978A priority Critical patent/JP4404373B2/ja
Publication of JP2007310905A publication Critical patent/JP2007310905A/ja
Application granted granted Critical
Publication of JP4404373B2 publication Critical patent/JP4404373B2/ja
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Classifications

    • 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
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

Landscapes

  • Executing Machine-Instructions (AREA)
  • Memory System Of A Hierarchy Structure (AREA)
  • Power Sources (AREA)
  • Advance Control (AREA)

Description

この発明は、半導体集積回路の低消費電力化技術に関し、例えば仮想記憶の使用のためにアドレス変換用バッファメモリが設けられたLSI(大規模集積回路)や、例えばVLIW(Very Long Instruction Word)方式のプロセッサコアを備えたLSIに適用して有用な技術に関する。
一般に大規模なデータを扱うプロセッサでは仮想記憶をサポートしている。仮想記憶とは、例えば、DRAM(Dynamic Random Access Memory)などの主記憶、並びに、ハードディスクなどの2次記憶を有するシステムにおいて、2次記憶に仮想記憶用の広大な記憶領域を確保するとともに、この記憶領域のデータのうちアクセス要求のあった一部分を主記憶に写してプロセッサからアクセスさせるようにすることで、限られた主記憶のアドレス空間をあたかも広大なアドレス空間を実装しているかのように見せる技術である。
仮想記憶を使用する場合には仮想的な論理アドレスを用いてプロセッサからアクセスが行われるため、この論理アドレスを主記憶上の物理アドレスに変換する必要がある。このアドレス変換は仮想記憶にアクセスするたびに行う必要があることから、仮想記憶をサポートするプロセッサでは、アドレス変換による性能のオーバーヘッドを軽減するため、このアドレス変換を高速に行うアドレス変換バッファ(TLB:Translation Look-aside Buffer)と呼ばれるメモリ回路を備えるのが一般的である。
ところで、プロセッサアーキテクチャーの1つに、並列に動作可能な複数の実行回路を備え、複数の命令コードが1つにまとめられた命令を受け、これら複数の命令コードを複数の実行回路で並列処理するようにしたVLIW(超長形式機械命令)と呼ばれる方式のものがある。VLIWの方式では、各命令コードの同時実行可能性についてハードウェアが判断する必要がなく、プロセッサは1命令中に含まれる複数の命令コードを、その配置に対応づけられた各実行回路に送って処理するだけで、並列処理による高いスループットを得ることが出来る。
このようなVLIWの方式では、同時実行される命令コードの数が少ない場合に、有効的な処理を伴わないNOP(Non Operation)命令のコードを挿入して命令長を合わせる必要がある。また、VLIW方式のプロセッサの中には、命令長を合わせる目的で挿入されるNOP命令を省く代わりに、同時実行される命令コードのグループ境界と各命令コードの配置の情報とが示された命令位置情報を付加することで命令を圧縮し、この圧縮された命令をプロセッサ内部で元に復元してデコード処理と実行処理とを行うようにしたものもある。このような圧縮命令により、命令キャッシュの効率の向上が図れる。
現在、LSIの高速化、大規模化に伴ってLSIの消費電力は増加の一途をたどっている。また、携帯電話や携帯型情報端末(PDA)など、バッテリーで駆動する電子機器にLSIが搭載されることも多くなっているため、LSIの低消費電力化の要求はますます高まってきている。
そこで、本発明者らは上記のアドレス変換バッファとVLIW方式のプロセッサにおける消費電力を低減できないか検討した。
アドレス変換バッファの低消費電力化を図る従来技術としては、例えば特開平11−134256号、特開平8−95864号、特開2000−148589号公報にそれぞれ開示の技術があった。
これらのうち特開平11−134256号に開示の技術は、アドレス変換を行う前に論理アドレスの上位ビットが前回のものと同一か比較して、同一である場合にアドレス変換バッファでアドレス変換を行わずに、前回の変換結果を使ってアドレス変換を行うようにすることで低消費電力化を図るものである。
また、特開平8−95864号に開示の技術は、同様に、アドレス変換を行う前に論理アドレスの上位ビット(仮想ページ番号)が前回のものと同一か比較し、同一である場合に前回の変換結果を使用し、その間、アドレス変換バッファを非活性状態とすることで低消費電力化を図るものである。
特開2000−148589号に開示の技術は、メモリ管理ユニットに設けられた複数のアドレス変換バッファのうち、常に1つのアドレス変換バッファしか動作しないように制御することで低消費電力化を図るものである。
特開平11−134256号公報 特開平08−095864号公報 特開2000−148589号公報
上記従来の技術のうち、特開平11−134256号に開示の技術は、アドレス変換動作で消費される電力を削減するものであり、アドレス変換バッファの待機時の電力の削減は図られていないため、不十分なものであった。一般に、アドレス変換バッファは、高速なキャッシュメモリと同等の構成を有しており、実施の形態で詳述するように待機中に消費される電力も無視できない。
また、特開平8−95864号に開示の技術は、アドレス変換バッファを非活性状態にして低消費電力化を図っているが、低消費電力化を図る期間が論理アドレスの上位ビット(仮想ページ番号)が前回と同じとなった期間だけであり、その他の期間についてまだまだ低消費電力化できる余地があると考えられる。また、この技術では、論理アドレスの上位ビットが前回と同じものか比較を行って、その結果が不一致である場合にアドレス変換バッファを活性化させてアドレス変換動作を開始させるため、アドレス変換に必要なタイミングが増加して、高速性能を劣化させる要因になることが判った。一般に、アドレス変換バッファのパスはクリティカルであるので、アドレス変換バッファにおけるタイミング増加はシステムの処理速度の低下につながってしまう。
また、プロセッサコアの消費電力を低減する従来技術としては例えば特開2001−22582号公報に開示の技術がある。この公報には、無関係な命令が入力された場合に、この命令の代わりにNOP命令を命令コードのレジスタやデコーダに出力するようにしたり、命令コードのレジスタに入力されるクロックを停止したりして低消費電力化を図る技術が開示されている。
しかしながら、上記従来の技術においても、NOP命令をデコード回路や実行回路に送った場合に、このNOP命令に対してデコード回路や実行回路は他の命令と同様に動作しているため、まだまだ不必要な電力消費が生じているのが判った。また、上記のように、命令コードが無関係なものか比較・検出を行い、その結果、無関係なものであった場合に低消費電力化の制御を行っていたのでは、その比較・検出にかかるタイミング増加によって、プロセッサの処理速度のボトルネックとなって動作周波数を余り高くすることが出来なくなったり、或いはプロセッサの処理に必要なステップ数が増加するなど、プロセッサの処理速度に悪影響が生じることが考えられた。
この発明の目的は、アドレス変換バッファの速度性能を劣化させることなくアドレス変換バッファについて十分に低消費電力化が図られた半導体集積回路を提供することにある。また、プロセッサの処理速度に影響を与えることなくVLIW方式のプロセッサコアの部分について十分に低消費電力化が図られた半導体集積回路を提供することにある。
この発明の前記ならびにそのほかの目的と新規な特徴については、本明細書の記述および添附図面から明らかになるであろう。
本願において開示される発明のうち代表的なものの概要を説明すれば、下記のとおりである。
すなわち、仮想記憶へのアクセスがない物理記憶アクセスモードのときや、キャッシュでミスヒットとなってキャッシュデータを更新している間、或いは、同じ論理ページアドレスで且つこのアドレス範囲の境界以外にアクセスがあったときに、少なくともアドレス変換バッファのタグ記憶部とエントリ記憶部とを例えば動作クロックを断つなどして非アクティブにするものである。このような手段により、アドレス変換バッファの速度性能を劣化させることなくアドレス変換バッファの低消費電力化を図ることが出来る。
また、本発明に係る半導体集積回路は、圧縮命令を復元して実行する機能を有したVLIW方式のプロセッサコアにおいて、圧縮命令を復元する処理ステージに命令位置情報に基づきNOP命令が挿入されていた箇所を検出して、その箇所に対応するデコード回路と実行回路とを例えば動作クロックを断つなどして非アクティブにするものである。このような手段によれば、プロセッサの処理速度を低下させることなくプロセッサコアの低消費電力化を図ることが出来る。
本願において開示される発明のうち代表的なものによって得られる効果を簡単に説明すれば下記のとおりである。
すなわち、本発明に従うと、処理スピードに影響を与えることなく、アドレス変換テーブルにおける消費電力の低減が図れるという効果がある。
また、本発明に従うと、VLIW方式のプロセッサにおいて処理スピードに影響を与えることなくNOP命令に係る処理について消費電力の低減が図れるという効果がある。
以下、本発明の好適な実施例を図面に基づいて説明する。
[第1実施例]
図1は、本発明の実施例のプロセッサコアを搭載したシステムLSIの全体構成を示すブロック図である。
この実施形態のシステムLSIは、特に制限されるものではないが、例えば携帯型の電子機器に搭載されてシステム全体の制御や動画像のデータ処理等を行うものもある。このシステムLSIには、プログラムを実行するプロセッサコア20、外部接続されるSDRAM(Synchronous DRAM)等の主記憶に対してデータアクセス制御を行うメモリインターフェース10、動画像データのエンコードやデコードに必要な演算処理を行うコプロセッサ30、動画像の大きさの伸縮に必要なデータ処理を行うビデオスケーラ40、外部接続される入出力機器とのデータのやり取りを行うIOユニット50、プロセッサコア20にデータを介さず直接的に周辺モジュール・主記憶間のデータアクセスを可能にするDMA(Direct Memory Access)コントローラ60、各モジュール間のデータ転送に使われる内部バス70、通信モジュールや大容量記憶装置などの周辺機器が接続される外部バスと内部バス70との間でデータの受渡しを行う外部バスインタフェース80などが設けられている。
上記プロセッサコア20は、VLIWの命令制御方式のもので、且つ、VLIWの命令からNOP命令を省く代わりに各命令コードの位置情報が付加された圧縮命令に対応可能なものであり、この圧縮命令を読み込むインストラクションキャッシュ(以下、Iキャッシュと略す)24と、圧縮命令を伸長して復元する命令ユニット21と、1命令中に含まれる同時実行される複数の命令コードをそれぞれデコードする複数のデコード回路を有する命令デコーダ22と、複数の命令コードのそれぞれについて演算処理を行う複数の実行回路を有する実行ユニット23と、演算データや結果データの読み書きが行われるデータキャッシュ(以下、Dキャッシュと略す)25とを備えている。
この実施例のシステムLSIは、外部バスに接続されるハードディスクなどの大容量記憶装置を用いて、主記憶に割り当てられる物理的なアドレス空間よりも大きな仮想的なアドレス空間を提供する仮想記憶が使用可能となったものである。そして、このような仮想記憶の機能を実現するため、仮想記憶へデータアクセスを行うモジュール(Iキャッシュ24、Dキャッシュ25、DMAコントローラ60)には、仮想記憶上の論理アドレスを主記憶の物理アドレスに変換するアドレス変換バッファ100がそれぞれ設けられている。
図2には、上記のアドレス変換バッファとその周辺部分のブロック構成図を示す。
アドレス変換バッファ100は、仮想記憶上の論理アドレスを上位所定数ビット(論理ページアドレスと呼ぶ)と残りの下位ビット(ページ内アドレスと呼ぶ)とに分け、この論理ページアドレスを対応する物理アドレスのページアドレス(物理ページアドレスと呼ぶ)に変換し、この物理ページアドレスと残りのページ内アドレスとを合わせたものを変換後の物理アドレスとして主記憶にアクセスさせるものである。なお、このアドレス変換バッファ100は、仮想アドレス空間を多重化して扱うことが可能なものであり、別途設定される空間識別子ASIDに基づいて多重化された仮想アドレス空間のうち何れか1つが選択されて、該仮想アドレス空間を用いた仮想記憶へのアクセスが行われるように構成されている。この多重化技術は公知のものである。
このアドレス変換バッファ100は、入力された論理ページアドレスを対応する物理ページアドレスに変換するTLB主要部110と、TLB主要部110からの物理ページアドレスの出力を保持する出力レジスタ120と、論理ページアドレス又はレジスタ120に保持された物理ページアドレスの何れかを選択的に出力するバイパス回路130と、TLB主要部110の内部クロックφiの供給を許可又は禁止するクロックイネーブル信号を生成するクロックイネーブル生成回路140と、多重化された仮想アドレス空間の何れか1つを選択する空間識別子ASIDや仮想記憶の使用の有無を示す仮想記憶バリッドビットVs等が格納されるステータスレジスタ150等を備えている。
TLB主要部110は、空間識別子ASIDや論理ページアドレスをタグ(TAG)情報として記憶するタグ記憶部111と、物理ページアドレスをエントリ情報として記憶するデータ記憶部112と、入力された空間識別子ASIDや論理ページアドレスとタグ情報とを比較して一致するものがあるか判定する図示略のタグ情報比較判定回路とからなる従来と同様の構成と、上記タグ記憶部111やデータ記憶部112へのクロックφiの供給と遮断とを行うゲーテッドクロック回路113等を備えている。また、タグ記憶部111には、空間識別子ASIDや論理ページアドレスが1個ずつ格納されるデータエントリごとにそのデータエントリの有効・無効を示すバリッドビットが設けられ、このビットが有効であるデータエントリが比較判定の対象となり得るようになっている。
ステータスレジスタ150の空間識別子ASIDやバリッドビットVsは、プロセッサコア20が実行しているプログラム或いはOS(Operating System)のソフトウェア処理に従って適宜書き換えられるものである。また、バリッドビッドVsは、仮想記憶を全く使用しない場合には常に"0"とされるが、仮想記憶を使用している場合には、OS等により主記憶中の仮想記憶の展開領域へアクセスが生じる際には"1"に書き換えられ、その他、主記憶中の通常の記憶領域へアクセスが生じる際には"0"に書き換えられるようになっている。
また、バイパス回路130の選択パスを決めるバイパス信号は、図示しない論理組合せ回路により、ステータスレジスタ150の仮想記憶バリッドビットVsが"0"に切り換わったら次のクロック信号φの立ち上がりでロウレベルにされて論理アドレス側のパスを選択し、他方、仮想記憶バリッドビットVsが"1"に切り換わったら次のクロック信号φの立ち上がりでハイレベルにされてレジスタ120側のパスを選択するようになっている。
図3には、タグ記憶部やデータ記憶部の構成例の一部を示す。
この実施例のタグ記憶部111およびデータ記憶部112は、図3にその一部を示すように、SSRAM(Synchronous Static Random Access Memory)により構成されたものである。SSRAMは、4個の素子から構成されるメモリセルMCや、メモリセルMCを選択するワード線WL、メモリセルMCから記憶データを読み出す1対のビット線BL,/BL、Yアドレスに従って出力データを選択するカラムスイッチSWc、メモリセルMCから1対のビット線BL,/BLに出力された電位を増幅出力するセンスアンプSA、ビット線BL,/BLやセンスアンプSAをプリチャージしてデータ読出し可能な状態にするプリチャージ用MOSFET(以下、プリチャージMOSと略す)QPなどを備えている。そして、内部クロックφi(外部から供給されたクロック信号φをゲーテッドクロック回路113を介して内部に導いたクロック)がロウレベルのときにプリチャージMOS QPがオン状態となってプリチャージが行われ、内部クロックφiがハイレベルになったときに選択されたメモリセルMCからデータが読み出され、その後、センスアンプSAの出力が確定したら、内部クロックφiがロウレベルにリセットされるように構成されている。内部クロックφiをリセットするタイミングは論理ゲートG1〜G4により決定され、センスアンプSAの出力は内部クロックφiがリセットされる前に出力先のラッチ回路に保持される。
従って、この実施例のタグ記憶部111およびデータ記憶部112は、アドレス線やワード線WLの選択をしなくても、内部クロックφiが供給される限り、プリチャージMOS QPのオン・オフ動作によりセンスアンプSAやビット線BL,/BLに電流が流れて電力消費が生じるようになっている。このような性質は高速なデータの読出しが必要となるアドレス変換バッファの記憶部において一般的なものであり、例えば、タグ記憶部111やデータ記憶部112を連想メモリを用いて構成した場合などにおいても同様に生じるものである。
図4には、図2のクロックイネーブル生成回路140に含まれる一部の回路図を示す。
図2のクロックイネーブル生成回路140には、入力された論理ページアドレスが前回のアドレス変換のものと同じで、且つ、ページ内アドレスが論理ページアドレスにより示されるアドレス範囲の境界部分に含まれない場合に、クロックイネーブル信号CEを無効にする無効信号を生成する回路が含まれている。この回路は、図4に示すように、前回入力された論理ページアドレスを格納するレジスタ143と、該レジスタ143の出力と今回入力された論理ページアドレスを比較する比較器145と、今回アクセス要求があったページ内アドレスが境界アドレス(例えば全ビット「0」か全ビット「1」)か否かを比較する比較器146A,146Bと、これら比較器145,146A,146Bの出力が上記の条件を示すものとなった場合にクロックイネーブルCEを無効にする信号を生成する論理ゲート147とから構成されるものである。
なお、ここでは、ページ内アドレスの境界アドレスとして全ビット「0」と全ビット「1」の場合を例示したが、例えば、1回のデータアクセス量に相当するアドレスの範囲がアドレスの下位nビットである場合には、ページ内アドレスの下位nビットを除くビットが全て「0」か「1」となるアドレス範囲を境界部分とすることで対応することが出来る。
クロックイネーブル生成回路140には、その他、キャッシュストール信号やステータスレジスタ150のバリッドビットVsの値を示す信号が入力され、キャッシュストール信号がハイレベルの間、或いはバリッドビッドVsが"0"の場合に、クロックイネーブル信号CEを無効とするように論理が組まれている。ここで、キャッシュストール信号とは、インストラクションキャッシュ24やデータキャッシュ25においてキャッシュミスの判定が発生し、必要なデータを主記憶からロードしているためキャッシュアクセスが不可能であることを外部に知らせる信号である。
図5(a)〜図5(c)には、TLB主要部110の内部クロックφiが停止される状態を説明するタイムチャートを示す。図5(a)は、ステータスレジスタのバリッドビットVsの値に応じてアドレス変換バッファが動的に停止制御される状態を説明するタイムチャート、図5(b)はキャッシュストール信号によりアドレス変換バッファが動的に停止制御される状態を説明するタイムチャート、図5(c)はメモリアクセスされるアドレスに応じてアドレス変換バッファが動的に停止制御される状態を説明するタイムチャートである。
この実施例のアドレス変換バッファ100においては、クロックイネーブル生成回路140から出力されるクロックイネーブルCEが無効(ロウレベル)とされるのは次の3つの条件(A)〜(C)の場合がある。
1つ目の条件(A)は、ステータスレジスタ150の仮想記憶バリッドビットVsが"0"となっている場合である。仮想記憶バリッドビッドVsが"0"となる場合は、一つにはシステムが初めから仮想記憶を使用しない場合がある。この場合、仮想記憶バリッドビッドVsは静的に"0"とされるので、クロックイネーブルCEはシステムの動作中に常に無効とされる。
仮想記憶バリッドビットVsが"0"となるもう一つの場合は、主記憶の仮想記憶データの展開領域以外のアドレスへアクセスが行われる場合である。この場合、OSにより仮想記憶バリッドビットVsが"0"に書き換えられるので、図5(a)に示すように、それに伴ってクロックイネーブルCEが無効とされる。そして、仮想記憶バリッドビットVsが"0"に書き換えられた後、次のクロック信号φの立上りによりバイパス信号がハイレベルにされ、これによりバイパス回路130において論理アドレス側のパスが選択されて論理アドレスが物理アドレスとして出力される。
クロックイネーブルCEを無効にする2つ目の条件(B)は、アドレス変換バッファ100と主記憶との間に介在するキャッシュメモリからキャッシュミスによるハイレベルのキャッシュストール信号が出力される場合である。図5(b)に示すように、キャッシュストール信号がハイレベルになるとクロックイネーブルCEが無効となって内部クロックφiが停止される。
3つ目の条件(C)は、図4の論理ゲート147からクロックイネーブルCEを無効にする信号が出力される場合である。すなわち、図5(c)に示すように、論理ページアドレスが「A」で続いた後に「B」に切り換わりその後「B」で連続するような場合(但し、ページ内アドレスがページ範囲の境界でないとする)、ページ内アドレスが「A」となっている2番目のサイクルや、「B」となっている2番目以降のサイクルに論理ゲート147の出力に基づきクロックイネーブルCEが無効とされて、アドレス変換バッファ100からはそれぞれページ内アドレスが変わった始めのサイクルで変換されレジスタ120に格納されている物理ページアドレスが出力される。
但し、同一の論理ページアドレスが続いている場合でも、ページ内アドレスがページ範囲の境界(例えば全ビット"0"や全ビット"1")であった場合には、論理ゲート147の出力に基づきクロックイネーブルCEが有効とされて、TLB主要部110が動作するようになっている。
以上のように、この実施例のシステムLSIによれば、アドレス変換バッファ100による論理ページアドレスの変換動作が不要なときに、TLB主要部110の内部クロックφiが停止されて消費電力の低減を図ることが出来る。
また、論理ページアドレスが前回と同一のときに内部クロックφiを停止する場合には、ページ内アドレスがアドレス範囲の境界部分にある場合を除外して制御されるので、この境界部分を含んで2つの論理ページアドレスにまたがる連続アクセスが行われた場合に、アドレス変換バッファ100が停止されないので、メモリアクセス処理が一次的に停止してシステムの処理スピードに影響を与えるといったことが回避される。
なお、仮想記憶を全く使用しない場合には、アドレス変換バッファ100を内部電源から切り離してリーク電流による消費電力の低減を図るようにしても良い。具体的には、ステータスレジスタ150の仮想記憶バリッドビットVsの読み出しをロウレベル固定とし、TLB主要部110と電源とをスイッチMOSFETにより切り離す。そして、TLB主要部110の出力にトライステートバッファを設け、TLB主要部110の入出力間に貫通電流が流れないように制御する。さらに、このような状態と、仮想記憶を使用する場合の状態とをボンディングオプション等で切り替え可能に構成することで、同一のマスクを用いた半導体製造プロセスで仮想記憶ありと無しの2製品を生産することも可能となる。
なお、本発明は上記実施例に限定されるものではなく、その要旨を逸脱しない範囲で種々変更可能であることはいうまでもない。
例えば、上記実施例においては、キャッシュメモリへのアクセスが行われない期間にTLB主要部110の内部クロックφiを停止させるために、キャッシュストール信号を用いて内部クロックφiを停止させる制御を行っているが、キャッシュストール信号を用いず、種々の状態検出によりメモリアクセスの要求がないことを検出してその検出信号に基づき内部クロックφiを停止させるようにしても良い。
以上の説明では主として本発明者によってなされた発明をその背景となった利用分野であるプロセッサを搭載したシステムLSIについて説明したがこの発明はそれに限定されるものでなく、アドレス変換テーブルを搭載したプロセッサ単体やMMU(Memory Management Unit)などの半導体集積回路に広く利用することが出来る。
[第2実施例]
次に、図1のプロセッサコア20の命令デコーダ22および実行ユニット23の部分の消費電力を低減する構成について説明する。
先にも述べたが、この実施例のプロセッサコア20は、VLIW形式の命令からNOP命令を省きその代わりに位置情報が付加された圧縮命令を入力して伸長および実行を行うように構成されたものである。
図6には、プロセッサコア20により命令を実行処理する過程を説明する図を示す。
プロセッサコア20の実行ユニット23には、VLIW命令の1命令中に含まれる複数の命令コードを同時に並列処理するため、複数の実行回路230〜233が設けられている。各実行回路230〜233は例えばメモリアクセス命令や演算命令など異種の命令処理を行うものが混在しているため、1命令中に含まれる複数の命令コードは予め定めされた配置でセットしなければならない。
実行ユニット23の前段に設けられている命令デコーダ22には、同様に複数のデコード回路220〜223が設けられ、複数の命令コードを同時にデコード処理するようになっている。
命令デコーダ22の前段には命令伸長回路210と命令バッファ211等を有した命令ユニット21が設けられて、該ユニット21において圧縮命令が伸長されるようになっている。
命令伸長回路210には、非圧縮の1個のVLIW命令の展開により1個の命令中に含まれる複数の命令コードが格納される複数の格納領域を有した展開バッファ214と、前段の命令バッファ211に格納された2命令分の命令位置情報をデコードしてこの2命令に含まれる複数の命令コードのうち、同時処理される同一グループの命令コードを展開バッファ214に展開させる命令位置情報デコーダ213などが設けられている。展開バッファ214には、命令バッファ211に格納された複数の命令コードをそれぞれ選択的に取り込むセレクタが設けられ、命令位置情報デコーダ213からのデコード信号によって何れかの命令コードをそれぞれラッチするように構成されている。
次に、命令デコーダ22と実行ユニット23を非アクティブに制御するための具体的構成を説明する。
上記複数のデコード回路220〜223には、ゲーテッドクロック回路225〜228を介して動作クロックφpが入力されるように構成されている。各ゲーテッドクロック回路225〜228の一方の入力端子には、命令位置情報デコーダ213からの制御信号V0〜V3が入力され、これらの信号によりデコード回路220〜223の動作クロックφpをそれぞれ別個に停止させることが可能になっている。
また、実行回路230〜233には、上記のゲーテッドクロック回路225〜228とフリップフロップ235〜238を介して動作クロックφpが入力されるように構成されている。すなわち、ゲーテッドクロック回路225〜228から出力されたクロック信号がフリップフロップ235〜238を介して1サイクル遅延されて実行回路230〜233に供給される。
上記の命令位置情報デコーダ213は、上記の命令伸長のための機能に加え、これらデコード回路220〜223および実行回路230〜233の動作クロックφpを停止して非アクティブにする制御手段としての機能を備えており、命令位置情報からNOP命令が省略されていた位置を検出したら、このグループのVLIW命令が命令デコーダ22でデコードされる処理サイクルに、検出したNOP命令の省略位置に対応するゲーテッドクロック回路225〜228の何れかにクロック停止の制御信号を出力するようになっている。
次に、上記のように構成されたプロセッサコア20による圧縮命令の実行処理の動作説明を行う。
図6の圧縮前命令COMに示されるように、VLIW命令は圧縮前において同時に実行される複数個(例えば4個)の命令コードを複数のフィールドに配列したものが1命令として扱われる。1つの命令コードの長さは、例えば32ビットである。同時実行される命令コードが所定個数に満たない場合には、命令コードのないフィールドに有効的な処理が行われないNOP命令が挿入されて命令長が合わせられる。
図7には、圧縮命令のデータ構造を説明する図を示す。
圧縮命令は、上記NOP命令を省いて有効な命令コードを配列順に詰めてまとめるとともに、同時処理される同一グループの命令コードの境界と各命令コードの配置が示された命令位置情報を1個の圧縮命令の最後に付加したデータ構成を有する。命令位置情報は、「フィールド0〜フィールド3」を表わす2ビットの位置情報と1命令の最後か否かを表わす1ビットのEND情報とからなる3ビットデータを、1個の圧縮命令中に含まれる4個の命令コードのそれぞれに対応させて配列した12ビットのデータである。このような圧縮方式では、VLIW命令の1個の命令コード長が長くなったり、1命令中に含まれる命令コードの数が多くなってNOP命令の挿入される割合が大きくなればなるほど、その圧縮率も大きくなる。
このようなVLIW命令の圧縮は、例えば、プログラムのコンパイル時に実施され、圧縮された状態で主記憶等に格納されており、そのままIキャッシュ24にロードされる。
圧縮命令がIキャッシュ24にロードされると、次に、命令ユニット21において圧縮命令を伸長する処理が行われる。伸長処理は、先ず、Iキャッシュ24から命令バッファ211に2個の圧縮命令を配列順に読み込み、次に、これら2個の圧縮命令の命令位置情報を命令位置情報デコーダ213によりデコードして、そのデコード信号により同時処理される同一グループの複数の命令コードをその位置情報に従った配置で展開バッファ214の各領域に格納することで達成される。ここで、圧縮前にNOP命令が挿入されていた箇所は、前回の命令コードが格納されたままとされる。
さらに、上記命令位置情報デコーダ213によるデコード処理において、ゲーテッドクロック回路225〜228に入力される制御信号V0〜V3のうち、命令コードが新たに配置されないフィールド(すなわち、圧縮前にNOP命令が挿入されていたフィールド)に対応する制御信号が次のサイクルにおいてロウレベルになるようにセットされる。
次に、上記展開バッファ214に展開された複数の命令コードが、命令デコーダ22の各デコード回路220〜223に送られて、それぞれデコード処理が行われる。但し、圧縮前にNOP命令が挿入されていた箇所に対応するデコード回路には、上記のゲーテッドクロック回路225〜228の制御により動作クロックφpが供給されないので、デコード処理は行われない。
命令デコードの処理がなされたら、次に、このデコード結果が対応する実行回路230〜233に送られて命令の実行処理が行われる。但し、圧縮前にNOP命令が挿入されていた箇所に対応する実行回路には、上記のゲーテッドクロック回路225〜228の制御とフリップフロップ235〜238の遅延により、実行処理のサイクルに動作クロックφpが供給されないので、実行処理は行われない。
実行処理がなされたら、その結果をDキャッシュ25又は所定のレジスタに書き込む処理を行って1命令の実行処理が完了する。
図8には、プロセッサコア20によるパイプライン処理の内容を説明する図を示す。
同図に示すように、上述した命令バッファ211への命令フェッチ「IF0」、圧縮命令を伸長して展開バッファ214に展開する処理「IF1」、命令デコーダ22による命令デコード(実行に必要なデータの読み出しを含む)「RD」、命令実行「EX」、並びに、結果の書込み処理「WB」は、それぞれがパイプライン処理の1つの処理ステージとなっている。従って、命令位置情報デコーダ213とゲーテッドクロック回路225〜228とフリップフロップ235〜238により行われる動作クロックφpの停止制御は、NOP命令が挿入されていた箇所の検出された命令が、デコード回路220〜223と実行回路230〜233へ移行されてそれぞれ処理されるサイクルに行われるようにタイミング制御されている。
以上のように、この実施例のシステムLSIによれば、VLIW命令の1命令中にNOP命令が含まれる箇所があった場合に、その命令コードのデコードと実行とを行うデコード回路220〜223および実行回路230〜233に動作クロックφpの供給が停止されるので、従来、NOP命令のデコードと実行にかかっていた消費電力を削減することが出来る。
また、圧縮前にNOP命令が含まれていた箇所に対して、圧縮命令を伸長するさいにNOP命令を復元する必要がなくなるため、NOP命令を復元する構成を省いて、この復元処理にかかっていた消費電力も削減することが出来る。
また、デコード回路220〜223や実行回路230〜233を停止させるか否かの検出処理ならびに停止させるフィールドの検出処理が、伸長処理において行われる命令位置情報のデコード処理と並行して行われるので、この検出のために処理スピードが低下するといった不都合が生じない。
ここで、先ず、NOP命令のデコード処理と実行処理とを停止することで得られる消費電力の削減効果について定量的に説明する。
図9は、NOP命令のデコードと実行を停止することで得られる消費電力の削減割合を表わしたグラフである。
同図において、「LSI−A」のグラフはVLIW方式のプロセッサコア20の他に周辺モジュールや周辺論理を多数含んだシステムLSIにおける消費電力削減割合、「VLIWコアロジック」のグラフはプロセッサコア20のみで見たときの消費電力削減割合を示している。また、「4整数演算VLIW」は整数演算を4並列で行うVLIW方式のプロセッサコアの場合、「8整数演算VLIW」は整数演算を8並列で行うVLIW方式のプロセッサコアの場合の消費電力削減割合を示している。
また、この消費電力削減割合の計算条件として、「LSI−A」のシステムLSIを構成するトランジスタ総数を約1490万個、その内、命令デコーダ22が占める個数を約20万個、実行ユニット23が占める個数を約330万個とし、また、実行するプログラム処理としてビデオデコード処理を対象とし、ループ等を考慮せずに1命令中に含まれるNOP命令コード数を1.99個、有効的な命令コード数を2.01個とした。
このような条件において、上記実施例のようにNOP命令のデコードと実行とを停止させると、プロセッサコア20の部分における消費電力の削減割合は、実行回路の停止により34.3%、デコード回路の停止により2.2%となり、大幅な節電効果が得られるという結論が得られた。
また、「LSI−A」のシステムLSIでは、周辺モジュールや周辺論理の消費電力は変化しないので消費電力の削減割合は少なくなるが、それでも実行回路の停止により11.2%、デコード回路の停止により0.7%の節電効果が得られるという結果が得られた。同様に、「4整数演算VLIW」や「8整数演算VLIW」のプロセッサコアについても、グラフに示すように大幅な節電効果を得ることが分かった。
次に、NOP命令の挿入箇所の検出がプロセッサの処理スピードに与える影響について、実施例の構成と、伸長処理の後にNOP命令の検出を行ってNOP命令のデコード処理と実行処理とを停止させる構成とで比較検討した内容の説明をする。
図10(a)と図10(b)には、NOP命令の挿入箇所検出がプロセッサの動作周波数に与える影響を説明する図を示す。図10(a)は実施例の場合、図10(b)は伸長処理の後にNOP命令の検出を行う場合のものである。
プロセッサコア20の各動作ステージでクリティカルなパスを有する部分は、一般にデコードステージ(RD)および実行ステージ(EX)であり、命令伸長ステージ(IF1)の処理には時間的な余裕が少し生じる。
本発明を適用しようとしている一つの従来製品について具体的な時間長を示せば、命令伸長ステージ(IF1)の処理に必要な時間長は3.17ns、デコードステージ(RD)と実行ステージ(EX)の処理に必要な時間長はそれぞれ3.3nsとなる。そして、この製品の最大動作周波数は300MHとなる。
主要な回路構成は変えずにこの製品に本発明を適用した場合、図10(a)に示すように、命令位置情報からNOP命令位置を検出して制御信号を出力するのに0.1ns、制御信号をデコード回路220〜223に動作クロックφpを供給するゲーテッドクロック回路225〜228に伝播するのに1.2ns、ゲーテッドクロック回路225〜228からデコード回路220〜223の入力段に設けられたデータラッチ用のフリップフロップまでクロック信号が伝播するのに0.2nsかかると概算できる。すなわち、NOP命令位置の検出からデコード回路220〜223を停止するのに必要なタイミング増分は1.5nsとなる。
しかしながら、これらの処理は、圧縮命令を伸長する処理と並行して行うことが出来るため、このタイミング増分1.5nsは命令伸長ステージ(IF1)の処理時間の中に包含することができ、プロセッサの処理スピードに影響を与えない。
一方、命令伸長後にNOP命令の検出を行う方式では、NOP命令の検出から制御信号を出力するに0.1ns、制御信号をクロックバッファまで伝播するのに0.2n、クロックバッファからデコード回路220〜223の入力フリップフロップまで伝播するのに0.2nsかかるとし、その合計のタイミング増分を0.5nsと概算しても、これらの処理は、圧縮命令を伸長した後に行う必要があることから、このタイミング増分0.5nsは命令伸長ステージ(IF1)の処理時間に加算され、命令伸長ステージ(IF1)の処理に必要な時間長は3.67nsとなる。この時間長はデコードステージ(RD)や実行ステージ(EX)の処理時間より長いものである。従って、このタイミング増分はプロセッサの処理スピードに影響して、その最高動作周波数は例えば272MHzなどと悪化する。
今後、配線材料の変更による信号伝播時間の低減と半導体プロセスの微細化によるトランジスタの高速化などにより、上記の命令伸長ステージ(IF1)の処理時間とデコードステージ(RD)や実行ステージ(EX)の処理時間は短縮し、互いの差も減少していくと考えられるので、上記のようなタイミング増分がプロセッサの処理スピードに与える影響は大きくなってしまう。
以上本発明者によってなされた発明を実施例に基づき具体的に説明したが、本発明は上記実施例に限定されるものではなく、その要旨を逸脱しない範囲で種々変更可能であることはいうまでもない。
例えば、上記実施例では、NOP命令が挿入されていたフィールドに対してNOP命令を復元しないように構成したが、展開バッファ214にNOP命令の命令コードを発生させる回路を設け、命令位置情報デコーダ213からのデコード信号によってNOP命令の挿入位置にNOP命令を復元するように構成しても良い。
更に、圧縮命令においてNOP命令が挿入されていた箇所は、前回の命令コードが格納されたままに限らず、任意の値を挿入可能となるような構成としても良い。
更に、本実施例では、4命令コードの並列演算の構成を前提としているが、4命令コードに限ることなく、それ以上の複数命令コード数、それ以下の複数命令コード数であってもNOP命令のデコード処理と実行処理とを停止させて低消費電力化を図ることが可能となる。
また、特に限定されないが、ゲーテッドクロック回路225〜228とフリップフロップ235〜238はプロセッサコア20内に配される。
また、この実施例は、NOP命令を省いた圧縮命令を伸長した後にデコードと実行とを行う構成を前提にしているが、NOP命令の挿入された非圧縮のVLIW命令を実行するプロセッサにおいても、動作周波数を低下させずにNOP命令のデコード処理と実行処理とを停止させて低消費電力化を図ることも可能である。すなわち、プロセッサのパイプライン処理の1ステージとして、命令をプリフェッチする処理ステージを追加するとともに、該プリフェッチの処理ステージでNOP命令の検出を行い、その結果、NOP命令が検出されたらデコーダ回路と実行回路とを停止させるように構成する。このような構成により、パイプライン処理のステージ数が1つ増えるが、プロセッサの動作周波数に影響を与えることなく、NOP命令のデコード処理と実行処理とを停止させて低消費電力化を図ることが出来る。
以上の説明では主として本発明者によってなされた発明をその背景となった利用分野であるプロセッサを搭載したシステムLSIについて説明したがこの発明はそれに限定されるものでなく、プロセッサ単体の半導体集積回路などに広く利用することが出来る。
本発明の実施例のシステムLSIの全体構成を示すブロック図である。 システムLSIに内蔵されたアドレス変換バッファとその周辺の構成を示すブロック図である。 アドレス変換バッファのTAG記憶部とデータ記憶部の一部のメモリ構成を示す回路図である。 図2のクロックイネーブル生成回路の一部を構成する回路図である。 図5(a)は、ステータスレジスタのバリッドビットの値に応じてアドレス変換バッファが動的に停止制御される状態を説明するタイムチャート、図5(b)はキャッシュストール信号によりアドレス変換バッファが動的に停止制御される状態を説明するタイムチャート、図5(c)はメモリアクセスされるアドレスに応じてアドレス変換バッファが動的に停止制御される状態を説明するタイムチャートである。 図1のプロセッサコアにより命令を実行処理する過程を説明する図を示す。 VLIWの圧縮命令のデータ構造を示す図である。 図1のプロセッサコアのパイプライン処理の内容を示す図である。 NOP命令に係る処理停止により得られる消費電力の削減割合を表わすグラフである。 図10(a)は実施例のプロセッサコアにおいてデコード回路と実行回路とを停止させる制御がプロセッサの動作周波数に与える影響を説明する図、図10(b)は伸長処理の後にNOP命令を検出する比較例においてデコード回路と実行回路とを停止させる制御がプロセッサの動作周波数に与える影響を説明する図を行う場合のものである。
符号の説明
20 プロセッサコア
21 命令ユニット
22 命令デコーダ
23 実行ユニット
24 Iキャッシュ
25 Dキャッシュ
60 DMAコントローラ
100 アドレス変換バッファ
110 TLB主要部
111 タグ記憶部
112 データ記憶部
113 ゲーテッドクロック回路
120 出力レジスタ
130 バイパス回路
140 クロックイネーブル生成回路
143 レジスタ
145,146A,146B 比較器
147 論理ゲート
150 ステータスレジスタ
210 命令伸長回路
211 命令バッファ
213 命令位置情報デコーダ
214 展開バッファ
220〜223 デコード回路
225〜228 ゲーテッドクロック回路
230〜233 実行回路
235〜238 フリップフロップ

Claims (6)

  1. 命令コードをデコードするデコード回路および該命令コードを実行する実行回路とが複数組設けられ、複数の命令コードと、同時処理される命令コードのグループの情報および複数組のデコード回路および実行回路のうち各命令コードをどの組で処理するか配置の情報を示す命令位置情報とが合わされた圧縮命令を受けて、該圧縮命令の各命令コードを上記命令位置情報に従ったグループおよび配置でデコード処理と実行処理とを行うプロセッサを備えた半導体集積回路であって、
    上記命令位置情報に従って同時処理される同一グループの命令コードを指定の配置にセットする伸長回路と、
    同時処理される1つのグループにおいて命令コードの数が少なく有効的な命令コードがセットされない配置が生じる場合に上記命令位置情報に基づき当該配置を検出する検出回路と、
    該検出回路の検出結果に基づき有効的な命令コードがセットされない配置に対応する実行回路を当該グループの実行期間に非アクティブにする制御回路とを備えるとともに、
    上記伸長回路における処理と、この処理でセットされるグループに対する上記検出回路の検出処理とが同一の処理サイクルに行われるように構成されていることを特徴とする半導体集積回路。
  2. 上記制御回路は、上記検出回路の検出結果に基づき有効的な命令コードがセットされない配置に対応するデコード回路を当該グループのデコード期間に非アクティブにするように構成されていることを特徴とする請求項1記載の半導体集積回路。
  3. 上記伸長回路は、
    上記複数組のデコード回路および実行回路にそれぞれ対応して複数個の命令コードを格納可能な複数の領域を有するバッファメモリを有し、
    上記命令位置情報に基づき同一グループの命令コードを指定された配置に対応する上記バッファメモリの領域に格納するように構成されていることを特徴とする請求項1又は2に記載の半導体集積回路。
  4. 上記プロセッサはコード長が大きな超長形式機械命令を処理可能であることを特徴とする請求項1〜3の何れかに記載の半導体集積回路。
  5. 上記圧縮命令は、同時実行される命令コードの数が少ない場合に挿入される有効的な処理のない無実行命令のコードを省く代わりに上記命令位置情報が付加された命令であることを特徴とする請求項4記載の半導体集積回路。
  6. 命令コードをデコードするデコード回路と該命令コードを実行する実行回路とが複数組設けられ、同時処理される同一グループの命令コードが1つにまとめられた命令を受けて、該命令に従って各命令コードのデコード処理と実行処理とを行うプロセッサを備えた半導体集積回路であって、
    上記デコード処理より前の処理ステージにおいて上記命令をバッファメモリに読み込むとともに当該命令の中に有効的な処理のない無実行命令のコードが含まれないか検出を行う検出回路と、
    該検出回路の結果に基づき上記無実行命令のコードが送られる組の実行回路を同一グループの命令コードの実行期間に非アクティブにする制御回路とを備えていることを特徴とする半導体集積回路。
JP2007187978A 2007-07-19 2007-07-19 半導体集積回路 Expired - Fee Related JP4404373B2 (ja)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2007187978A JP4404373B2 (ja) 2007-07-19 2007-07-19 半導体集積回路

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2007187978A JP4404373B2 (ja) 2007-07-19 2007-07-19 半導体集積回路

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
JP2002216258A Division JP4026753B2 (ja) 2002-07-25 2002-07-25 半導体集積回路

Publications (2)

Publication Number Publication Date
JP2007310905A JP2007310905A (ja) 2007-11-29
JP4404373B2 true JP4404373B2 (ja) 2010-01-27

Family

ID=38843643

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2007187978A Expired - Fee Related JP4404373B2 (ja) 2007-07-19 2007-07-19 半導体集積回路

Country Status (1)

Country Link
JP (1) JP4404373B2 (ja)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101545701B1 (ko) 2008-10-07 2015-08-19 삼성전자 주식회사 프로세서 및 그 명령어 번들 복원 방법
JP4829370B1 (ja) 2010-07-09 2011-12-07 株式会社東芝 メモリ制御装置、メモリ装置および停止制御方法

Also Published As

Publication number Publication date
JP2007310905A (ja) 2007-11-29

Similar Documents

Publication Publication Date Title
JP4026753B2 (ja) 半導体集積回路
US7657708B2 (en) Methods for reducing data cache access power in a processor using way selection bits
US7594131B2 (en) Processing apparatus
TWI454909B (zh) 減少記憶體裝置之功率消耗之記憶體裝置、方法及系統
US7117290B2 (en) MicroTLB and micro tag for reducing power in a processor
TWI335512B (en) Technique for using memory attributes
US6356990B1 (en) Set-associative cache memory having a built-in set prediction array
US9244837B2 (en) Zero cycle clock invalidate operation
US7650465B2 (en) Micro tag array having way selection bits for reducing data cache access power
US11436146B2 (en) Storage control apparatus, processing apparatus, computer system, and storage control method
US6240489B1 (en) Method for implementing a pseudo least recent used (LRU) mechanism in a four-way cache memory within a data processing system
US20120047311A1 (en) Method and system of handling non-aligned memory accesses
JP4404373B2 (ja) 半導体集積回路
US11080188B1 (en) Method to ensure forward progress of a processor in the presence of persistent external cache/TLB maintenance requests
TWI517040B (zh) 保護二進制轉譯碼的完整性
KR100398954B1 (ko) 멀티웨이 세트 연관 구조의 캐쉬 메모리 및 데이터 판독방법
US7076635B1 (en) Method and apparatus for reducing instruction TLB accesses
JP2011107888A (ja) 演算処理装置及び演算処理装置の制御方法
US6862242B2 (en) SRAM control circuit with a power saving function
US20030126345A1 (en) Method and apparatus for converting an external memory access into a local memory access in a processor core
JP2001202239A (ja) マイクロプロセッサのための低電力インストラクションデコーディング方法
JP2000285019A (ja) キャッシュ制御回路
KR100196522B1 (ko) 고속 및 고집적 마이크로프로세서를 위한 캐쉬 메모리 장치
US8793469B2 (en) Programmable logic array and read-only memory area reduction using context-sensitive logic for data space manipulation
JPH09114660A (ja) データ処理装置

Legal Events

Date Code Title Description
A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20090901

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

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20091029

A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20091030

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20121113

Year of fee payment: 3

R150 Certificate of patent or registration of utility model

Free format text: JAPANESE INTERMEDIATE CODE: R150

LAPS Cancellation because of no payment of annual fees