JP3734888B2 - 電力管理機能を備えたマイクロプロセッサ - Google Patents

電力管理機能を備えたマイクロプロセッサ Download PDF

Info

Publication number
JP3734888B2
JP3734888B2 JP19016296A JP19016296A JP3734888B2 JP 3734888 B2 JP3734888 B2 JP 3734888B2 JP 19016296 A JP19016296 A JP 19016296A JP 19016296 A JP19016296 A JP 19016296A JP 3734888 B2 JP3734888 B2 JP 3734888B2
Authority
JP
Japan
Prior art keywords
functional unit
microprocessor
power
control register
value
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 - Lifetime
Application number
JP19016296A
Other languages
English (en)
Other versions
JPH0962418A (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.)
HP Inc
Original Assignee
Hewlett Packard Co
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 Hewlett Packard Co filed Critical Hewlett Packard Co
Publication of JPH0962418A publication Critical patent/JPH0962418A/ja
Application granted granted Critical
Publication of JP3734888B2 publication Critical patent/JP3734888B2/ja
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline, look ahead
    • G06F9/3885Concurrent instruction execution, e.g. pipeline, look ahead using a plurality of independent parallel functional units
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3234Power saving characterised by the action undertaken
    • G06F1/324Power saving characterised by the action undertaken by lowering clock frequency
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3234Power saving characterised by the action undertaken
    • G06F1/325Power saving in peripheral device
    • G06F1/3275Power saving in memory, e.g. RAM, cache
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3234Power saving characterised by the action undertaken
    • G06F1/3287Power saving characterised by the action undertaken by switching off individual functional units in the computer system
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3234Power saving characterised by the action undertaken
    • G06F1/3296Power saving characterised by the action undertaken by lowering the supply or operating voltage
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/30076Arrangements for executing specific machine instructions to perform miscellaneous control operations, e.g. NOP
    • G06F9/30083Power or thermal control instructions
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline, look ahead
    • G06F9/3836Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline, look ahead
    • G06F9/3867Concurrent instruction execution, e.g. pipeline, look ahead using instruction pipelines
    • G06F9/3869Implementation aspects, e.g. pipeline latches; pipeline synchronisation and clocking
    • 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

Description

【0001】
【発明の属する技術分野】
本発明は、一般的には電力管理技術に関するもので、特に、電力管理技術のコンピュータ・システムへの応用に関するものである。
【0002】
【従来の技術】
コンピュータ・システムにおける電力管理は、ラップトップおよびノートブック型コンピュータの出現と共にますます重要となって来ている。これらの携帯型コンピュータは、通常はニッケル・カドミウム(ニカド)またはニッケル・メタル・ハイドライド(nickel-metal-hydride)のバッテリで動作する。あいにく、バッテリ技術の進歩は、現在の携帯型コンピュータの電力需要の増加に歩調を合わすことができなかった。白黒からカラー表示への移行が、マイクロプロセッサのクロック速度およびメイン・メモリのサイズの増加と共に、電力需要の大幅な増大をもたらした。
【0003】
バッテリ寿命を伸ばすため、コンピュータ・システムはいわゆる「電力管理」技術を取り入れた。このような技術は、コンピュータ・システム全体の中の個々のサブシステムの消費電力を減らすことによってシステムの消費電力を最小にすることを試みる。電力管理機能を備えた従来技術コンピュータ・システム10の一例が図1に示されている。このシステム10は、中央処理装置(CPU)またはマイクロプロセッサ12、キーボード16、ディスク18、ディスプレイ20、メイン・メモリ・サブシステム22およびI/Oサブシステム24を含む。CPU12は、バス14を経由してすべてのサブシステムに接続している。2つの主要な電力管理技術がある。第1は、サブシステムのクロック速度を制御するもので、第2は、例えばアイドル状態のコンポーネントの電源の切断のように、サブシステムに供給される電力の制御を伴うものである。
【0004】
従来技術において周知の通り、CMOS集積回路(IC)の消費電力は、ICのスイッチ頻度に直接比例し、このスイッチ頻度は、ICに提供されるクロック速度によって制御される。従って、クロック速度を調整することによって、ICによって消費される電力を低減させることができる。システム10は、このような利点を活かして、種々のサブシステムに供給されるクロック信号を一定の条件の下で減少または停止させる。この条件は、典型的には、サブシステムが所定の時間アイドルであるということである。その活動の監視は、マイクロプロセッサによって所定のメモリ位置の書き込みまたは読み取りを検出することによって行われる。そのようなメモリ活動が所定の時間間隔の間発生しなかった場合、マイクロプロセッサは、システムへの影響なしにサブシステムを安全に閉じることができると仮定する。
【0005】
システム10は、また、マイクロプロセッサ12によって個別に制御可能な5つのスイッチS1−S5を含む。これらのスイッチは、対応するサブシステムに供給される電力、または、それらに供給されるクロック周波数を制御することができる。スイッチがクロック周波数を制御する場合には、クロック分割回路(図示されていない)によってクロック信号を典型的には2の倍数で分割するかまたはクロック周波数をゼロにする。所定時間のアイドルを検出した後、マイクロプロセッサ12は、マイクロプロセッサとスイッチの間を連結する線26のような対応する線上に信号を出すことによってスイッチS3のようなスイッチをオンに設定する。これによって、該スイッチが適切な状態に切り替わり、クロックまたは電力が調節されることとなる。サブシステムが活動的になると、マイクロプロセッサ12は、該信号をオフに設定し、これによってその状態が通常に戻り、クロック周波数が通常の動作周波数に設定されるか、または電力がサブシステムに再供給される。
【0006】
いずれにせよ、典型的には、マイクロプロセッサがサブシステムを起動させるかまたは「目覚め」させた後、サブシステムは直ちに使用可能になる。従って、マイクロプロセッサ12は、サブシステムが再び完全に機能的になるまであらかじめ決められた時間量待たなければならない。このような動作は、典型的には、非マスク型割り込みによって起動される割り込みサービス・ルーチンによって取り扱われる。次に、割込みサービス・ルーチンは、サブシステムをアクセスしようとしたシステム・レベル・アプリケーションへ制御を移す前に、サブシステムが操作可能であることを確認する。そのようなシステムには、インテル社のIntel486SL、Advanced Micro Devices社のAM386DY-LVおよびChipset Technologies社のSuperstateなどのシステム管理アーキテクチャによって実施されているシステムがある。
【0007】
これらの技術のすべては、個々のサブシステムの電力を減らすことに焦点を当てている。(図1に示されているような)マイクロプロセッサのクロック速度を減少させることができるにもかかわらず、そのような技術は、マイクロプロセッサ自身によって浪費される電力に対する非常にきめの粗いレベルの制御を行う。更に、クロック周波数を減じることは、システム処理能力の比例的減退を招来する。マイクロプロセッサ12は、バス活動を監視する若干の内部論理部を除いてスリープに入る。
【0008】
いくつかのその他のアプローチは、システム・レベルというよりむしろマイクロプロセッサまたは「チップ」レベルにおける電力管理に焦点を置いた。そのようなチップ・レベルのアプローチは、命令ストリームの中で動的に命令を「感知」し、それらの命令を実行するために必要とされるチップの全体または部分を閉鎖する。IBM、モトローラおよびとアップル・コンピュータによる共同開発のPowerPCマイクロプロセッサは、そのようなアプローチを使用する。PowerPCにおいては、次の4つの異なる電力状態がある。すなわち、Full On(フル活動)、Doze(まどろみ)、Nap(うたた寝)およびSleep(睡眠)である。PowerPCアーキテクチャは、チップがこれら4つのモードのどのモードに置かれるかを指定するレジスタを含む。ソフトウェア典型的にはオペレーティング・システムは、このレジスタに該当する値を書き込むことによってそのモードを設定する。「Full On(フル活動)」電力モードに設定されると、PowerPCマイクロプロセッサは、現在の命令を実行する上で必要でない機能ユニットからクロックをはずすかゲートすることによってそれらの機能ユニットを使用停止にする。「Doze(まどろみ)」モードでは、「Full On(フル活動)」モードの場合と同様の方法で、バス監視論理回路および基礎時間減衰計を除いて、すべての機能ユニットが使用停止にされる。「Nap(うたた寝)」モードでは、バス監視論理回路も使用停止にされる。最も電力消費の少ない「Sleep(睡眠)」モードでは、システム・クロック(SYSCLK)は取り除かれ、フェーズ・ロック・ループ(PLL)が使用停止にされる。
【0009】
インテル社によって製作されたペンティアム・マイクロプロセッサは、同様のアプローチを使用してその内部浮動小数点機構の消費電力を減らしている。ペンティアムは、動的に現在の命令を感知して、浮動小数点活動が存在しない時、すなわち、浮動小数点命令が浮動小数点機構に送られていない時、その機構に対するクロックを遮断する。
【0010】
発明名称が"Method and Apparatus for Placing an Integrated Circuit Chipin a Reduced Power Consumption State"であるVolk氏に付与された米国特許第5,388,265号は、特定のチップ活動がないことを検出する場合にそのチップ全体への電力供給を動的に遮断する点を除いて、同様のアプローチを使用する。その電力遮断は、活動を監視する専用のハードウェアによって実行され、チップ全体の電力消費を節約する。発明名称"Microprocessor having Built-in Synchronous Memory with Power-Saving Feature"であるShiraishi氏その他に付与された米国特許第5,276,889号は、チップ搭載同期メモリの電力消費を減少させるため、メモリが現在実行中の命令にとって必要とされない場合該メモリを使用停止にする。命令デコーダが、命令ストリームを動的に監視して、メモリを使用しない命令が実行される時メモリへの電力供給を停止するためメモリ・イネーブル信号をオフにする。
【0011】
これらの「動的」アプローチが持つ問題点は、それらが命令ストリームを監視して検出するための負荷をハードウェアに課すことである。これは、高度なパイプライン方式のマイクロプロセッサにおいてクロック周期を遅くさせる可能性がある。加えて、ハードウェアにとって、特定の命令が発せられようとしているのか否かを前もって判断することが困難である。検出回路は、命令バッファの待ち行列に入れられた命令をチェックすることはできるが、この形態でも、先行して警告できるのは限られた命令数だけである。このような先行警告では、命令が実行される前に機能ユニットを完全に使用できないようにするには不充分なことがある。また、機能ユニットを目覚めさせるため、パイプライン処理を減速させる必要がある。
【0012】
別のアプローチが、Perry氏その他に付与の特許名称"Power Conservation in Microprocessor Controlled Devices."である米国特許第5,142,684号に記載されている。このアプローチは、2つのプロセッサを使用する。すなわち、1つは、可変速度でフォアグランド・タスクを実行させる高速プロセッサで、他方はバックグラウンド・タスクを実行する低速プロセッサである。低速プロセッサは、処理量の多いフォアグランド・タスクがスケジュールされる時のみ高速プロセッサを起動する。この形態では、大部分のタスクに関しては低速プロセッサを使用し、必要な場合にのみ高速従って電力消費の多いプロセッサを使用することによって、電力を節約する。更に別のレベルの電源制御がソフトウェアによって提供される。高速プロセッサ・クロックのクロック速度を制御するクロック制御コードが各サブルーチンに組み込まれる。高速プロセッサはこのコードを読み、アプリケーション特有集積回路(すなわちASIC)へそのコードを書き出す。ASICは、そのコードの値に依存する所定量だけ高速クロックを分断する。このようにして、タスク全体が所与のクロック速度で実行される。このアプローチが持つ問題は、追加費用と複雑性を設計に加える第2のプロセッサを必要とする点である。
【0013】
【発明が解決しようとする課題】
このように、上述のような従来技術の問題点を持たない電力管理機構を備えたマイクロプロセッサの必要性が存在する。
【0014】
【課題を解決するための手段】
改善された電力管理機構を含むマイクロプロセッサが提供される。該マイクロプロセッサは、マイクロプロセッサの範囲内の個々の機能ユニットの消費電力を個別に制御するため、複数のフィールドを有する電力制御レジスタを備える。機能ユニットが将来必要とされるか否かを判断するため将来を見通すことができる能力を持つソフトウェアによって、電力制御レジスタ・フィールドは設定される。これによって、マイクロプロセッサは、特定の機能ユニットが現在実行中のソフトウェアによって必要とされないとソフトウェアが判断すると、機能ユニットの任意の1つを遮断またはその実行速度を調節することができる。これは、命令活動を動的に検出し解読するタスクの負荷をハードウェアからソフトウェアへ移すものである。加えて、ソフトウェア制御によって、ハードウェアでは可能でない電力管理機能を可能にする。例えば、電力を節約するため、ソフトウェアは、特定ブロックのコードを実行している間、ブランチ予測ハードウェアを動作停止にすることができる。ソフトウェアは、また、特定ブロックのコードが完全に内部キャッシュの範囲内でまかなわれると予測される場合、メイン・メモリに対する外部バス・インターフェースを遮断または低速化することができる。ソフトウェアは、ハードウェアには利用することができない知識を備えることができるので、処理能力に対する影響の最も少ない電力管理意思決定を効果的に行うことができる。
【0015】
機能ユニットは、電力制御レジスタの対応するフィールドに応じて、そこに記憶されている値に対応するように実行速度を調節する。実行速度は、多くの異なる方法で制御することができる。第1に、機能ユニットに提供されるクロック信号を、電力制御レジスタ・フィールドに対応して分断することができる。これは、機能ユニットがI/O装置であるような場合には機能ユニットのレベルで、さもなければマイクロプロセッサ全体のグローバルなレベルでも実施することができる。第2に、電力制御レジスタ・フィールドに対応して機能ユニットへの電力供給を停止させることによって、機能ユニットの実行速度を調節することができる。これは、機能ユニットと接地の間に、あるいは別の形態では機能ユニットと供給電圧(Vdd)の間に、ゲーティング・トランジスタを配置することによって実施することができる。第3のアプローチでは、機能ユニットが多ポート型ランダム・アクセス・メモリ(RAM)である場合、電力制御レジスタ・フィールドに対応して、該RAMの1つまたは複数のポートのセンサおよびバッファ・ドライバを使用停止にする。ポートの1つを使用停止にすることによって、電力が少なくなるので、多ポートRAMのスループットまたは実行速度は低下する。第4のより一般的なアプローチは、制御レジスタ・フィールドに応じて、機能ユニットからデータを取り除くものである。これは、データ・バスと機能ユニットの間に配置された3態バッファを使用停止にすることによって達成される。更に別のアプローチでは、電力制御レジスタ・フィールドを用いて、32ビットと64ビットの外部インターフェースの間で切り換えを行いI/O装置の電力を減少させることができる。上記列挙したアプローチは可能なもののすべてではないが、マイクロプロセッサの内部電力管理に対するソフトウェア・アプローチの能力を例証するものである。
【0016】
本発明の別の1つの側面において、マイクロプロセッサは、クロック・サイクルの単位で電力待ち時間値(すなわちPLV−Power Latency Valueの頭文字)を記憶する電力待ち時間レジスタを含む。ソフトウェアが、電力制御レジスタにある1つの値を書き込むことによって機能ユニットを「目覚めさせる(wake up)」命令(すなわち機能ユニットの活動、従って電力消費レベルを増加させる命令)を発する場合、該機能ユニットは、実際に使用可能となるまで一定のサイクル数を要する。PLV値は、当該機能ユニットに関して目覚ましに要するサイクル数に関するソフトウェアによる仮定を表す。このことは、当該機能ユニットの電力待ち時間レジスタが書き込まれた後PLVのサイクル数の間、当該機能ユニットに関連する命令が命令ストリームに存在しないことが保証されることを意味する。機能ユニットが使用可能になるまでに要する「実際の」サイクル数(以下Actual Latency Valueの頭文字をとってALVと呼ぶ)は機能ユニットに記憶されていて、このALV値がPLV値と比較される。機能ユニットがPLVサイクル数より早く使用可能となれば、アクションをとる必要はない。PLVサイクル数より長くかかる場合は、その機能ユニットが使用可能になるまで別の実行機能ユニットを停止させる停止信号を発する。従って、電力待ち時間レジスタは、機能ユニットからの応答を必要とする命令を監視するため低消費電力状態にある時命令ストリームを動的に監視する必要性から機能ユニットを解放する。この構成の場合、動的に命令を感知する実施形態に比較して複雑性は非常に小さい。本発明の好ましい実施形態において、上記機能を実施するため、2つの減分カウンタおよびいくつかの関連組合せ回路が必要とされる。
【0017】
ソフトウェアは、機能ユニットを目覚めさせる命令のスケジュールを制御することによって、特定の目標チップについてALV値よりPLV値が大きくなるようにすることができる。機能ユニットの電力遮断に関する異なる方法を使用し、異なるALV値を持つチップ実施形態も可能である。上述のメカニズムは、コードに変更を加えない同一のソフトウェアをエラーなしですなわち互換性を保ちながら異なる実現形態上で正確に実行させることを可能にする。更に、特定の実施形態に関する機能ユニットの電力停止を最適化するため、該特定実施形態のALV値をソフトウェアによって調べることもできる。
【0018】
上記発明の課題を解決する手段として、本発明は、複数の機能ユニット、各々が1つの機能ユニットに対応し1つの値を記憶する複数のフィールドを有する電力制御レジスタ、および、各機能ユニットによって消費される電力量を決定するため、各機能ユニットに対応する上記フィールドに記憶された値に応じて各機能ユニットの実行速度を調節する手段を持つ電力管理機能を備えたマイクロプロセッサを含む。
【0019】
【発明の実施の形態】
図2は、本発明に従うマイクロプロセッサ100のブロック図である。本明細書において使用するマイクロプロセッサという用語は、所与のタスクを遂行するため、マイクロコードであろうと目的コードであろうがいずれかの形態の命令を実行するICを指す。従って、該マイクロプロセッサは、従来型のCPUの他、デジタル信号プロセッサ(DSP)、マイクロコントローラ、コプロセッサ、データ変換器その他を含む。該マイクロプロセッサは、特定の機能を遂行するように構成された一群の(組合せまたは逐次)論理機構として定義される。それらに含められる典型的機能ユニットには、整数加減乗除の各演算、浮動小数点加減乗除の各演算およびロード/ストアを実行する機能ユニットがある。また、その他の機能ユニットとして、入出力(I/0)機構、マルチメディア装置、多ポート・キャッシュ・メモリ機構、レジスタ・ファイル、命令ディスパッチ機構、ブランチ予測機構、レジスタ保存エンジン、データ・バスがあり、また、特定の機能またはタスクを遂行する専用装置も含まれる。
【0020】
これら機能ユニット(Functional Unitの頭文字をとって以下FUと略称する場合がある)は、種々の機能ユニットにデータ、アドレスおよび制御情報を提供するバス102および104によって相互に接続される。電力制御レジスタ106もまたマイクロプロセッサ100に含められる。電力制御レジスタ106は、値を記憶するための複数のフィールドを含む。これらの値は、製造工程で設定される場合もあり、あるいはまたソフトウェアによって設定されることもある。各フィールドは、それぞれの機能ユニットに対応する。フィールド108のような各電力制御レジスタ・フィールドは、対応する機能ユニットの実行速度従って消費電力を調節する。この制御は、後述する種々の形態で実行される。電力制御レジスタの各フィールドはバスを経由して対応する機能ユニットに接続する。例えば、バス110はフィールド108を機能ユニットFU1に接続してそのフィールドに記憶されている値を当該機能ユニットに提供する。バス112、114および116は、同様に、それぞれの電力制御レジスタのフィールドの内容を対応する機能ユニットに提供する。電力制御レジスタ106は、また、どの機能ユニットにも接続していない付加的フィールドを含むこともできる。それらのフィールドは、マイクロプロセッサ・アーキテクチャの将来の拡張、あるいは、マイクロプロセッサ100の全域的電力管理制御に備えるものである。そのようなフィールドのビット幅は、要求される制御の分解能に従う。
【0021】
マイクロプロセッサ100は、また、待ち時間制御レジスタ118を含む。このレジスタ118も、各々が1つの機能ユニットに対応する複数のフィールドを含む。電力制御レジスタ・フィールドの場合と同様に、待ち時間制御レジスタのフィールドの内容は、バス120、122、124および126経由でそれぞれの機能ユニットへ提供される。図10および図11を参照して後述するように、待ち時間制御レジスタ・フィールドに記憶される値は、対応する電力制御レジスタ・フィールドに所定の値を書き込むことによって機能ユニットに再び電力が供給された後機能ユニットが完全に作動する状態になるまでに要するクロック・サイクル数に関する(コンパイラによって設定される)仮定値に対応する。待ち時間制御レジスタ・フィールドの動作の詳細は後述する。
【0022】
図3には、機能ユニットの実行速度従って電力消費を低下させる第1のアプローチが示されている。このアプローチでは、クロック発振器130に接続するクロック分割器128が、クロック発振器によって生成されたマスタ・クロック信号(MASTER_CLOCK)を分割する。クロック分割器は、マスタ・クロック(MASTER_CLOCK)を受け取って、刻時ツリー132を介してマイクロプロセッサの各部へ分配されるシステム・クロック(SYSTEM_CLOCK)を生成する。刻時ツリー132は、マイクロプロセッサ全体にわたってクロック遅延およびクロック片寄りを最小限にとどめるため(従来技術の)複数のクロック・バッファ134、136および138を含む。
【0023】
クロック分割器128は、電力制御レジスタのグロ―バル・フィールド(FUG)140に接続してそこに記憶された値を受け取る。このグローバル・レジスタ・フィールド140は、特定の機能ユニット専用のものではなく、すべての機能ユニットに供給されるクロック周波数を制御することによってすべての機能ユニットの実行速度を調節する。フィールド140に記憶された値が、バス142を経由してクロック分割器128へ提供される。クロック分割器は、電力制御レジスタ・フィールドに記憶された値に応じてマスタ・クロック信号を細分する。マスタ・クロック信号が分割される度合いは、レジスタ・フィールド140のビット数に依存する。好ましい実施形態においては、クロック分割器は、フィールド140に記憶された値に応じて(例えば1/2, 1/3, 1/4 ... 1/16のような)整数比率でマスタ・クロック信号を分割する。分解能の量は、電力制御レジスタ・フィールドのビット数の関数であって、設計者によって設定されることができる。また、予め定めた値を使用してマスタ・クロック信号をゼロに分割することもできる。
【0024】
このアプローチを各機能ユニットに関して適用すれば、対応する電力制御レジスタ・フィールドによって、図4に示されるように、特定の機能ユニットに供給されるクロック速度を調節することができる。しかしながら、ほとんどのパイプライン構成のマイクロプロセッサは、全体を通して単一のクロック周波数を必要とする。統一的クロック信号を必要としない実施形態に関しては、個別のクロック分割回路を使用することができる。
【0025】
図4には、電力消費を調整または低下させるため、機能ユニットの実行速度を低下させる第2のアプローチが示されている。このアプローチでは、個々の機能ユニットに提供されるクロック信号が、電力制御レジスタの対応するフィールドに記憶された値に応じて閉じられる。図3の場合と同様に、クロック発信器144がマスタ・クロック信号(MASTER_CLOCK)を生成するが、マスタ・クロック信号を分割する代わりに、個々の機能ユニットに提供されるクロック信号がANDゲート146のようなANDゲートによってゲートされる。ANDゲート146は、電力制御レジスタ・フィールド108に記憶された値がすべてバイナリ1でない限り、マスタ・クロック信号が機能ユニットFU1に分配されることを禁じる。このように、クロック信号(CLK)は、対応する電力制御レジスタ・フィールド108に記憶された値に基づいて、選択的に適用され機能ユニットから取り除かれることができる。このアプローチがすべてのバイナリーが1であるという値に限定されるものではないが、現行の論理機構を変更せずにクロック信号をゲートすることを前提とすればこれが好ましい実施形態であるという点は明らかであろう。
【0026】
図5には、機能ユニットが入出力(I/O)装置である場合の別のアプローチが示されている。この場合、機能ユニットは、対応する電力制御レジスタ・フィールド108へ接続してその値を受け取る論理ブロック148を含む。論理ブロック148は、2つの出力を生成する。第1は、図3で説明したようなクロック分割器150に提供されるクロック分割器信号(DIVIDER)出力である。論理ブロック148のDIVIDER信号出力は、クロック分割器150によってクロック分割器の出力である入出力クロック(I/O_CLK)のクロック速度を決定するために使用される。I/O_CLK信号は、出力ラッチ152のクロック(CLK)入力へ送られる。出力ラッチは、I/O機能ユニットのデータ出力をゲートまたはラッチするために使用される。このように、機能ユニットの入出力速度は、対応する電力制御レジスタ・フィールド108に記憶される値を変更することによって調節することができる。従って、機能ユニットによって消費される電力は、I/O速度の関数であって、該フィールドの値を変えることによって調節することができる。
【0027】
論理ブロック148の第2の出力は、出力励振器154に接続した使用可能(ENABLE)信号である。この出力励振器154は、3態励振器であって、ENABLE信号がオフの場合高いインピーダンス状態に置かれる。励振器の出力は、パッド156に接続され、周知の方法でマイクロプロセッサへの外部接続機構を提供する。励振器を使用停止にすることによって、マイクロプロセッサは、パッド56に接続する寄生容量Cpの充電または放電による消費電力を効果的に低下または最小化することができる。本発明の好ましい実施形態における論理ブロック148は、電力制御レジスタに記憶された所定の値に応じてイネーブル信号をオフにする。論理ブロックは、また、クロック率を決定するためクロック分割器に分割器値(DIVIDER)を提供する。このように、実行速度を低下させ、電力消費を低減するため2つのレベルの制御がこのアプローチによって提供される。
【0028】
図6には、個々の機能ユニットの電力を削減する更に別のアプローチが示されている。このアプローチでは、機能ユニットと供給電圧端子の間にトランジスタが配置される。このアプローチは、機能ユニットを使用停止にすることによって機能ユニットの実行速度を効果的にゼロに低下させる。図6に示されるように、機能ユニットの接地端子(GND)とマイクロプロセッサの接地の間にNPNトランジスタ158が配置される。トランジスタ158のゲートは、電力制御レジスタ・フィールド108に記憶された値に応じてイネーブル(ENABLE)信号をトランジスタのゲートに提供する論理ブロック160に接続される。このアプローチでは、電力制御レジスタ・フィールドは単一ビットでよく、論理ブロックは単純な誘導因子にすぎない。しかし、電力制御レジスタ・フィールドを複数ビットとして、論理ブロック160が予め定められた値を解読してその値が検出される時イネーブル信号をオフにするように働く組合せ論理機構とすることもできる。トランジスタを正の電源(SUPPLY Vdd)と機能ユニットの正の電力入力端子との間に配置することもできる点は当業者に明らかであろう。図6に示されるように、その他の機能ユニットの各々も、その実行速度を制御するためそれぞれのトランジスタを備え持つ。これらのトランジスタは、電力制御レジスタの対応するフィールドに記憶された値に従う。対応する論理ブロックおよび種々の接続機構は簡略化のため図示されていない。
【0029】
図7には、機能ユニットが多ポート型メモリである場合に電力制御レジスタのフィールドに応答して機能ユニットの処理速度を調節する別のアプローチが示されている。多くのマイクロプロセッサは、メモリに対する複数の同時並行アクセスを可能にする多ポート型メモリを含む。典型的には、このようなメモリは、レジスタ・ファイルあるいはキャッシュ・メモリで使用される。図7には、2ポート型静的ランダム・アクセス・メモリー(SRAM)162が示されている。センス・アンプ(SENSE AMP)、励振器、アドレス・デコーダ(DECODER)およびプルアップ・トランジスタ(PULL-UP)が、ポート1(PORT1)およびポート2(PORT2)の各ポートに接続されている。
【0030】
このアプローチでは、1つのポートまたは両方のポートに関するセンス・アンプ、励振器、アドレス・デコーダおよびプルアップ・トランジスタが、電力制御レジスタ・フィールド108に記憶された値に応じて選択的に使用停止(DISABLE)とされる。論理ブロック164が、レジスタ・フィールド108に接続してそこに記憶されている値を解読する。論理ブロック164が電力制御レジスタに記憶された所定の値を検出すると、第1ポートに関係するコンポーネントに与えられているイネーブル信号(ENABLE1)をオフにすることによって、センス・アンプ166、アドレス・デコーダ(DECODE1およびDECODE2)167、バッファ168およびプルアップ・トランジスタ(PULL-UP1およびPULL-UP2)169を使用停止にする。これらのコンポーネントは、使用停止とされ、第1ポートによって消費される電力を減少させる。
【0031】
論理ブロック164は、また、第2のイネーブル信号(ENABLE2)を生成し、同様の方法で第2ポート(PORT2)に関係するコンポーネントを制御する。ENABLE1およびENABLE2信号は、フィールド108のビット数および分解能に従って、電力制御レジスタに記憶されている同一または異なる値に応答して、オン/オフすることができる。代替形態として、異なるフィールドを各メモリ・ポートに割り当てことができる。これらのコンポーネントを選択的に使用停止にすることによって、機能ユニットFU1の実行速度従って消費電力をそれに応じて調節することができる。
【0032】
マイクロプロセッサによって消費される電力量を制御するために使用することができる更なるアプローチが図8に示されている。このアプローチでは、データが、電力制御レジスタの対応するフィールドに記憶されている値に応じて機能ユニットから選択的に取り除かれる。これは、データを機能ユニットに接続させるバッファを3態化(tri-state)化させるかまたは使用停止にすることによって達成される。例えば、図8に示されるように、データ・バス170はバッファ172のような3態バッファを経由して種々の機能ユニットに接続している。論理ブロック174が、機能ユニットFU1に対応する電力制御レジスタ・フィールド108と3態バッファ172の間に配置される。論理ブロック174は、レジスタ・フィールド108の中に検出されるあらかじめ定められた値に応じて、バッファ172に送られるイネーブル信号(ENABLE)をオフにすることによってバッファ172を選択的に使用停止にする。バッファ172を使用停止にすることによって、バス176上の寄生容量を充電/放電することによって消費される電力および該バスに接続する論理ブロック部分によって消費される電力が節減される。このアプローチは、また、機能ユニットはデータなしで実行することができないので、機能ユニットの実行速度を調節するものと見なすことができる。
【0033】
代替形態として、データ・バスそれ自体を1つの機能ユニットとみなすことができる。その場合、すべての機能ユニットからデータを同時に取り除く機能を持つ3態バッファ175を使用停止にすることによってデータ・バスを完全に遮断することができる。これは、データ・バス上の寄生容量を充電/放電することによって消費される電力を節約する。
【0034】
機能ユニットがI/O装置である場合に実行速度を調節し従って消費電力を節約する更なるアプローチが図9に示されている。このアプローチでは、マイクロプロセッサへの外部インタフェースが、32ビット・インターフェースと64ビット・インターフェースの間で切り換えられる。論理ブロック178は、マルチプレクサ180のセレクト入力に提供されるMUX信号を生成する。マルチプレクサ180は、セレクト信号(すなわちMUX)の状態に従って、その入力Aで与えられるデータかその入力Bで与えられるデータかいずれかを供給するという既知の方法で動作する。マルチプレクサ180は、MUX信号に応じてAとBの入力の間を切り換えることによって、64ビットすべてのデータを連続した2つの32ビット・ワードの形で出力させることができる。
【0035】
論理ブロック178は、電力制御レジスタ・フィールド108に記憶されている値に応じてMUX信号を生成する。従って、電力制御レジスタ・フィールド108は、32ビットと64ビットのインターフェースの間で、機能ユニット従ってマイクロプロセッサを切り換えるために使用することができ、これによって、駆動されるデータ線の数が減少するため電力消費がそれに応じて変化する。これは、例えばモトローラ68040マイクロプロセッサで使用されている動的バス幅変更技術に類似しているが、本発明のバス幅変更は、マイクロプロセッサに与えられる外部入力によらず、電力制御レジスタに記憶されている値に応じて行われる点が相違する。
【0036】
本発明の別の側面が図10および図11に示されている。上記の諸アプローチのどれが使用されるとしても、対応する電力制御レジスタ・フィールドが機能ユニットに通常電力を供給するため変更された後ただちに当該機能ユニットが使用可能または動作可能とならない点は当業者に明らかであろう。例えば、電力制御レジスタ・フィールドに適切な値を記憶することによって電力を機能ユニットに再供給する場合、機能ユニットがその機能を実行するまでにいくつかのクロック・サイクルを要するであろう。従って、命令がその機能ユニットにあまりに早く発せられると、その結果エラーとなる場合がある。そのため、本発明は、機能ユニット内に電力待ち時間レジスタ118および関連論理機構を具備して、上記のような条件が発生する場合マイクロプロセを停止させる。相当なハードウェア負荷を機能ユニットに課する従来技術と異なって、このアプローチは、機能ユニットが命令を監視することはせず、単に、機能ユニットに記憶される実際の待ち時間レジスタ値と電力待ち時間レジスタ118の対応する電力待ち時間レジスタ・フィールドの間の簡単な比較を実行するだけである。
【0037】
図10に示されるように、機能ユニットは、実際待ち時間レジスタおよび停止論理ブロックを含む。実際待ち時間レジスタは、機能ユニットが電力節約状態から完全動作状態に変わった後機能ユニットが完全に動作可能となるまでに要する実際のクロック・サイクル数を表す値を含む。上述から明らかなように、これは、機能ユニットの実行速度を制御する電力制御レジスタ・フィールドが電力節約状態に対応する値から完全電力供給状態に対応する値へ変る場合の状況に対応する。一方、電力待ち時間レジスタ118の中の対応するフィールドは、実際待ち時間レジスタの値に関するコンパイラの仮定に対応する。対応する電力制御レジスタ・フィールドが電力節約状態に対応する値から完全電力供給状態に対応する値へ変わった後この仮定した値に相当するサイクル数が経過するまで当該機能ユニットへ命令が発せられないことを保証するためコンパイラはこの仮定を使用する。これは、命令をチェックする責任を機能ユニットからコンパイラへダウンロードするものである。これは、機能ユニットが命令を動的に監視する必要がなくなるので、従来技術に比較してすぐれたアプローチである。このアプローチは、1993年5月6日出願の米国特許出願第08/059,041号(発明名称"Method and Apparatus for Simplifying Interlock Hardware" )に記載のものと似ている。しかし、コンパイラによって設定された仮定が実際待ち時間レジスタによって指定されたものと合致しない場合に問題が起きる。そのような場合、機能ユニットは、マイクロプロセッサを停止させて、実際待ち時間レジスタに記憶された値の指定の通り、機能ユニットが完全に動作可能となるまで待たなければならない。これを実現するために必要な論理が、図10および図11に示されている。
【0038】
図10において、各装置は、実際待ち時間レジスタ(APLR)および関連停止論理ブロックを持つ。例えば、機能ユニットFU1は、実際待ち時間レジスタ200および関連停止論理ブロック202を含む。停止論理ブロック202は、次の3つの入力部を含む。すなわち、第1は、レジスタ200に接続して実際待ち時間値を受け取る入力、第2は、電力待ち時間レジスタ118の対応するフィールドに接続して待ち時間仮定値を受け取る入力、および第3は、電力制御レジスタ106の対応するフィールド108に接続する入力である。停止論理ブロックは、電力制御レジスタ・フィールド108を監視して、そこに記憶された値が動作可能状態における増加に対応する値に変化したことを検出しなければならない。本発明の好ましい実施形態において、これは機能ユニットが完全に使用可能な状態または通常の状態に置かれる状況に対応する。しかし、この値は、任意の動作状態にも、または機能ユニットが動作する多数の状態にも対応させることができる。
【0039】
停止論理ブロック202は、マイクロプロセッサの多段階パイプラインを制御するパイプライン制御機構204へ送る停止信号(POWER-STALL1)を生成する。信号線206は、パイプライン制御機構204へこの停止信号を渡す。停止論理ブロックは、コンパイラが実際待ち時間値について誤った仮定を設定した場合、電力停止信号(POWER-STALL1)をオンにする。電力制御レジスタの対応するフィールド108が低消費電力から全電力または通常電力へ変更された後実際待ち時間レジスタ値による指定に従って必要サイクル数が経過するまで、この信号はオンのままにされる。その他の機能ユニットも、同様の条件で電力停止信号((POWER-STALL2...POWER-STALLn)を生成する。
【0040】
パイプライン制御機構204は、これらの電力停止信号のいずれかがオンにされた時、あるいは、その他の機能停止発生源のいずれかが対応する停止条件を生成した時、停止信号を生成する。上記その他の機能停止発生源には、周知の通り、制御またはデータの損壊が含まれる。マイクロプロセッサのパイプラインは、機能停止信号がオフにされるまで停止させられる。パイプライン制御機構204の実施形態は当業界において既知のものであるから、本明細書では説明を行わない。この技術は、例えば、John L.HennessyおよびDavid A. Patterson両氏共著の"Computer Architecture:A Quantitative Approach 251-343(1990)"に記載されている。
【0041】
図11の停止論理ブロック202は、電力制御レジスタ108に接続され、当該フィールドが低消費電力から全電力または通常電力へ変更されたことを検出する変更検出器208を含む。変更検出器の出力は、2つのロード可能なカウンタ器210および212に接続される。変更検出器208が生成するロード信号に応答して、カウンタ210および212は、それらのデータ入力部(DIN)に提示された値をロードする。カウンタ210に関しては、ロードされる値は、実際待ち時間レジスタ200に記憶されている値であり、カウンタ212に関しては、その値は電力待ち時間レジスタ・フィールド201に記憶されている値である。これらカウントタ210および212の両方は、システムクロックCLKによって刻時されるクロック入力を持つ。カウンタ210および212は、更に、カウンタの現在時通算値であるデータの出力部(DOUT)を含む。このように、カウンタがロードされた後、データ出力値は、カウンタにロードされた値に対応する。カウンタが減分されるにつれ、データ出力値は、その減分された値に対応する。
【0042】
カウンタ210の出力データ(COUNT1)がゼロに等しくなると、ゼロ信号(ZERO1)を生成するゼロ検出器214へ送られる。同様に、ゼロ検出器216は、カウンタ212のデータ出力がゼロに等しくなる時を検出するためカウンタ212に接続される。カウンタ212によって生成されるCOUNT2信号がゼロに等しくなると、ゼロ検出器216はゼロ信号ZERO2を発する。
【0043】
出力信号ZERO1はインバータ220を経由してANDゲート218へ送られ、一方、出力信号ZERO2はANDゲート218へ直接送られる。ANDゲート218は、信号ZERO2がオンで信号ZERO1オンでない時停止信号POWER-STALL1を生成する。この条件は、カウンタ212がカウンタ210より前に減分を終了した状況に対応する。これは、電力待ち時間レジスタ・フィールド201に記憶された値がレジスタ200に記憶された実際待ち時間値より小さい場合に発生する。この場合、信号POWER-STALL1はカウンタ210のカウントダウンが終了するまでオンのままにされる。このようにして、信号POWER-STALL1は、電力待ち時間レジスタ・フィールド201に記憶された値とレジスタ200に記憶された実際待ち時間値との間の差に等しいクロック数の間オンのままにされる。このサイクル数経過後、危機は去って、POWER-STALL1はオフにされる。検出器222が、POWER-STALL1上の1から0への状態移行を検出して、それに応じて、カウンタ210および212をリセットする。このように、停止論理ブロック202は、命令がそれに発せられる前に機能ユニットが完全に使用可能となることを保証する。IBM、モトローラおよびアップル社によるPowerPCマイクロプロセッサにおいて実施されているように命令を明示的に監視する形態をとることなく、本発明の上記機能は達成される。
【0044】
実際待ち時間レジスタに記憶される値は、ソフトウェアにとって利用可能であるので、そこに記憶される電力待ち時間レジスタ値の内容をソフトウェアが変更することが可能である。(例えばステータス・レジスタのような)他の制御レジスタが読み取られる場合と全く同じ方法で、実際待ち時間レジスタの内容を読む命令によってこれを達成することができる。この能力は、各々が異なる実際待ち時間値を持つようなマイクロプロセッサの複数のバージョンについて共通のプログラム・コードを使用することを可能にする。このプログラム・コードが適切な値を電力待ち時間レジスタ・フィールドに書き込むことができる。
【0045】
実行ユニット速度を調節する電力制御レジスタおよび関連手段を備えるマイクロプロセッサ100によって、ソフトウェアが該マイクロプロセッサの消費電力を調節または制御することが可能となる。この形態は、ソフトウェアが将来どのような機能ユニットが必要とされるかを判断するため将来を見通すことができるので、ハードウェア実施形態に比較して、有利である。必要とされない機能ユニットは、電力制御レジスタ・フィールドの対応する値を設定することによって低消費電力または無電力状態に設定することができる。更に、この能力によって、ソフトウェアは、さもなければ並列的に実行されるタスクを順次に実行することによって、あらかじめ決められた量以下に消費電力を保つことができる。この形態はマイクロプロセッサの処理能力を抑えることを含むけれども、電力を節約し、それによって、同じシリコン色素が、低コストのプラスチック・パッケージを含む種々の異なるパッケージまたは放熱板なしのパッケージで使用されることを可能にする。シリコンがパッケージに許容される以上の電力を消費しないことを保証するため、製造工程中に値を設定することによって、またはウェーハによって、または部品のパッケージングによって、特定の機能ユニットを永久に使用停止または低消費電力状態に設定することもできる。次にソフトウェアがこの設定値をを感知してそれに応じてタスクを直列化することもできる。
【0046】
マイクロプロセッサは、図1に示されるような従来からのコンピュータ・システムで使用されることができる。次に、電力制御レジスタに書き込みを行うソフトウェアはメイン・メモリ22に記憶される。本明細書において開示される電力管理技術は、従来技術によって提供されるシステム・レベルのアプローチと関連して使用して、マイクロプロセッサおよびシステム・レベルの電力管理の改善に供することもできる。
【0047】
以上本発明の原理を特定の実施形態を用いて記述したが、本発明の構成および細部はそのような原理を逸脱することなく修正することができる点は明らかであろう。
【0048】
本発明には、例として次のような実施様態が含まれる。
(1)電力管理機能を備えたマイクロプロセッサであって、複数の機能ユニットと、各々が1つの機能ユニットに対応し1つの値を記憶する複数のフィールドを有する電力制御レジスタと、各機能ユニットによって消費される電力量を決定するため、各機能ユニットに対応する上記フィールドに記憶された値に応じて各機能ユニットの実行速度を調節する手段と、を備えるマイクロプロセッサ。
(2)上記電力制御レジスタの各フィールドの値がマイクロプロセッサの製造工程中に設定される、上記(1)に記載のマイクロプロセッサ。
(3)上記電力制御レジスタの各フィールドの値がマイクロプロセッサの半導体組立工程中に設定される、上記(2)に記載のマイクロプロセッサ。
(4)上記電力制御レジスタの各フィールドの値がマイクロプロセッサのパッケージング工程中に設定される、上記(2)に記載のマイクロプロセッサ。
(5)上記電力制御レジスタの各フィールドの値がマイクロプロセッサによって実行されるソフトウェアによって設定される、上記(1)に記載のマイクロプロセッサ。
(6)上記マイクロプロセッサがパイプラインを含み、電力制御レジスタの1つのフィールドの上記値に応じて、該パイプラインを停止させる手段を更に含む上記(1)に記載のマイクロプロセッサ。
(7)各機能ユニットの実行速度を調節する上記手段が、電力制御レジスタの対応するフィールドの値に応じて当該機能ユニットの電力を停止するため、機能ユニットと電力供給端子の間に配置されたトランジスタを含む、上記(1)に記載のマイクロプロセッサ。
(8)各機能ユニットの実行速度を調節する上記手段が、電力制御レジスタの対応するフィールドの値に応じて、機能ユニットへのデータ入力に関する状態移行を実行停止状態にさせる手段を含む、上記(1)に記載のマイクロプロセッサ。
【0049】
(9)上記マイクロプロセッサがクロック信号を生成して該クロック信号を機能ユニットに送信するクロック回路を更に含み、各機能ユニットの実行速度を調節する上記手段が、電力制御レジスタの対応するフィールドの値に応じて上記クロック信号率を調節する手段を含む、上記(1)に記載のマイクロプロセッサ。
(10)上記クロック信号率を調節する手段が、電力制御レジスタの対応するフィールドの値に応じて、上記クロック信号率をゼロに調節する手段を含む、上記(9)に記載のマイクロプロセッサ。
(11)上記マイクロプロセッサが、電力制御レジスタ・フィールドが調節された後当該機能ユニットが使用可能となるまでに要するクロック・サイクル数に対応する待ち時間値を記憶する待ち時間フィールドを有する電力待ち時間レジスタを更に含み、上記クロック・サイクル数がソフトウエアによって仮定され、上記機能ユニットが、電力制御レジスタの対応するフィールドが該機能ユニットを通常状態に置くように変更された後該機能ユニットが使用可能となるまでその実行を停止させる手段を含む、上記(1)に記載のマイクロプロセッサ。
(12)上記電力待ち時間レジスタが、対応する機能ユニットに関する待ち時間値を各々が記憶する複数の待ち時間フィールドを含む、上記(11)に記載のマイクロプロセッサ。
【0050】
(13)電力管理機能を持つコンピュータであって、複数の機能ユニット、および、各々が上記機能ユニットの1つに対応する複数の電力制御レジスタ・フィールドを持つ電力制御レジスタを備えたマイクロプロセッサと、上記マイクロプロセッサに接続して、上記マイクロプロセッサによる実行が可能な命令を記憶するメモリと、上記メモリに記憶され、電力消費の水準を制御する値を上記電力制御レジスタ・フィールドに保存することを当該マイクロプロセッサに要求する実行可能コードと、上記電力制御レジスタ・フィールドに保存された値に応じて各機能ユニットの実行速度を調節して各機能ユニットによって消費される電力を調整する手段と、を含むコンピュータ。
(14)上記マイクロプロセッサがクロック信号を生成して該クロック信号を機能ユニットに送信するクロック回路を更に含み、各機能ユニットの実行速度を調節する上記手段が、電力制御レジスタの対応するフィールドの値に応じて上記クロック信号率を調節する手段を含む、上記(13)に記載のコンピュータ。
(15)クロック信号率を調節する上記手段が、クロック信号の周波数を、第1に記憶された値に応じて、最大周波数を分母とする分数に調節するクロック分割回路を含む、上記(14)に記載のコンピュータ。
【0051】
(16)上記クロック分割回路が、第2に記憶された値に応じて、クロック信号の周波数をゼロに調節する、上記(15)に記載のコンピュータ。
(17)電力制御レジスタのフィールドに記憶された値に応じて、データ・バス・インターフェースの幅を第1のビット数から第2のビット数へ減少させる手段を更に含む、上記(13)に記載のコンピュータ。
(18)上記マイクロプロセッサが、電力制御レジスタ・フィールドが調節された後当該機能ユニットが使用可能となるまでに要するクロック・サイクル数に対応する待ち時間値を記憶するため各機能ユニットに対応する1つまたは複数の待ち時間レジスタ・フィールドを持つ電力待ち時間レジスタを更に含み、上記クロック・サイクル数がソフトウエアによって仮定され、待ち時間値によって指定されたクロック・サイクルの後命令が発せられるが当該機能ユニットがまだ使用可能でない場合該機能ユニットが使用可能になるまでその命令の実行を停止させる手段を上記機能ユニットが含む、上記(13)に記載のコンピュータ。
(19)上記マイクロプロセッサが多段階方式のパイプラインを含み、上記機能ユニットが、上記電力制御レジスタ・フィールドに記憶された値に応じて、多数の停止信号を上記パイプラインに送出する手段を含む、上記(13)に記載のコンピュータ。
【0052】
(20)複数の機能ユニットを有するマイクロプロセッサを備えたコンピュータにおいて消費電力を最小にする方法であって、
上記複数の機能ユニットの1つにそれぞれ対応する複数のフィールドを持つ電力制御レジスタを備えたマイクロプロセッサを準備し、上記電力制御レジスタの各フィールドに1つの値を記憶し、マイクロプロセッサによって消費される電力を調節するため、上記電力制御レジスタに記憶した上記値に従って各機能ユニットの実行速度を調節する方法。
(21)上記各機能ユニットの実行速度調節が、機能ユニットに与えられるクロック信号のクロック速度を調節することを含む、上記(20)に記載の方法。
(22)上記各機能ユニットの実行速度調節が、機能ユニットに接続したバスを3態回路で接続することを含む、上記(20)に記載の方法。
(23)上記電力制御レジスタの各フィールドへの1つの値の記憶が、各機能ユニットに対する1つの値を記憶することを含む、上記(20)に記載の方法。
【0053】
【発明の効果】
本発明は、命令ストリームを監視する負荷をハードウェアに課す従来技術の電力管理技術の動的アプローチが持つ問題点を解決し、マイクロプロセッサの機能ユニット毎のソフトウェアによる柔軟な消費電力節約が実現する。
【図面の簡単な説明】
【図1】従来技術の電力管理能力を持つコンピュータ・システムのブロック図である。
【図2】本発明に従うソフトウェアによる制御可能な電力管理機能を備えるマイクロプロセッサのブロック図である。
【図3】図2のマイクロプロセッサの電力管理機能の1側面を示すブロック図である。
【図4】図2のマイクロプロセッサの電力管理機能の第2の側面を示すブロック図である。
【図5】図2のマイクロプロセッサの電力管理機能の第3の側面を示すブロック図である。
【図6】図2のマイクロプロセッサの電力管理機能の第4の側面を示すブロック図である。
【図7】図2のマイクロプロセッサの電力管理機能の第5の側面を示すブロック図である。
【図8】図2のマイクロプロセッサの電力管理機能の第6の側面を示すブロック図である。
【図9】図2のマイクロプロセッサの電力管理機能の第7の側面を示すブロック図である。
【図10】本発明の第2の実施形態を示すブロック図である。
【図11】図10の電力停止論理部分のブロック図である。
【符号の説明】
100 マイクロプロセッサ
102、104、110、112、114、116、120、122、124、126、142、176 バス
106 電力制御レジスタ
108 電力制御レジスタのフィールド
118 待ち時間制御レジスタ
128、150 クロック分割器
130、144 クロック発振器
132 刻時ツリー
134、136、138 クロック・バッファ
140 電力制御レジスタのグローバル・フィールド
146 ANDゲート
148、160、164、174、178 論理ブロック
152 出力ラッチ
154 出力励振器
156 パッド
158 NPNトランジスタ
162 多ポートSRAM
166 センス・アンプ
167 アドレス・デコーダ
168 バッファ
169 プルアップ・トランジスタ
172、175 3態バッファ
180 マルチプレクサ
200 実際待ち時間レジスタ
202 停止論理ブロック
204 パイプライン制御機構
206 信号線
208 変更検出器
210、212 カウンタ
214、216 ゼロ検出器
222 検出器

Claims (21)

  1. 電力管理機能を備えたマイクロプロセッサであって、複数の機能ユニットと、各々が1つの機能ユニットに対応し1つの値を記憶する複数のフィールドを有する電力制御レジスタと、各機能ユニットによって消費される電力量を決定するため、各機能ユニットに対応する上記フィールドに記憶された値に応じて各機能ユニットの実行速度を調節する手段と、電力制御レジスタ・フィールドが調節された後当該機能ユニットが使用可能となるまでに要するクロック・サイクル数に対応する待ち時間値を記憶する待ち時間フィールドを有する電力待ち時間レジスタとを含み、上記クロック・サイクル数がコンパイラによって仮定され、上記機能ユニットが、電力制御レジスタの対応するフィールドが該機能ユニットを通常状態に置くように変更された後該機能ユニットが使用可能となるまでその実行を停止させる手段を含む、マイクロプロセッサ。
  2. 上記電力制御レジスタの各フィールドの値がマイクロプロセッサの製造工程中に設定される、請求項1に記載のマイクロプロセッサ。
  3. 上記電力制御レジスタの各フィールドの値がマイクロプロセッサの半導体組立工程中に設定される、請求項2に記載のマイクロプロセッサ。
  4. 上記電力制御レジスタの各フィールドの値がマイクロプロセッサのパッケージング工程中に設定される、請求項2に記載のマイクロプロセッサ。
  5. 上記電力制御レジスタの各フィールドの値がマイクロプロセッサによって実行されるソフトウェアによって設定される、請求項1に記載のマイクロプロセッサ。
  6. 上記マイクロプロセッサがパイプラインを含み、電力制御レジスタの1つのフィールドの上記値に応じて、該パイプラインを停止させる手段を更に含む請求項1に記載のマイクロプロセッサ。
  7. 各機能ユニットの実行速度を調節する上記手段が、電力制御レジスタの対応するフィールドの値に応じて当該機能ユニットの電力を停止するため、機能ユニットと電力供給端子の間に配置されたトランジスタを含む、請求項1に記載のマイクロプロセッサ。
  8. 各機能ユニットの実行速度を調節する上記手段が、電力制御レジスタの対応するフィールドの値に応じて、機能ユニットへのデータ入力に関する状態移行を実行停止状態にさせる手段を含む、請求項1に記載のマイクロプロセッサ。
  9. 上記マイクロプロセッサがクロック信号を生成して該クロック信号を機能ユニットに送信するクロック回路を更に含み、各機能ユニットの実行速度を調節する上記手段が、電力制御レジスタの対応するフィールドの値に応じて上記クロック信号率を調節する手段を含む、請求項1に記載のマイクロプロセッサ。
  10. 上記クロック信号率を調節する手段が、電力制御レジスタの対応するフィールドの値に応じて、上記クロック信号率をゼロに調節する手段を含む、請求項9に記載のマイクロプロセッサ。
  11. 上記電力待ち時間レジスタが、対応する機能ユニットに関する待ち時間値を各々が記憶する複数の待ち時間フィールドを含む、請求項に記載のマイクロプロセッサ。
  12. 電力管理機能を持つコンピュータであって、複数の機能ユニット、および、各々が上記機能ユニットの1つに対応する複数の電力制御レジスタ・フィールドを持つ電力制御レジスタを備えたマイクロプロセッサと、上記マイクロプロセッサに接続して、上記マイクロプロセッサによる実行が可能な命令を記憶するメモリと、上記メモリに記憶され、電力消費の水準を制御する値を上記電力制御レジスタ・フィールドに保存することを当該マイクロプロセッサに要求する実行可能コードと、上記電力制御レジスタ・フィールドに保存された値に応じて各機能ユニットの実行速度を調節して各機能ユニットによって消費される電力を調整する手段と、を含み、上記マイクロプロセッサが、電力制御レジスタ・フィールドが調節された後当該機能ユニットが使用可能となるまでに要するクロック・サイクル数に対応する待ち時間値を記憶するため各機能ユニットに対応する1つまたは複数の待ち時間レジスタ・フィールドを持つ電力待ち時間レジスタを更に含み、上記 クロック・サイクル数がコンパイラによって仮定され、待ち時間値によって指定されたクロック・サイクルの後命令が発せられるが当該機能ユニットがまだ使用可能でない場合該機能ユニットが使用可能になるまでその命令の実行を停止させる手段を上記機能ユニットが含む、コンピュータ。
  13. 上記マイクロプロセッサがクロック信号を生成して該クロック信号を機能ユニットに送信するクロック回路を更に含み、各機能ユニットの実行速度を調節する上記手段が、電力制御レジスタの対応するフィールドの値に応じて上記クロック信号率を調節する手段を含む、請求項12に記載のコンピュータ。
  14. クロック信号率を調節する上記手段が、クロック信号の周波数を、電力制御レジスタに記憶された値に応じて、整数比率で分割するクロック分割回路を含む、請求項13に記載のコンピュータ。
  15. 上記クロック分割回路が、電力制御レジスタに記憶された値に応じて、クロック信号の周波数をゼロに調節する、請求項14に記載のコンピュータ。
  16. 電力制御レジスタのフィールドに記憶された値に応じて、データ・バス・インターフェースの幅を第1のビット数から第2のビット数へ減少させる手段を更に含む、請求項12に記載のコンピュータ。
  17. 上記マイクロプロセッサが多段階方式のパイプラインを含み、上記機能ユニットが、上記電力制御レジスタ・フィールドに記憶された値に応じて、多数の停止信号を上記パイプラインに送出する、請求項12に記載のコンピュータ。
  18. 複数の機能ユニットを有するマイクロプロセッサを備えたコンピュータにおいて消費電力を最小にする方法であって、上記複数の機能ユニットの1つにそれぞれ対応する複数のフィールドを持つ電力制御レジスタおよび電力制御レジスタ・フィールドが調節された後当該機能ユニットが使用可能となるまでに要するクロック・サイクル数に対応する待ち時間値を記憶する待ち時間フィールドを有する電力待ち時間レジスタを備えたマイクロプロセッサを準備し、上記電力制御レジスタの各フィールドに1つの値を記憶し、上記電力待ち時間レジスタの各待ち時間フィールドに待ち時間値を記憶し、マイクロプロセッサによって消費される電力を調節するため、上記電力制御レジスタに記憶した上記値に従って各機能ユニットの実行速度を調節し、上記電力制御レジスタの対応するフィールドが該機能ユニットを通常状態に置くように変更された後該機能ユニットが使用可能となるまでその実行を停止させる、方法。
  19. 上記各機能ユニットの実行速度調節が、機能ユニットに与えられるクロック信号のクロック速度を調節することを含む、請求項18に記載の方法。
  20. 上記各機能ユニットの実行速度調節が、機能ユニットに接続したバスを3態回路で接続することを含む、請求項18に記載の方法。
  21. 上記電力制御レジスタの各フィールドへの1つの値の記憶が、各機能ユニットに対する1つの値を記憶することを含む、請求項18に記載の方法。
JP19016296A 1995-08-11 1996-07-19 電力管理機能を備えたマイクロプロセッサ Expired - Lifetime JP3734888B2 (ja)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US514,284 1995-08-11
US08/514,284 US5996083A (en) 1995-08-11 1995-08-11 Microprocessor having software controllable power consumption

Publications (2)

Publication Number Publication Date
JPH0962418A JPH0962418A (ja) 1997-03-07
JP3734888B2 true JP3734888B2 (ja) 2006-01-11

Family

ID=24046545

Family Applications (1)

Application Number Title Priority Date Filing Date
JP19016296A Expired - Lifetime JP3734888B2 (ja) 1995-08-11 1996-07-19 電力管理機能を備えたマイクロプロセッサ

Country Status (2)

Country Link
US (1) US5996083A (ja)
JP (1) JP3734888B2 (ja)

Families Citing this family (205)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7266725B2 (en) 2001-09-03 2007-09-04 Pact Xpp Technologies Ag Method for debugging reconfigurable architectures
US6115799A (en) * 1996-07-19 2000-09-05 Canon Kabushiki Kaisha Information processing apparatus and associated method for managing a memory using a next fit and for reducing a memory fragmentation problem
DE19651075A1 (de) 1996-12-09 1998-06-10 Pact Inf Tech Gmbh Einheit zur Verarbeitung von numerischen und logischen Operationen, zum Einsatz in Prozessoren (CPU's), Mehrrechnersystemen, Datenflußprozessoren (DFP's), digitalen Signal Prozessoren (DSP's) oder dergleichen
DE19654595A1 (de) 1996-12-20 1998-07-02 Pact Inf Tech Gmbh I0- und Speicherbussystem für DFPs sowie Bausteinen mit zwei- oder mehrdimensionaler programmierbaren Zellstrukturen
ATE243390T1 (de) 1996-12-27 2003-07-15 Pact Inf Tech Gmbh Verfahren zum selbständigen dynamischen umladen von datenflussprozessoren (dfps) sowie bausteinen mit zwei- oder mehrdimensionalen programmierbaren zellstrukturen (fpgas, dpgas, o.dgl.)
US6282663B1 (en) * 1997-01-22 2001-08-28 Intel Corporation Method and apparatus for performing power management by suppressing the speculative execution of instructions within a pipelined microprocessor
US6182203B1 (en) * 1997-01-24 2001-01-30 Texas Instruments Incorporated Microprocessor
US6542998B1 (en) 1997-02-08 2003-04-01 Pact Gmbh Method of self-synchronization of configurable elements of a programmable module
CN1157641C (zh) * 1997-09-03 2004-07-14 松下电器产业株式会社 处理器
US8686549B2 (en) 2001-09-03 2014-04-01 Martin Vorbach Reconfigurable elements
DE19861088A1 (de) 1997-12-22 2000-02-10 Pact Inf Tech Gmbh Verfahren zur Reparatur von integrierten Schaltkreisen
EP0953892A1 (en) * 1998-04-29 1999-11-03 Lsi Logic Corporation Method of providing clock signals to load circuits in an ASIC device
JP2000020187A (ja) * 1998-07-07 2000-01-21 Fujitsu Ltd 情報処理装置及び電力制御方法並びに記録媒体
US6378081B1 (en) * 1998-10-01 2002-04-23 Gateway, Inc. Power conservation without performance reduction in a power-managed system
JP2000122747A (ja) * 1998-10-12 2000-04-28 Nec Corp ディジタル信号演算処理部の制御装置および方法
US6657973B1 (en) * 1998-10-27 2003-12-02 Matsushita Electric Industrial Co., Ltd. Communications node, network system and method of controlling network system
US6347377B2 (en) * 1998-11-04 2002-02-12 Phoenix Technologies Ltd. Method and apparatus for providing intelligent power management
US6604202B1 (en) * 1998-11-20 2003-08-05 Hitachi, Ltd. Low power processor
US6611891B1 (en) 1998-11-23 2003-08-26 Advanced Micro Devices, Inc. Computer resource configuration mechanism across a multi-pipe communication link
JP3326399B2 (ja) * 1998-12-17 2002-09-24 松下電器産業株式会社 通信ノードおよびこれを有する情報機器、並びにネットワークシステム
US6477654B1 (en) * 1999-04-06 2002-11-05 International Business Machines Corporation Managing VT for reduced power using power setting commands in the instruction stream
US6345362B1 (en) * 1999-04-06 2002-02-05 International Business Machines Corporation Managing Vt for reduced power using a status table
US6510525B1 (en) * 1999-04-26 2003-01-21 Mediaq, Inc. Method and apparatus to power up an integrated device from a low power state
US6438700B1 (en) * 1999-05-18 2002-08-20 Koninklijke Philips Electronics N.V. System and method to reduce power consumption in advanced RISC machine (ARM) based systems
AU5805300A (en) 1999-06-10 2001-01-02 Pact Informationstechnologie Gmbh Sequence partitioning in cell structures
US6564331B1 (en) * 1999-09-24 2003-05-13 Intel Corporation Low power register file
US6662302B1 (en) * 1999-09-29 2003-12-09 Conexant Systems, Inc. Method and apparatus of selecting one of a plurality of predetermined configurations using only necessary bus widths based on power consumption analysis for programmable logic device
US6564328B1 (en) * 1999-12-23 2003-05-13 Intel Corporation Microprocessor with digital power throttle
ATE366958T1 (de) 2000-01-14 2007-08-15 Texas Instruments France Mikroprozessor mit ermässigtem stromverbrauch
US7100061B2 (en) 2000-01-18 2006-08-29 Transmeta Corporation Adaptive power control
AUPQ542900A0 (en) * 2000-02-04 2000-02-24 Bisinella, Richard Microprocessor
JP3538358B2 (ja) * 2000-02-17 2004-06-14 三菱電機株式会社 プログラマブル・コントローラ
US7856633B1 (en) 2000-03-24 2010-12-21 Intel Corporation LRU cache replacement for a partitioned set associative cache
EP1342158B1 (de) 2000-06-13 2010-08-04 Richter, Thomas Pipeline ct-protokolle und -kommunikation
US6968469B1 (en) 2000-06-16 2005-11-22 Transmeta Corporation System and method for preserving internal processor context when the processor is powered down and restoring the internal processor context when processor is restored
JP3878431B2 (ja) * 2000-06-16 2007-02-07 株式会社ルネサステクノロジ 半導体集積回路装置
US6678815B1 (en) * 2000-06-27 2004-01-13 Intel Corporation Apparatus and method for reducing power consumption due to cache and TLB accesses in a processor front-end
EP1182552A3 (en) * 2000-08-21 2003-10-01 Texas Instruments France Dynamic hardware configuration for energy management systems using task attributes
EP1182548A3 (en) * 2000-08-21 2003-10-15 Texas Instruments France Dynamic hardware control for energy management systems using task attributes
US6766460B1 (en) * 2000-08-23 2004-07-20 Koninklijke Philips Electronics N.V. System and method for power management in a Java accelerator environment
US6971035B2 (en) * 2000-08-29 2005-11-29 Sony Corporation Method and system for reducing power consumption of a multi-function electronic apparatus that is adapted to receive power from a host system
US6963992B1 (en) * 2000-09-28 2005-11-08 Cypress Semiconductor Corp. Method and apparatus to generate clock and control signals for over-clocking recovery in a PLL
US6910139B2 (en) * 2000-10-02 2005-06-21 Fujitsu Limited Software processing apparatus with a switching processing unit for displaying animation images in an environment operating base on type of power supply
US8058899B2 (en) 2000-10-06 2011-11-15 Martin Vorbach Logic cell array and bus system
US7260731B1 (en) * 2000-10-23 2007-08-21 Transmeta Corporation Saving power when in or transitioning to a static mode of a processor
US7069047B2 (en) * 2001-01-19 2006-06-27 Raze Technologies, Inc. System and method for on-line insertion of line replaceable units in wireless and wireline access systems
JP3877518B2 (ja) 2000-12-13 2007-02-07 松下電器産業株式会社 プロセッサの電力制御装置
US7000130B2 (en) * 2000-12-26 2006-02-14 Intel Corporation Method and apparatus for thermal throttling of clocks using localized measures of activity
US6691301B2 (en) * 2001-01-29 2004-02-10 Celoxica Ltd. System, method and article of manufacture for signal constructs in a programming language capable of programming hardware architectures
US6895520B1 (en) 2001-03-02 2005-05-17 Advanced Micro Devices, Inc. Performance and power optimization via block oriented performance measurement and control
US7444531B2 (en) 2001-03-05 2008-10-28 Pact Xpp Technologies Ag Methods and devices for treating and processing data
US7844796B2 (en) 2001-03-05 2010-11-30 Martin Vorbach Data processing device and method
US9037807B2 (en) 2001-03-05 2015-05-19 Pact Xpp Technologies Ag Processor arrangement on a chip including data processing, memory, and interface elements
US6993669B2 (en) * 2001-04-18 2006-01-31 Gallitzin Allegheny Llc Low power clocking systems and methods
US6990598B2 (en) * 2001-03-21 2006-01-24 Gallitzin Allegheny Llc Low power reconfigurable systems and methods
JP2002366351A (ja) * 2001-06-06 2002-12-20 Nec Corp スーパースカラ・プロセッサ
US7657877B2 (en) 2001-06-20 2010-02-02 Pact Xpp Technologies Ag Method for processing data
US20030120896A1 (en) * 2001-06-29 2003-06-26 Jason Gosior System on chip architecture
US7174467B1 (en) 2001-07-18 2007-02-06 Advanced Micro Devices, Inc. Message based power management in a multi-processor system
US7051218B1 (en) 2001-07-18 2006-05-23 Advanced Micro Devices, Inc. Message based power management
US7996827B2 (en) 2001-08-16 2011-08-09 Martin Vorbach Method for the translation of programs for reconfigurable architectures
JP2005507652A (ja) * 2001-08-17 2005-03-24 インサイト・ゲノミックス・インコーポレイテッド 核酸結合タンパク質
US7434191B2 (en) 2001-09-03 2008-10-07 Pact Xpp Technologies Ag Router
US8686475B2 (en) 2001-09-19 2014-04-01 Pact Xpp Technologies Ag Reconfigurable elements
JP4931308B2 (ja) * 2001-09-28 2012-05-16 ルネサスエレクトロニクス株式会社 半導体集積回路装置
FI20011947A (fi) * 2001-10-05 2003-04-06 Nokia Corp Menetelmä suorittimen toiminnan ohjaamiseksi ja suoritin
US6938176B1 (en) * 2001-10-05 2005-08-30 Nvidia Corporation Method and apparatus for power management of graphics processors and subsystems that allow the subsystems to respond to accesses when subsystems are idle
US20030088799A1 (en) * 2001-11-05 2003-05-08 Bodas Devadatta V. Method and apparatus for regulation of electrical component temperature and power consumption rate through bus width reconfiguration
GB2366891B (en) * 2001-12-06 2002-11-20 Appsense Ltd Improvements in and relating to computer apparatus terminal server apparatus & performance management methods therefor
US6948079B2 (en) * 2001-12-26 2005-09-20 Intel Corporation Method and apparatus for providing supply voltages for a processor
US20030122429A1 (en) * 2001-12-28 2003-07-03 Zhang Kevin X. Method and apparatus for providing multiple supply voltages for a processor
US20030126477A1 (en) * 2001-12-28 2003-07-03 Zhang Kevin X. Method and apparatus for controlling a supply voltage to a processor
US7114086B2 (en) * 2002-01-04 2006-09-26 Ati Technologies, Inc. System for reduced power consumption by monitoring instruction buffer and method thereof
EP1483682A2 (de) 2002-01-19 2004-12-08 PACT XPP Technologies AG Reconfigurierbarer prozessor
EP2043000B1 (de) 2002-02-18 2011-12-21 Richter, Thomas Bussysteme und Rekonfigurationsverfahren
US8914590B2 (en) 2002-08-07 2014-12-16 Pact Xpp Technologies Ag Data processing method and device
FI115562B (fi) * 2002-03-27 2005-05-31 Nokia Corp Menetelmä ja järjestelmä tehonkulutuksen määrittämiseksi elektroniikkalaitteen yhteydessä ja elektroniikkalaite
US7941675B2 (en) 2002-12-31 2011-05-10 Burr James B Adaptive power control
US7180322B1 (en) 2002-04-16 2007-02-20 Transmeta Corporation Closed loop feedback control of integrated circuits
US7336090B1 (en) 2002-04-16 2008-02-26 Transmeta Corporation Frequency specific closed loop feedback control of integrated circuits
AU2002257172A1 (en) * 2002-04-19 2003-11-03 International Business Machines Corporation Power control of a processor using hardware structures controlled by a compiler with an accumulated instruction profile
US6792379B2 (en) * 2002-04-24 2004-09-14 Yoshiyuki Ando Data-based control of integrated circuits
US6957163B2 (en) * 2002-04-24 2005-10-18 Yoshiyuki Ando Integrated circuits having post-silicon adjustment control
JP3685151B2 (ja) * 2002-04-26 2005-08-17 セイコーエプソン株式会社 クロック制御回路、データ転送制御装置及び電子機器
JP3685150B2 (ja) * 2002-04-26 2005-08-17 セイコーエプソン株式会社 クロック制御回路、データ転送制御装置及び電子機器
EP1363179A1 (en) 2002-05-17 2003-11-19 STMicroelectronics S.A. Architecture for controlling dissipated power in a system on a chip and related system
US7269752B2 (en) * 2002-06-04 2007-09-11 Lucent Technologies Inc. Dynamically controlling power consumption within a network node
US6667929B1 (en) 2002-06-14 2003-12-23 International Business Machines Corporation Power governor for dynamic RAM
US7657861B2 (en) 2002-08-07 2010-02-02 Pact Xpp Technologies Ag Method and device for processing data
AU2003286131A1 (en) 2002-08-07 2004-03-19 Pact Xpp Technologies Ag Method and device for processing data
US7634668B2 (en) * 2002-08-22 2009-12-15 Nvidia Corporation Method and apparatus for adaptive power consumption
JP4388895B2 (ja) 2002-09-06 2009-12-24 ペーアーツェーテー イクスペーペー テクノロジーズ アクチエンゲゼルシャフト リコンフィギュアラブルなシーケンサ構造
US7243217B1 (en) * 2002-09-24 2007-07-10 Advanced Micro Devices, Inc. Floating point unit with variable speed execution pipeline and method of operation
US20050044429A1 (en) * 2003-08-22 2005-02-24 Ip-First Llc Resource utilization mechanism for microprocessor power management
US7290156B2 (en) * 2003-12-17 2007-10-30 Via Technologies, Inc. Frequency-voltage mechanism for microprocessor power management
US7774627B2 (en) * 2002-10-03 2010-08-10 Via Technologies, Inc. Microprocessor capable of dynamically increasing its performance in response to varying operating temperature
US7302599B2 (en) * 2004-02-12 2007-11-27 Via Technologies, Inc. Instantaneous frequency-based microprocessor power management
US7814350B2 (en) * 2002-10-03 2010-10-12 Via Technologies, Inc. Microprocessor with improved thermal monitoring and protection mechanism
US7698583B2 (en) 2002-10-03 2010-04-13 Via Technologies, Inc. Microprocessor capable of dynamically reducing its power consumption in response to varying operating temperature
US7770042B2 (en) * 2002-10-03 2010-08-03 Via Technologies, Inc. Microprocessor with improved performance during P-state transitions
US7882369B1 (en) 2002-11-14 2011-02-01 Nvidia Corporation Processor performance adjustment system and method
US7849332B1 (en) 2002-11-14 2010-12-07 Nvidia Corporation Processor voltage adjustment system and method
US7886164B1 (en) 2002-11-14 2011-02-08 Nvidia Corporation Processor temperature adjustment system and method
WO2004051449A2 (en) * 2002-12-04 2004-06-17 Koninklijke Philips Electronics N.V. Register file gating to reduce microprocessor power dissipation
US7500126B2 (en) * 2002-12-04 2009-03-03 Nxp B.V. Arrangement and method for controlling power modes of hardware resources
US8086884B2 (en) * 2002-12-16 2011-12-27 Hewlett-Packard Development Company, L.P. System and method for implementing an integrated circuit having dynamically variable power limit
US7290152B2 (en) * 2002-12-30 2007-10-30 International Business Machines Corporation Method and system for managing power within a compute component of a multiprocessor system
US7953990B2 (en) * 2002-12-31 2011-05-31 Stewart Thomas E Adaptive power control based on post package characterization of integrated circuits
US7228242B2 (en) 2002-12-31 2007-06-05 Transmeta Corporation Adaptive power control based on pre package characterization of integrated circuits
US7205758B1 (en) 2004-02-02 2007-04-17 Transmeta Corporation Systems and methods for adjusting threshold voltage
US7642835B1 (en) * 2003-11-12 2010-01-05 Robert Fu System for substrate potential regulation during power-up in integrated circuits
US7949864B1 (en) 2002-12-31 2011-05-24 Vjekoslav Svilan Balanced adaptive body bias control
US7786756B1 (en) 2002-12-31 2010-08-31 Vjekoslav Svilan Method and system for latchup suppression
US6992675B2 (en) * 2003-02-04 2006-01-31 Ati Technologies, Inc. System for displaying video on a portable device and method thereof
US7185215B2 (en) * 2003-02-24 2007-02-27 International Business Machines Corporation Machine code builder derived power consumption reduction
US20040181654A1 (en) * 2003-03-11 2004-09-16 Chung-Hui Chen Low power branch prediction target buffer
US6915438B2 (en) * 2003-04-04 2005-07-05 Arraycomm, Inc Distributed power management method for monitoring control/status signal of sub-modules to manage power of sub-modules by activating clock signal during operation of sub-modules
US7028197B2 (en) * 2003-04-22 2006-04-11 Lsi Logic Corporation System and method for electrical power management in a data processing system using registers to reflect current operating conditions
US7134028B2 (en) * 2003-05-01 2006-11-07 International Business Machines Corporation Processor with low overhead predictive supply voltage gating for leakage power reduction
JP2007501478A (ja) * 2003-05-07 2007-01-25 ヴァーチャル シリコン テクノロジー インコーポレイテッド 電力の島を使用した集積回路での電力の管理
EP1676208A2 (en) 2003-08-28 2006-07-05 PACT XPP Technologies AG Data processing device and method
US7174469B2 (en) * 2003-09-30 2007-02-06 International Business Machines Corporation Processor power and energy management
TWI242133B (en) * 2003-12-02 2005-10-21 Via Tech Inc Interrupt signal control method
US7287173B2 (en) * 2003-12-19 2007-10-23 Intel Corporation Method for computing power consumption levels of instruction and recompiling the program to reduce the excess power consumption
US7129771B1 (en) 2003-12-23 2006-10-31 Transmeta Corporation Servo loop for well bias voltage source
US7246219B2 (en) * 2003-12-23 2007-07-17 Intel Corporation Methods and apparatus to control functional blocks within a processor
US7012461B1 (en) 2003-12-23 2006-03-14 Transmeta Corporation Stabilization component for a substrate potential regulation circuit
US7649402B1 (en) 2003-12-23 2010-01-19 Tien-Min Chen Feedback-controlled body-bias voltage source
US7692477B1 (en) 2003-12-23 2010-04-06 Tien-Min Chen Precise control component for a substrate potential regulation circuit
KR20050071739A (ko) * 2004-01-02 2005-07-08 삼성전자주식회사 누설 전력을 줄이기 위한 마이크로프로세서
US7816742B1 (en) 2004-09-30 2010-10-19 Koniaris Kleanthes G Systems and methods for integrated circuits comprising multiple body biasing domains
US7859062B1 (en) * 2004-02-02 2010-12-28 Koniaris Kleanthes G Systems and methods for integrated circuits comprising multiple body biasing domains
US7334418B2 (en) * 2004-02-12 2008-02-26 Via Technologies, Inc. Method and apparatus for microprocessor temperature control
US7376854B2 (en) * 2004-03-31 2008-05-20 Intel Corporation System for enabling and disabling voltage regulator controller of electronic appliance according to a series of delay times assigned to voltage regulator controllers
US7334143B2 (en) * 2004-04-19 2008-02-19 Hewlett-Packard Development Company, L.P. Computer power conservation apparatus and method that enables less speculative execution during light processor load based on a branch confidence threshold value
US7395419B1 (en) * 2004-04-23 2008-07-01 Apple Inc. Macroscalar processor architecture
US7617496B2 (en) 2004-04-23 2009-11-10 Apple Inc. Macroscalar processor architecture
US7401240B2 (en) * 2004-06-03 2008-07-15 International Business Machines Corporation Method for dynamically managing power in microprocessor chips according to present processing demands
US7562233B1 (en) 2004-06-22 2009-07-14 Transmeta Corporation Adaptive control of operating and body bias voltages
US7774625B1 (en) 2004-06-22 2010-08-10 Eric Chien-Li Sheng Adaptive voltage control by accessing information stored within and specific to a microprocessor
US7330988B2 (en) * 2004-06-30 2008-02-12 Sun Microsystems, Inc. Method and apparatus for power throttling in a multi-thread processor
US7299371B2 (en) * 2004-08-05 2007-11-20 International Business Machines Corporation Hierarchical management for multiprocessor system
US7299372B2 (en) * 2004-08-05 2007-11-20 International Business Machines Corporation Hierarchical management for multiprocessor system with real-time attributes
JP2008520314A (ja) * 2004-11-22 2008-06-19 コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ 可変電力消費の携帯型超音波システム
US7395443B1 (en) * 2004-12-28 2008-07-01 Advanced Micro Devices, Inc. Integrated circuit with a hibernate mode and method therefor
US7467325B2 (en) * 2005-02-10 2008-12-16 International Business Machines Corporation Processor instruction retry recovery
US20060184771A1 (en) * 2005-02-11 2006-08-17 International Business Machines Mini-refresh processor recovery as bug workaround method using existing recovery hardware
US7334140B2 (en) * 2005-03-03 2008-02-19 International Business Machines Corporation Apparatus and method to selectively provide power to one or more components disposed in an information storage and retrieval system
US7739531B1 (en) 2005-03-04 2010-06-15 Nvidia Corporation Dynamic voltage scaling
JP4082706B2 (ja) * 2005-04-12 2008-04-30 学校法人早稲田大学 マルチプロセッサシステム及びマルチグレイン並列化コンパイラ
US7444525B2 (en) * 2005-05-25 2008-10-28 Sony Computer Entertainment Inc. Methods and apparatus for reducing leakage current in a disabled SOI circuit
US7472301B2 (en) * 2005-05-27 2008-12-30 Codman Neuro Sciences Sárl Circuitry for optimization of power consumption in a system employing multiple electronic components, one of which is always powered on
US7225100B2 (en) * 2005-07-05 2007-05-29 Via Technologies, Inc. Apparatus and method for dynamic configuration of temperature profile in an integrated circuit
US8914618B2 (en) * 2005-12-29 2014-12-16 Intel Corporation Instruction set architecture-based inter-sequencer communications with a heterogeneous resource
EP1974265A1 (de) 2006-01-18 2008-10-01 PACT XPP Technologies AG Hardwaredefinitionsverfahren
US7555664B2 (en) * 2006-01-31 2009-06-30 Cypress Semiconductor Corp. Independent control of core system blocks for power optimization
US20070188186A1 (en) * 2006-02-14 2007-08-16 Toshiba America Electronic Components Systems and methods for managing power supplied to integrated circuits
US8595279B2 (en) * 2006-02-27 2013-11-26 Qualcomm Incorporated Floating-point processor with reduced power requirements for selectable subprecision
US8102398B2 (en) * 2006-03-03 2012-01-24 Ati Technologies Ulc Dynamically controlled power reduction method and circuit for a graphics processor
US7693257B2 (en) * 2006-06-29 2010-04-06 Accuray Incorporated Treatment delivery optimization
US7565560B2 (en) * 2006-10-31 2009-07-21 International Business Machines Corporation Supplying combinations of clock frequency, voltage, and current to processors
US8667198B2 (en) * 2007-01-07 2014-03-04 Apple Inc. Methods and systems for time keeping in a data processing system
US7818592B2 (en) * 2007-04-18 2010-10-19 Globalfoundries Inc. Token based power control mechanism
US9134782B2 (en) 2007-05-07 2015-09-15 Nvidia Corporation Maintaining optimum voltage supply to match performance of an integrated circuit
US20090125010A1 (en) * 2007-07-06 2009-05-14 Sharkey Hugh R Uterine Therapy Device and Method
US7937568B2 (en) * 2007-07-11 2011-05-03 International Business Machines Corporation Adaptive execution cycle control method for enhanced instruction throughput
JP4782082B2 (ja) * 2007-08-22 2011-09-28 日本電信電話株式会社 パケット処理装置、方法、およびプログラム
US8370663B2 (en) 2008-02-11 2013-02-05 Nvidia Corporation Power management with dynamic frequency adjustments
US8145923B2 (en) * 2008-02-20 2012-03-27 Xilinx, Inc. Circuit for and method of minimizing power consumption in an integrated circuit device
US8028180B2 (en) * 2008-02-20 2011-09-27 International Business Machines Corporation Method and system for power conservation in a hierarchical branch predictor
US20090276644A1 (en) * 2008-05-02 2009-11-05 Goodnow Kenneth J Structure for semiconductor power distribution and control
US20090273239A1 (en) * 2008-05-02 2009-11-05 Goodnow Kenneth J Semiconductor power distribution and control systems and methods
US8181003B2 (en) * 2008-05-29 2012-05-15 Axis Semiconductor, Inc. Instruction set design, control and communication in programmable microprocessor cores and the like
US20100146169A1 (en) * 2008-12-05 2010-06-10 Nuvoton Technology Corporation Bus-handling
US8037325B1 (en) 2008-12-09 2011-10-11 Google Inc. System and method for determining power consumption
US7653826B1 (en) 2009-01-20 2010-01-26 International Business Machines Corporation Method and apparatus for query optimization and management of sleepy drives
US8135972B2 (en) 2009-03-10 2012-03-13 Cortina Systems, Inc. Data interface power consumption control
US9104435B2 (en) * 2009-04-14 2015-08-11 Empire Technology Development Llc Program and data annotation for hardware customization and energy optimization
US8255716B2 (en) * 2009-08-27 2012-08-28 Qualcomm Incorporated Power optimization for data services
US8700925B2 (en) * 2009-09-01 2014-04-15 Nvidia Corporation Regulating power using a fuzzy logic control system
US8826048B2 (en) * 2009-09-01 2014-09-02 Nvidia Corporation Regulating power within a shared budget
JP5321866B2 (ja) * 2009-09-16 2013-10-23 株式会社東芝 コンピュータシステム
NL2003915C2 (en) * 2009-12-07 2011-06-09 Yggdra Solutions Improved power usage management.
US9256265B2 (en) 2009-12-30 2016-02-09 Nvidia Corporation Method and system for artificially and dynamically limiting the framerate of a graphics processing unit
US9830889B2 (en) 2009-12-31 2017-11-28 Nvidia Corporation Methods and system for artifically and dynamically limiting the display resolution of an application
US20110292855A1 (en) * 2010-05-28 2011-12-01 Qualcomm Incorporated Dynamic clock buffer power optimization based on modes of operation
US8839006B2 (en) 2010-05-28 2014-09-16 Nvidia Corporation Power consumption reduction systems and methods
KR101754203B1 (ko) * 2011-01-19 2017-07-07 삼성전자주식회사 파워 게이팅 기반의 재구성가능 프로세서, 이를 위한 컴파일 장치 및 방법
US20120246458A1 (en) * 2011-03-25 2012-09-27 Cisco Technology, Inc. Power optimization on a thin client device
JP5647062B2 (ja) * 2011-04-28 2014-12-24 富士通フロンテック株式会社 最大消費電力軽減装置
JP5946251B2 (ja) * 2011-07-06 2016-07-06 ルネサスエレクトロニクス株式会社 半導体装置およびシステム
JP5806529B2 (ja) 2011-07-06 2015-11-10 ルネサスエレクトロニクス株式会社 半導体装置、それを用いた無線通信端末、及びクロック周波数制御方法
US9009451B2 (en) * 2011-10-31 2015-04-14 Apple Inc. Instruction type issue throttling upon reaching threshold by adjusting counter increment amount for issued cycle and decrement amount for not issued cycle
US9367080B2 (en) * 2011-12-22 2016-06-14 Intel Corporation Apparatus, system, and method for providing clock signal on demand
JP5928272B2 (ja) * 2012-09-18 2016-06-01 富士通株式会社 半導体集積回路及びコンパイラ
US10175981B2 (en) * 2013-07-09 2019-01-08 Texas Instruments Incorporated Method to control the number of active vector lanes for power efficiency
US10732689B2 (en) 2013-07-09 2020-08-04 Texas Instruments Incorporated Controlling the number of powered vector lanes via a register field
KR102154080B1 (ko) * 2014-07-25 2020-09-09 삼성전자주식회사 전력 관리 시스템, 이를 포함하는 시스템 온 칩 및 모바일 기기
US9747239B2 (en) * 2014-08-25 2017-08-29 Apple Inc. Transaction filter for on-chip communications network
US9927862B2 (en) 2015-05-21 2018-03-27 Microsoft Technology Licensing, Llc Variable precision in hardware pipelines for power conservation
US9977488B1 (en) * 2016-03-10 2018-05-22 Changming Kong Electronic device with smart power management system
KR20190041330A (ko) 2017-10-12 2019-04-22 에스케이하이닉스 주식회사 전원 게이팅 회로를 포함하는 반도체 장치
US10588607B2 (en) 2017-12-08 2020-03-17 Clarius Mobile Health Corp. Systems and methods for managing power in an ultrasound imaging machine
TWI697841B (zh) * 2018-12-18 2020-07-01 新唐科技股份有限公司 控制電路及快速設定電源模式的方法
US10565036B1 (en) 2019-02-14 2020-02-18 Axis Semiconductor, Inc. Method of synchronizing host and coprocessor operations via FIFO communication

Family Cites Families (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4991078A (en) * 1987-09-29 1991-02-05 Digital Equipment Corporation Apparatus and method for a pipelined central processing unit in a data processing system
US5142684A (en) * 1989-06-23 1992-08-25 Hand Held Products, Inc. Power conservation in microprocessor controlled devices
JPH0328911A (ja) * 1989-06-26 1991-02-07 Mitsubishi Electric Corp マイクロプロセッサ
US5222239A (en) * 1989-07-28 1993-06-22 Prof. Michael H. Davis Process and apparatus for reducing power usage microprocessor devices operating from stored energy sources
US5167024A (en) * 1989-09-08 1992-11-24 Apple Computer, Inc. Power management for a laptop computer with slow and sleep modes
US5230074A (en) * 1991-01-25 1993-07-20 International Business Machines Corporation Battery operated computer power management system
GB2264794B (en) * 1992-03-06 1995-09-20 Intel Corp Method and apparatus for automatic power management in a high integration floppy disk controller
US5392437A (en) * 1992-11-06 1995-02-21 Intel Corporation Method and apparatus for independently stopping and restarting functional units
EP0597601A1 (en) * 1992-11-13 1994-05-18 National Semiconductor Corporation Reflexively sizing memory bus interface
US5603037A (en) * 1993-04-23 1997-02-11 Intel Corporation Clock disable circuit for translation buffer
US5420808A (en) * 1993-05-13 1995-05-30 International Business Machines Corporation Circuitry and method for reducing power consumption within an electronic circuit
US5471625A (en) * 1993-09-27 1995-11-28 Motorola, Inc. Method and apparatus for entering a low-power mode and controlling an external bus of a data processing system during low-power mode

Also Published As

Publication number Publication date
US5996083A (en) 1999-11-30
JPH0962418A (ja) 1997-03-07

Similar Documents

Publication Publication Date Title
JP3734888B2 (ja) 電力管理機能を備えたマイクロプロセッサ
US6021501A (en) Clock enable/disable circuit of power management system
JP3701910B2 (ja) スリープ状態への移行
US5649213A (en) Method and apparatus for reducing power consumption in a computer system
US6118306A (en) Changing clock frequency
US8051315B2 (en) Power throttling apparatus
US5935253A (en) Method and apparatus for powering down an integrated circuit having a core that operates at a speed greater than the bus frequency
US7120810B2 (en) Instruction-initiated power management method for a pipelined data processor
US20070043965A1 (en) Dynamic memory sizing for power reduction
Gary et al. PowerPC 603, a microprocessor for portable computers
US20080077816A1 (en) Subsystem Power Management
JP3919246B2 (ja) マルチプレクサ、集積プロセッサ、および信号マルチプレクサ
US20070174514A1 (en) Instantaneous data-driven clock-gating device and hard-wired streaming processing system including the same
US7210054B2 (en) Maintaining processor execution during frequency transitioning
EP1831770A2 (en) Techniques to manage power for a mobile device
US6496888B1 (en) Incorporation of bus ratio strap options in chipset logic
US6035315A (en) Floating point power conservation
US5784627A (en) Integrated timer for power management and watchdog functions
EP1237066B1 (en) Microprocessor with hardware controlled power management and selectable input/output control pins and method therfor
JPH10301659A (ja) マイクロプロセッサ
JP2007521538A (ja) 要求駆動型クロック・スロットリング電力低減を用いるプロセッサ
Gary Low-power microprocessor design

Legal Events

Date Code Title Description
A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20050623

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20050628

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20050916

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: 20051018

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20051020

R150 Certificate of patent or registration of utility model

Free format text: JAPANESE INTERMEDIATE CODE: R150

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

Free format text: PAYMENT UNTIL: 20091028

Year of fee payment: 4

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

Free format text: PAYMENT UNTIL: 20091028

Year of fee payment: 4

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

Free format text: PAYMENT UNTIL: 20101028

Year of fee payment: 5

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

Free format text: PAYMENT UNTIL: 20111028

Year of fee payment: 6

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

Free format text: PAYMENT UNTIL: 20121028

Year of fee payment: 7

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

Free format text: PAYMENT UNTIL: 20121028

Year of fee payment: 7

S111 Request for change of ownership or part of ownership

Free format text: JAPANESE INTERMEDIATE CODE: R313113

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

Free format text: PAYMENT UNTIL: 20121028

Year of fee payment: 7

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350

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

Free format text: PAYMENT UNTIL: 20121028

Year of fee payment: 7

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

Free format text: PAYMENT UNTIL: 20131028

Year of fee payment: 8

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

EXPY Cancellation because of completion of term