JP2002334128A - Method for simulating power consumption of semiconductor integrated circuit - Google Patents
Method for simulating power consumption of semiconductor integrated circuitInfo
- Publication number
- JP2002334128A JP2002334128A JP2001140462A JP2001140462A JP2002334128A JP 2002334128 A JP2002334128 A JP 2002334128A JP 2001140462 A JP2001140462 A JP 2001140462A JP 2001140462 A JP2001140462 A JP 2001140462A JP 2002334128 A JP2002334128 A JP 2002334128A
- Authority
- JP
- Japan
- Prior art keywords
- power consumption
- cache
- mmu
- instruction
- write
- 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.)
- Pending
Links
Classifications
-
- Y—GENERAL 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
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE 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/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Memory System Of A Hierarchy Structure (AREA)
Abstract
Description
【0001】[0001]
【発明の属する技術分野】本発明は、計算機を用いて行
う半導体集積回路の消費電力シミュレーション方法にか
かわり、特に、命令レベルのシミュレーションによって
消費電力を見積もる場合に、論理アドレスを用いてタス
ク処理を行うことを前提としたプロセッサコアに対して
も、その半導体集積回路の回路動作を模擬するととも
に、その消費電力を高速に見積もるための技術に関す
る。BACKGROUND OF THE INVENTION 1. Field of the Invention The present invention relates to a method for simulating power consumption of a semiconductor integrated circuit using a computer, and more particularly to performing task processing using logical addresses when estimating power consumption by instruction-level simulation. The present invention also relates to a technique for simulating the circuit operation of a semiconductor integrated circuit and estimating the power consumption of the processor core at high speed.
【0002】[0002]
【従来の技術】従来、計算機を用いた半導体集積回路の
消費電力シミュレーション方法として、特にコアベース
設計又はIPベース設計と呼ばれる設計においては、命
令レベルでのシミュレーション方法が用いられていた。2. Description of the Related Art Conventionally, as a method of simulating power consumption of a semiconductor integrated circuit using a computer, a simulation method at an instruction level has been used particularly in a design called core-based design or IP-based design.
【0003】命令レベルの消費電力のシミュレーション
としては、特開平09−218731号公報、特開平1
0−254944号公報等に開示されている。これらで
示されている方法は、予めキャッシュアクセスやバスア
クセスなどのシミュレーション対象動作に対する消費電
力ライブラリを用意し、シミュレーションを実行した結
果、各シミュレーション対象動作の発生回数を数え、実
行したプログラムに対して、シミュレーション対象の回
路全体で消費される電力を計算するというものである。As a simulation of power consumption at an instruction level, Japanese Patent Application Laid-Open No. 09-218731 and
No. 0-254944. The methods shown in these methods prepare a power consumption library for a simulation target operation such as a cache access or a bus access in advance, and execute a simulation.As a result, the number of occurrences of each simulation target operation is counted, and the executed program is executed. That is, the power consumed by the entire circuit to be simulated is calculated.
【0004】[0004]
【発明が解決しようとする課題】しかしながら、近年、
半導体集積回路が用いられる分野においては、ソフトウ
ェアに複雑で高度な処理とソフトウェア自身の再利用性
が求められており、その実現のためにハードウェアにお
いてもMMU(Memory Management Unit:メモリ管理
機構)を搭載し、論理アドレスやアクセス保護機能を実
現することが必須となっている。However, in recent years,
In the field in which semiconductor integrated circuits are used, software is required to have complicated and advanced processing and reusability of the software itself. To realize this, an MMU (Memory Management Unit) is also required in hardware. It is indispensable to mount it and implement a logical address and access protection function.
【0005】MMUを搭載したシステムでは、アドレス
変換のテーブルであるページ表を必要に応じてアクセス
し、MMU内のアドレス変換テーブルであるTLB(Tr
anslation Lookaside Buffers:アドレス変換バッフ
ァ)への格納が行われる。また、キャッシュの動作モー
ドが同時にページ表に定義され、アドレス領域ごとにキ
ャッシュ動作として、ライトバックモード又はライトス
ルーモード、又はキャッシュ動作禁止などが定義され
る。In a system equipped with an MMU, a page table which is an address conversion table is accessed as necessary, and a TLB (Tr) which is an address conversion table in the MMU is accessed.
Anslation Lookaside Buffers: address translation buffers) are stored. The cache operation mode is also defined in the page table at the same time, and a write-back mode or a write-through mode, a cache operation prohibition, or the like is defined as a cache operation for each address area.
【0006】ライトバックモード(WB)とは、メモリ
に対するデータの書き出し処理の際、キャッシュにヒッ
トした場合に、キャッシュメモリ内のデータのみを更新
するキャッシュ動作モードである。ライトスルーモード
(WT)とは、メモリに対するデータの書き出し処理の
際、キャッシュにヒットした場合に、キャッシュメモリ
内のデータを更新するとともに、メインメモリ中の対応
するアドレスのデータも更新するキャッシュ動作モード
である。The write-back mode (WB) is a cache operation mode for updating only data in the cache memory when a cache hit occurs during data write processing to the memory. The write-through mode (WT) is a cache operation mode for updating data in a cache memory and updating data at a corresponding address in a main memory when a cache hit occurs during a process of writing data to the memory. It is.
【0007】キャッシュメモリ内でのライトバックモー
ドのキャッシュ動作とライトスルーモードのキャッシュ
動作とは、互いに動作が異なるため、消費電力の見積も
りを区別する必要がある。[0007] Since the cache operation in the write-back mode and the cache operation in the write-through mode in the cache memory are different from each other, it is necessary to distinguish power consumption estimates.
【0008】さらに、ライトバックモードで定義された
アドレス領域のデータは、キャッシュ内のデータとの対
比において、対応するアドレスのメインメモリのデータ
の内容との一致性がない。そのため、キャッシュ内のみ
が更新された場合、一致性の保証ができないデータはダ
ーティデータとして扱いを区別する必要がある。したが
って、キャッシュの内容を一新したり、格納されている
キャッシュデータを別のアドレスのデータで上書きした
りする場合に、ダーティデータの書き出しというハード
ウェア処理が発生する。Furthermore, data in the address area defined in the write-back mode is inconsistent with data in the main memory at the corresponding address in comparison with data in the cache. Therefore, when only the contents of the cache are updated, data for which consistency cannot be guaranteed must be treated as dirty data and distinguished. Therefore, when the contents of the cache are renewed or stored cache data is overwritten with data of another address, a hardware process of writing dirty data occurs.
【0009】また、前記のようなソフトウェアの代表的
な例としてリアルタイムオペレーティングシステムがあ
り、これは近年、使われることが多くなっている。この
ようなソフトウェアを使用した場合、アドレス変換のテ
ーブルを切り替えることでタスクを切り替える手法がと
られ、論理アドレスでキャッシュ内にデータを格納して
いた場合、タスクの切り替え時にも、前記のダーティデ
ータの書き出しがハードウェア処理として生じ、前記の
ようにMMUを想定していない従来の消費電力のシミュ
レーション方法では正確な消費電力の見積もりはできな
い。A typical example of the above-mentioned software is a real-time operating system, which has been used in recent years. When such software is used, a method of switching tasks by switching an address conversion table is employed.If data is stored in a cache at a logical address, even when the task is switched, the Writing occurs as hardware processing, and accurate power consumption cannot be estimated by the conventional power consumption simulation method that does not assume an MMU as described above.
【0010】本発明は、かかる点に鑑みてなされたもの
であり、MMUを搭載し、論理アドレスと物理アドレス
を区別するプロセッサにおいて、命令レベルでの消費電
力のシミュレーションを行い、消費電力を正確に見積も
ることが可能な半導体集積回路の消費電力シミュレーシ
ョン方法を提供することを目的としている。SUMMARY OF THE INVENTION The present invention has been made in view of the above circumstances. In a processor equipped with an MMU and distinguishing between a logical address and a physical address, a simulation of power consumption at an instruction level is performed so that power consumption can be accurately calculated. It is an object of the present invention to provide a power consumption simulation method for a semiconductor integrated circuit that can be estimated.
【0011】[0011]
【課題を解決するための手段】前記の目的を達成するた
め、本発明による半導体集積回路の消費電力シミュレー
ション方法は、CPU(中央演算処理装置)、キャッシ
ュメモリおよびMMU(メモリ管理機構)を備えたプロ
セッサにおいて、予め、プロセッサ命令レベルの各命令
については命令毎の消費電力情報を備え、MMUについ
てはMMU動作毎の消費電力情報を備え、キャッシュメ
モリについてはキャッシュ動作毎の消費電力情報を備
え、シミュレーション実行中、又はシミュレーション実
行後に、前記の各消費電力情報に基づいて、シミュレー
ション対象のプロセッサにおいて消費される電力を計算
するものである。In order to achieve the above object, a method for simulating power consumption of a semiconductor integrated circuit according to the present invention includes a CPU (Central Processing Unit), a cache memory, and an MMU (Memory Management Mechanism). In the processor, power consumption information for each instruction is provided in advance for each instruction at the processor instruction level, power consumption information for each MMU operation is provided for the MMU, and power consumption information for each cache operation is provided for the cache memory. During the execution or after the execution of the simulation, the power consumed by the processor to be simulated is calculated based on the power consumption information.
【0012】キャッシュメモリおよびMMUを備えたプ
ロセッサの命令動作を計算機中でシミュレートする方法
を対象とし、シミュレーション前に予め、前記のプロセ
ッサの命令セットについて各々の命令が実行されるとき
に消費される電力を求め、命令毎の消費電力情報として
記憶しておき、また、前記のMMUの複数動作について
各々の動作に消費される電力を求め、MMU動作毎の消
費電力情報として記憶しておき、さらに、前記キャッシ
ュメモリの複数動作に対してライトバックモード、ライ
トスルーモードを区別して各々の動作に消費される電力
を求め、キャッシュ動作毎の消費電力情報を記憶してお
く。そして、与えられた論理アドレスを使用するプログ
ラムコードに対するシミュレーション実行時に、各々の
命令に対して、命令動作、MMU動作およびキャッシュ
動作をシミュレートするとともに、前記の命令毎の消費
電力情報に基づいて実行中の命令に対するCPU部の消
費電力を求め、前記MMU動作毎の消費電力情報に基づ
いてアドレス変換により発生するMMU動作に対応した
MMU部の消費電力を求め、さらにバスアクセスにより
発生するキャッシュ動作に対応したキャッシュ部の消費
電力を求め、前記のCPU部の消費電力と前記MMU部
の消費電力と前記キャッシュ部の消費電力から、プロセ
ッサにおけるプログラムコード実行時のトータルの消費
電力を求めることを特徴とする。The present invention is directed to a method of simulating the instruction operation of a processor having a cache memory and an MMU in a computer, and is consumed when each instruction is executed beforehand for the instruction set of the processor before the simulation. The power is obtained and stored as power consumption information for each instruction, and the power consumed for each operation of the plurality of operations of the MMU is obtained and stored as power consumption information for each MMU operation. The power consumed for each operation is obtained by distinguishing the write-back mode and the write-through mode for a plurality of operations of the cache memory, and power consumption information for each cache operation is stored. Then, when a simulation is performed for a program code using a given logical address, an instruction operation, an MMU operation, and a cache operation are simulated for each instruction and executed based on the power consumption information for each instruction. The power consumption of the CPU unit for the instruction in the middle is obtained, the power consumption of the MMU unit corresponding to the MMU operation generated by the address conversion is obtained based on the power consumption information for each MMU operation, and the power consumption of the MMU unit is further calculated. Determining a corresponding power consumption of the cache unit, and calculating a total power consumption of the processor when executing the program code from the power consumption of the CPU unit, the power consumption of the MMU unit, and the power consumption of the cache unit. I do.
【0013】本発明によれば、キャッシュメモリおよび
MMUを備えたプロセッサにおいて、プログラムコード
実行時の消費電力を比較的高速に求めることが可能にな
る。According to the present invention, in a processor including a cache memory and an MMU, it is possible to relatively quickly determine the power consumption during execution of a program code.
【0014】[0014]
【発明の実施の形態】以下、本発明の実施の形態を総括
的に説明する。BEST MODE FOR CARRYING OUT THE INVENTION Hereinafter, embodiments of the present invention will be generally described.
【0015】本願第1の発明の半導体集積回路の消費電
力シミュレーション方法は、シミュレーション実行前
に、プロセッサの命令セットの個々の命令およびキャッ
シュメモリおよびMMUの複数の動作に対して、回路レ
ベル又はゲートレベルのシミュレーション、又は実際に
試作した実チップの評価結果より、各命令が実行される
ときに消費される電力を求め、命令毎の消費電力情報と
して記憶し、各キャッシュ動作が実行されるときに消費
される電力を求め、キャッシュ動作毎の消費電力情報と
して記憶し、各MMU動作が実行されるときに消費され
る電力を求め、MMU動作毎の消費電力情報として記憶
しておく。この処理は、命令セット中の命令個数および
キャッシュ動作種類の個数分の処理、および、MMUの
動作種類の個数分の処理を行えば良いので、回路レベル
やゲートレベルのシミュレーションを用いても現実的な
時間内に計算することが可能である。A power consumption simulation method for a semiconductor integrated circuit according to a first aspect of the present invention provides a circuit-level or gate-level simulation for each instruction of an instruction set of a processor and a plurality of operations of a cache memory and an MMU before executing a simulation. The power consumed when each instruction is executed is obtained from the simulation of the above or the evaluation result of the actual chip actually produced, and stored as power consumption information for each instruction, and the power consumed when each cache operation is executed. The power consumed is calculated and stored as power consumption information for each cache operation. The power consumed when each MMU operation is executed is determined and stored as power consumption information for each MMU operation. This processing may be performed for the number of instructions in the instruction set and for the number of cache operation types, and for the number of MMU operation types. It is possible to calculate within a short time.
【0016】そして、シミュレーション実行中に与えら
れたプログラムコードに対する命令動作をシミュレート
するとともに、実行された命令に対応する消費電力の値
を命令毎の消費電力から検索する。キャッシュに関して
は、実行される命令のフェッチおよび、一部の命令に関
してはデータの書き込み又は、読み出しのアクセスのキ
ャッシュ動作をシミュレートするとともに、実行された
キャッシュ動作に対応する消費電力の値をキャッシュ動
作毎の消費電力情報から検索し、MMUに関しては命令
フェッチおよび一部の命令に関してはデータの書き込み
/読み出しのアクセスのアドレスに対するMMU動作を
シミュレートするとともに、実行されたMMU動作に対
応する消費電力の値をMMU動作毎の消費電力情報から
検索する。Then, while simulating the instruction operation for the program code given during the execution of the simulation, the value of the power consumption corresponding to the executed instruction is searched from the power consumption for each instruction. With respect to the cache, the cache operation of fetching an instruction to be executed and, for some instructions, writing or reading data is simulated, and the value of power consumption corresponding to the executed cache operation is cached. The power consumption information is searched from each power consumption information, and for the MMU, the MMU operation for the address of the instruction fetch and the data write / read access for some instructions is simulated, and the power consumption corresponding to the executed MMU operation is simulated. A value is retrieved from the power consumption information for each MMU operation.
【0017】これらの消費電力の値を一定時間ごとに集
計してゆくことで、与えられたプログラムコードで動作
するときに、CPU部とキャッシュ部とMMU部が消費
する電力の時間的遷移を求める。By summing up these power consumption values at regular intervals, a time transition of the power consumed by the CPU unit, the cache unit, and the MMU unit when operating with the given program code is obtained. .
【0018】以上のようにして、本発明によれば、キャ
ッシュメモリおよびMMUを備えたプロセッサにおい
て、プログラムコード実行時の消費電力を比較的高速に
求めることが可能になる。As described above, according to the present invention, in a processor including a cache memory and an MMU, it is possible to obtain the power consumption during execution of a program code at a relatively high speed.
【0019】本願第2の発明の半導体集積回路の消費電
力シミュレーション方法は、上記第1の発明において、
前記のMMU動作毎の消費電力情報が、少なくとも、M
MUが内蔵するTLB(アドレス変換バッファ)がヒッ
トした場合の動作とミスした場合の動作とを区別した消
費電力情報であり、与えられたプログラムコードに対す
るシミュレーション実行時に、各々の命令に対して、前
記CPU部から出力される論理アドレスに対して前記T
LBがヒットした場合には前記TLBがヒットした場合
のMMU動作に対する消費電力情報に基づいて前記MM
U部の消費電力を求め、前記TLBがミスした場合には
前記TLBがミスした場合の消費電力情報に基づいて前
記MMU部の消費電力を求めることを特徴とする。した
がって、キャッシュメモリ及びMMUを備えたプロセッ
サの消費電力の見積もりを実現することができる。According to a second aspect of the present invention, there is provided a power consumption simulation method for a semiconductor integrated circuit according to the first aspect, wherein
The power consumption information for each MMU operation is at least M
This is power consumption information that distinguishes between an operation performed when a hit occurs in a TLB (address translation buffer) incorporated in the MU and an operation performed when a miss occurs. For the logical address output from the CPU unit, the T
When the LB hits, the MM based on the power consumption information for the MMU operation when the TLB hits
The power consumption of the U unit is obtained, and when the TLB misses, the power consumption of the MMU unit is obtained based on power consumption information when the TLB misses. Therefore, the power consumption of the processor including the cache memory and the MMU can be estimated.
【0020】本願第3の発明の半導体集積回路の消費電
力シミュレーション方法は、上記第1・第2の発明にお
いて、前記のキャッシュ動作毎の消費電力情報が、少な
くともライトバックモード用とライトスルーモード用の
それぞれに備えられており、与えられたプログラムコー
ドに対するシミュレーション実行時に、各々の命令実行
時にCPU部から出力された論理アドレスをMMUにお
いてアドレス変換した結果、キャッシュをライトバック
モードで使用するアドレスであった場合には、前記のラ
イトバックモード用のキャッシュ動作毎の消費電力情報
に基づいてキャッシュ部の消費電力を求め、出力された
論理アドレスをMMUにおいてアドレス変換した結果、
キャッシュをライトスルーモードで使用するアドレスで
あった場合には、前記のライトスルーモード用のキャッ
シュ動作毎の消費電力情報に基づいてキャッシュ部の消
費電力を求めることを特徴とする。したがって、キャッ
シュメモリ及びMMUを備え、ライトバックモードとラ
イトスルーモードを持つプロセッサの消費電力の正確な
見積もりを実現することができる。According to a third aspect of the present invention, there is provided the power consumption simulation method for a semiconductor integrated circuit according to the first and second aspects, wherein the power consumption information for each cache operation is at least for a write-back mode and a write-through mode. When a simulation is performed for a given program code, the logical address output from the CPU unit at the time of execution of each instruction is converted by the MMU into an address. As a result, the address is used to use the cache in the write-back mode. In this case, the power consumption of the cache unit is obtained based on the power consumption information for each cache operation for the write-back mode, and the output logical address is converted by the MMU into an address.
When the address is used for the cache in the write-through mode, the power consumption of the cache unit is obtained based on the power consumption information for each cache operation for the write-through mode. Therefore, it is possible to accurately estimate the power consumption of the processor including the cache memory and the MMU and having the write-back mode and the write-through mode.
【0021】本願第4の発明の半導体集積回路の消費電
力シミュレーション方法は、上記第1〜第3の発明にお
いて、前記のキャッシュ動作毎の消費電力情報が、少な
くともキャッシュのダーティデータの書き出し動作を区
別して備えており、与えられたプログラムコードに対す
るシミュレーション実行時に、キャッシュの読み出しミ
スや、ダーティデータの書き出し処理命令、MMUの参
照するページ表がそれまでと異なるページ表に変更され
るなど、キャッシュ内のダーティデータを書き出す動作
が生じた場合には、前記のダーティデータ書き出し動作
についての消費電力情報からキャッシュ部の消費電力を
求めることを特徴とする。したがって、キャッシュメモ
リ及びMMUを備え、ダーティデータの書き出しが生じ
るプログラムにおいても、プロセッサの消費電力の正確
な見積もりを実現することができる。According to a fourth aspect of the present invention, there is provided a power consumption simulation method for a semiconductor integrated circuit according to the first to third aspects, wherein the power consumption information for each cache operation includes at least a write operation of dirty data of the cache. When a simulation is performed on a given program code, a cache read error, a dirty data write processing instruction, and a page table referred to by the MMU are changed to a page table different from the previous one. When an operation of writing dirty data occurs, the power consumption of the cache unit is obtained from the power consumption information on the dirty data writing operation. Therefore, even in a program including a cache memory and an MMU and in which dirty data is written out, accurate estimation of the power consumption of the processor can be realized.
【0022】本願第5の発明の半導体集積回路の消費電
力シミュレーション方法は、上記第1〜第4の発明にお
いて、シミュレーション実行中には、消費電力計算に必
要な情報を記憶装置に保存しておき、シミュレーション
実行後に、前記の記憶装置に保存しておいた消費電力計
算に必要な情報を基に、当該シミュレーションで求めた
回路動作時の回路の消費電力を求めることを特徴とす
る。According to a fifth aspect of the present invention, there is provided a power consumption simulation method for a semiconductor integrated circuit according to the first to fourth aspects, wherein information necessary for power consumption calculation is stored in a storage device during execution of the simulation. After the simulation is executed, the power consumption of the circuit at the time of the circuit operation obtained by the simulation is obtained based on information necessary for the power consumption calculation stored in the storage device.
【0023】(具体的な実施の形態)以下、本発明にか
かわる半導体集積回路の消費電力シミュレーション方法
の具体的な実施の形態を図面に基づいて説明する。(Specific Embodiment) Hereinafter, a specific embodiment of a method for simulating power consumption of a semiconductor integrated circuit according to the present invention will be described with reference to the drawings.
【0024】図1は本発明の実施の形態にかかわる半導
体集積回路の消費電力シミュレーション方法のシミュレ
ーション実行時の処理の流れを示すフローチャートであ
る。101はシミュレーション対象となる回路内の各部
の初期化を行う初期化処理である。ここでは、プロセッ
サモデルのCPU部やキャッシュ部およびMMU部の各
種レジスタ等が設定される。102はシミュレートする
プロセッサモデルに与えるプログラムコードを読み込
み、シミュレーションを開始する命令の位置と、シミュ
レーションを終了する命令の位置を設定するプログラム
コード読み込み処理である。103は与えられたプログ
ラムコードから、現在の実行サイクルにおいて実行する
命令を読み込む命令読み込み処理である。命令はCPU
部が命令が格納されている論理アドレスを出力し、キャ
ッシュメモリを介して読み込まれ、キャッシュ外部から
命令を読み込むためにMMU部が論理アドレスを物理ア
ドレスに変換するので、キャッシュ部の動作のシミュレ
ーションとMMU部の動作のシミュレーションが行われ
る。104は命令読み込み処理103でシミュレートさ
れたMMU部の動作に従って、MMU部動作毎の消費電
力情報からMMU部で消費される電力を求めるMMU部
消費電力計算処理である。105は命令読み込み処理1
03でシミュレーションされたキャッシュ部の動作に従
ってキャッシュ動作毎の消費電力情報からキャッシュ部
で消費される消費電力を求めるキャッシュ部消費電力計
算処理である。106は命令読み込み処理103で読み
込まれた命令のプロセッサ動作をシミュレートする命令
実行処理である。107は命令ごとの消費電力情報より
命令実行処理106でシミュレートされた命令に対応す
る消費電力を求めるCPU部消費電力計算処理である。FIG. 1 is a flowchart showing the flow of processing when a simulation is performed in a method for simulating power consumption of a semiconductor integrated circuit according to an embodiment of the present invention. Reference numeral 101 denotes an initialization process for initializing each unit in a circuit to be simulated. Here, the CPU unit of the processor model, the cache unit, and various registers of the MMU unit are set. Reference numeral 102 denotes a program code reading process for reading the program code given to the processor model to be simulated, and setting the position of the instruction to start the simulation and the position of the instruction to end the simulation. An instruction reading process 103 reads an instruction to be executed in the current execution cycle from a given program code. Instruction is CPU
The unit outputs a logical address where the instruction is stored, is read via the cache memory, and the MMU unit converts the logical address into a physical address to read the instruction from outside the cache. A simulation of the operation of the MMU unit is performed. Reference numeral 104 denotes an MMU unit power consumption calculation process for obtaining power consumed by the MMU unit from power consumption information for each operation of the MMU unit in accordance with the operation of the MMU unit simulated in the instruction reading process 103. 105 is an instruction reading process 1
This is a cache unit power consumption calculation process for calculating the power consumption of the cache unit from the power consumption information for each cache operation according to the operation of the cache unit simulated in 03. An instruction execution process 106 simulates a processor operation of the instruction read in the instruction reading process 103. Reference numeral 107 denotes CPU unit power consumption calculation processing for obtaining power consumption corresponding to the instruction simulated in the instruction execution processing 106 from the power consumption information for each instruction.
【0025】108は命令実行処理106においてシミ
ュレートされた命令でデータアクセスが発生した場合、
シミュレーションされたMMU部の動作に従ってMMU
動作毎の消費電力情報からMMU部で消費される消費電
力を求めるMMU部消費電力計算処理である。109は
命令実行処理106においてシミュレートされた命令で
データアクセスが発生した場合、シミュレーションされ
たキャッシュ部の動作に従ってキャッシュ動作毎の消費
電力情報からキャッシュ部で消費される消費電力を求め
るキャッシュ部消費電力計算処理である。Reference numeral 108 denotes a case where a data access occurs by an instruction simulated in the instruction execution processing 106.
MMU according to the operation of the simulated MMU unit
This is an MMU unit power consumption calculation process for calculating the power consumption consumed by the MMU unit from the power consumption information for each operation. Reference numeral 109 denotes a cache unit power consumption for calculating the power consumption of the cache unit from the power consumption information for each cache operation according to the simulated operation of the cache unit when data access occurs by the instruction simulated in the instruction execution processing 106. This is a calculation process.
【0026】110はプログラムコード読み込み処理1
02において設定されている終了命令位置によりシミュ
レートすべきプログラムコードが終了しているかどうか
を判断するプログラムコード終了判断処理である。11
2はプログラムコード終了判断処理110でプログラム
コードのシミュレーションが終了していないと判断され
たときに、シミュレーションを行う実行サイクルを1だ
け進める実行サイクル更新処理であり、実行サイクルの
更新後に命令読み込み処理103に戻り、次の実行サイ
クルの処理を継続する。111はプログラムコード終了
判断処理110によりシミュレートすべきプログラムコ
ードが終了しているときに、これまでの消費電力計算処
理で計算した消費電力情報を出力する消費電力出力処理
である。Reference numeral 110 denotes a program code reading process 1
This is a program code end determination process for determining whether or not the program code to be simulated has ended based on the end instruction position set in 02. 11
2 is an execution cycle update process for advancing the execution cycle for performing the simulation by one when it is determined in the program code end determination process 110 that the simulation of the program code is not completed. And the processing of the next execution cycle is continued. Reference numeral 111 denotes a power consumption output process for outputting the power consumption information calculated in the power consumption calculation process up to now when the program code to be simulated by the program code end determination process 110 has been completed.
【0027】図2はシミュレートされるプロセッサの命
令セットの一例である。201は命令セットの一覧を示
した命令テーブルである。LDRは、アドレスにより指
定されるメモリ領域のデータからレジスタにデータを転
送するデータロード命令である。STRは、レジスタか
らアドレスにより指定されるメモリ領域にデータを転送
するデータストア命令である。CMPは、ソースで指定
されるレジスタの値、または定数値とディスティネーシ
ョン(データ送り先)で指定されるレジスタの値とを比
較し、等しければ比較結果フラグをリセットし、等しく
なければ比較結果フラグをセットする比較命令である。
ADDは、ソースで指定されるレジスタの値とディステ
ィネーションで指定されるレジスタの値とを加算し、結
果をディスティネーションで指定されるレジスタに代入
する加算命令である。SUBは、ソースで指定されるレ
ジスタの値からディスティネーションで指定されるレジ
スタの値を減算し、結果をディスティネーションで指定
されるレジスタに代入する減算命令である。BNQは、
比較結果フラグがセットされていればラベルで指定され
た命令位置に処理をジャンプさせる条件分岐命令であ
る。NOPは、何の計算も行わず命令サイクルを1進め
る命令である。MCRは、ディスティネーションで示さ
れたMMU部内蔵レジスタに、ソースで示されたレジス
タの値を格納するMMU部制御命令である。ここでMM
U部内蔵レジスタの値はMMUが使用するテーブル表が
置かれているアドレスの基準となるアドレスである。FIG. 2 is an example of a simulated processor instruction set. 201 is an instruction table showing a list of instruction sets. LDR is a data load instruction for transferring data from data in a memory area specified by an address to a register. STR is a data store instruction for transferring data from a register to a memory area specified by an address. CMP compares the value of a register specified by the source or a constant value with the value of the register specified by the destination (data destination), resets the comparison result flag if they are equal, and resets the comparison result flag if they are not equal. This is a comparison instruction to be set.
ADD is an addition instruction for adding the value of the register specified by the source and the value of the register specified by the destination, and assigning the result to the register specified by the destination. SUB is a subtraction instruction for subtracting the value of the register specified by the destination from the value of the register specified by the source, and assigning the result to the register specified by the destination. BNQ is
If the comparison result flag is set, this is a conditional branch instruction that causes the processing to jump to the instruction position specified by the label. The NOP is an instruction that advances the instruction cycle by one without performing any calculation. The MCR is an MMU unit control instruction that stores the value of the register indicated by the source in the register incorporated in the MMU indicated by the destination. Where MM
The value of the U-unit built-in register is an address serving as a reference of the address where the table used by the MMU is placed.
【0028】図3はシミュレーション対象となるプロセ
ッサの命令毎の消費電力情報を示す。301は命令毎の
消費電力表であり、命令テーブル201で定義されてい
る命令毎に、その命令が一度実行されるときの消費電力
値が格納されている。FIG. 3 shows power consumption information for each instruction of a processor to be simulated. Reference numeral 301 denotes a power consumption table for each instruction, which stores a power consumption value when the instruction is executed once for each instruction defined in the instruction table 201.
【0029】図4はMMU動作毎の消費電力情報の一例
である。401はMMU動作毎の消費電力表であり、4
02にMMU動作としてTLBがヒットした場合として
TLB Hitと、TLBがミスした場合としてTLB
Missが定義され、予めMMU動作がヒットした場合
とミスした場合について消費電力を回路シミュレーター
等で求め、このMMU動作毎の消費電力表401に格納
しておく。ここではTLB Hit時に5[μW/MHz]、ミ
ス時に40[μW/MHz]の値が格納されている。FIG. 4 shows an example of power consumption information for each MMU operation. Reference numeral 401 denotes a power consumption table for each MMU operation.
02, TLB Hit as the case where the TLB hits as the MMU operation, and TLB as the case where the TLB misses
Miss is defined, and power consumption is determined in advance by a circuit simulator or the like when the MMU operation hits and misses, and stored in the power consumption table 401 for each MMU operation. Here, a value of 5 [μW / MHz] is stored at the time of TLB Hit, and a value of 40 [μW / MHz] is stored at the time of a mistake.
【0030】図5はキャッシュ動作毎の消費電力情報の
一例である。501はキャッシュ動作毎の消費電力表で
あり、502にキャッシュ動作として読み込み動作の際
のキャッシュヒットとして「Read Hit」と、読
み込み動作の際のキャッシュミスとして「Read M
iss」と、書き込み動作の際の「Write Hi
t」と、書き込み動作の際の「Write Miss」
が定義され、さらに、ダーティデータとして区別された
データをメモリ領域に書き出す動作の際の動作として
「Clean」が定義され、これらの消費電力情報はキ
ャッシュ動作がライトスルーモードで動作している場合
と、ライトバックモードで動作している場合のそれぞれ
で定義されている。これらの動作毎に、予めキャッシュ
動作が生じた場合について回路シミュレーター等で求
め、このキャッシュ動作毎の消費電力表501に格納し
ておく。FIG. 5 shows an example of power consumption information for each cache operation. Reference numeral 501 denotes a power consumption table for each cache operation. Reference numeral 502 denotes “Read Hit” as a cache hit during a read operation as a cache operation, and “Read M” as a cache miss during a read operation.
iss ”and“ Write Hi ”during the write operation.
t "and" Write Miss "during the write operation.
Is defined, and “Clean” is defined as an operation at the time of writing data classified as dirty data to the memory area, and the power consumption information is obtained when the cache operation operates in the write-through mode. , Respectively, when operating in the write-back mode. For each of these operations, a case where a cache operation occurs is obtained in advance by a circuit simulator or the like, and stored in the power consumption table 501 for each cache operation.
【0031】ここではライトスルーモード時の消費電力
として、Read Hit時に20[μW/MHz]、Read
Miss時に100[μW/MHz]、Write Hit時
に80[μW/MHz]、Write Miss時に40[μW/M
Hz]がそれぞれ格納され、ライトバックモード時の消費
電力として、Read Hit時に20[μW/MHz]、Re
ad Miss時に100[μW/MHz]、Write Hi
t時に70[μW/MHz]、Write Miss時に35
[μW/MHz]の値が格納され、Clean時には書き出す
データ1ワード当たりの消費電力として10[μW/MHz]
が格納されている。Here, the power consumption in the write-through mode is 20 [μW / MHz] at the time of Read Hit,
100 [μW / MHz] at Miss, 80 [μW / MHz] at Write Hit, 40 [μW / M] at Write Miss
Hz] are stored, and as power consumption in the write-back mode, 20 [μW / MHz] and Re
100 [μW / MHz] at the time of ad Miss, Write Hi
70 [μW / MHz] at t, 35 at Write Miss
The value of [μW / MHz] is stored, and at the time of Clean, the power consumption per word of data to be written is 10 [μW / MHz].
Is stored.
【0032】図6は初期化処理101において、メモリ
領域に格納されるメモリの内容の一例である。601は
それぞれの物理アドレスとそこに格納されているデータ
の表であり、[50]には“8”、[80]には“200”が格
納されていることを示している。FIG. 6 shows an example of the contents of the memory stored in the memory area in the initialization processing 101. Numeral 601 is a table of each physical address and data stored therein, and indicates that [8] is stored in [50] and “200” is stored in [80].
【0033】図7は初期化処理101において、メモリ
領域に格納されるデータの内容のうち、ページ表1とし
て格納されるデータの内容の一例である。初期化処理時
のメモリの内容601によれば、ページ表1は[300]を
テーブル表が置かれているアドレスの基準としてもつペ
ージ表であり、ページ表1の内容701はその内容であ
る。ページ表1の内容701は、論理アドレスの値と、
その変換された後の物理アドレスと、そのアドレスのメ
モリ領域のキャッシュモードが示されている。ページ表
の一部702は論理アドレス[0]から[49]に対するペー
ジ表であり、アドレス[300]に格納されている。ページ
表の一部703は論理アドレス[50]から[99]に対するペ
ージ表であり、アドレス[301]に格納されている。MM
U部はページ表1の基準として命令セット201で示さ
れた命令MCRで論理アドレス[0]に対するページ表の
一部が格納されているアドレスをMMU部の制御レジス
タに格納しており、論理アドレスの大きさに従ってMM
U部の内部制御レジスタの値を基準にページ表1にアク
セスを行う。ページ表1の一部706において物理アド
レスが禁止になっているのは、これらの論理アドレス[2
00]から[249]がアクセス禁止領域になることを示してい
る。FIG. 7 shows an example of the contents of the data stored as the page table 1 in the contents of the data stored in the memory area in the initialization processing 101. According to the contents 601 of the memory at the time of the initialization processing, the page table 1 is a page table having [300] as a reference of the address where the table table is placed, and the contents 701 of the page table 1 are the contents. The content 701 of the page table 1 includes a logical address value,
The physical address after the conversion and the cache mode of the memory area of the address are shown. Part 702 of the page table is a page table for logical addresses [0] to [49], and is stored at address [300]. Part 703 of the page table is a page table for logical addresses [50] to [99], and is stored at address [301]. MM
The U section stores, in the control register of the MMU section, the address where a part of the page table corresponding to the logical address [0] is stored in the control register of the MMU in the instruction MCR indicated by the instruction set 201 as a reference of the page table 1. MM according to the size of
The page table 1 is accessed based on the value of the internal control register of the U section. The physical addresses are prohibited in the part 706 of the page table 1 because these logical addresses [2
00] to [249] indicate that the access is prohibited.
【0034】図8は初期化処理101において、メモリ
領域に格納されるデータの内容のうち、ページ表2とし
て格納されるデータの内容の一例である。初期化処理時
のメモリの内容601によれば、ページ表2は[400]を
テーブル表が置かれているアドレスの基準としてもつペ
ージ表であり、ページ表2の内容801はその内容であ
る。ページ表2の内容801は、論理アドレスの値と、
その変換された後の物理アドレスと、そのアドレスのメ
モリ領域のキャッシュモードが示されている。ページ表
2の一部802は論理アドレス[0]から[49]に対するペ
ージ表であり、アドレス[400]に格納されている。ペー
ジ表2の一部803は論理アドレス[50]から[99]に対す
るページ表であり、アドレス[401]に格納されている。
MMU部はページ表2の基準として命令セット201で
示された命令MCRで論理アドレス[0]に対するページ
表の一部が格納されているアドレスをMMU部の制御レ
ジスタに格納しており、論理アドレスの大きさに従って
MMU部の内部制御レジスタの値を基準にページ表2に
アクセスを行う。ページ表2の一部806において物理
アドレスが禁止になっているのは、これらの論理アドレ
ス[200]から[249]がアクセス禁止領域になることを示し
ている。FIG. 8 shows an example of the contents of the data stored as the page table 2 among the contents of the data stored in the memory area in the initialization processing 101. According to the contents 601 of the memory at the time of the initialization processing, the page table 2 is a page table having [400] as a reference of the address where the table table is placed, and the contents 801 of the page table 2 are the contents. The content 801 of the page table 2 includes a logical address value,
The physical address after the conversion and the cache mode of the memory area of the address are shown. Part 802 of page table 2 is a page table for logical addresses [0] to [49], and is stored at address [400]. Part 803 of page table 2 is a page table for logical addresses [50] to [99], and is stored at address [401].
The MMU unit stores, in the control register of the MMU unit, an address at which a part of the page table corresponding to the logical address [0] is stored in the instruction MCR indicated by the instruction set 201 as a basis of the page table 2 in the control register of the MMU unit. The page table 2 is accessed based on the value of the internal control register of the MMU unit in accordance with the size of. The prohibition of the physical address in the part 806 of the page table 2 indicates that these logical addresses [200] to [249] are access-prohibited areas.
【0035】図9はシミュレーションの対象となるプロ
セッサで実行するプログラムの一例である。901はプ
ログラム全体であり、各1行が1命令を表しており、各
行は左の列より、ラベル、命令、ディスティネーション
(データ送り先)、ソースを示す。902はプログラム
の各行が格納されているアドレスを示している。格納ア
ドレス[0]の命令903すなわちLDRのソースの[80]
は論理アドレス空間上のアドレス80を示す。904か
ら921に至る他の命令についても同様に各行が1命令
を示す。FIG. 9 shows an example of a program executed by a processor to be simulated. Reference numeral 901 denotes the entire program, each row representing one instruction, and each row indicates a label, an instruction, a destination (data destination), and a source from the left column. Reference numeral 902 denotes an address where each line of the program is stored. The instruction 903 at the storage address [0], ie, the source [80] of the LDR
Indicates an address 80 in the logical address space. Similarly, for other instructions from 904 to 921, each row indicates one instruction.
【0036】図12は、本実施の形態にかかわるシミュ
レーション処理を実行する計算機のハードウェア構成の
一例である。1201は処理されたあらゆる情報を表示
するためのディスプレイ装置、1202は設計者があら
ゆる情報や処理命令を入力するためのキーボード、12
03はあらゆる処理を行う中央演算処理装置、1204
は各種情報を格納する記憶装置である。FIG. 12 is an example of a hardware configuration of a computer that executes a simulation process according to the present embodiment. Reference numeral 1201 denotes a display device for displaying all processed information; 1202, a keyboard for a designer to input all information and processing instructions;
03 is a central processing unit that performs all kinds of processing, 1204
Is a storage device for storing various information.
【0037】図13は、本実施の形態にかかわるシミュ
レーションにおけるプロセッサモデルの概念図の一例で
あり、モデルはCPU部1301とMMU部1302と
キャッシュ部1303によって構成され、さらにプロセ
ッサモデルがなんらかのバスモデルと接続するバスイン
ターフェース部1304が加わり、これらの各部の動作
がシミュレーションされる。FIG. 13 is an example of a conceptual diagram of a processor model in a simulation according to the present embodiment. The model includes a CPU unit 1301, an MMU unit 1302, and a cache unit 1303. A bus interface unit 1304 to be connected is added, and the operation of each of these units is simulated.
【0038】以下、本実施の形態にかかわる半導体集積
回路の消費電力シミュレーション方法を図1のフローチ
ャートに基づき、プログラム901を実行した場合を一
例に用いて具体的に説明する。Hereinafter, a method for simulating power consumption of a semiconductor integrated circuit according to the present embodiment will be described in detail with reference to the flowchart of FIG.
【0039】初期化処理101ではプログラムの実行を
行うための初期化を行う。ここでは図13に示すプロセ
ッサモデルのCPU部1301やMMU部1302、キ
ャッシュ部1303の各種レジスタ等が設定される。メ
モリの内容は、表601に従って設定されているとす
る。In an initialization process 101, initialization for executing a program is performed. Here, various registers of the CPU unit 1301, the MMU unit 1302, and the cache unit 1303 of the processor model shown in FIG. 13 are set. It is assumed that the contents of the memory are set according to Table 601.
【0040】プログラムコード読み込み処理102では
プログラムコード901が記憶装置1204に読み込ま
れ、命令903からプログラムの実行を開始するように
プログラムカウンタレジスタが設定される。また、命令
921に達した場合にプログラムの実行を終了するよう
に設定される。また、MMU部1302のアドレス変換
に使用されるページ表の基準になるアドレスとして[30
0]が与えられる。In the program code reading process 102, the program code 901 is read into the storage device 1204, and the program counter register is set so that the execution of the program is started from the instruction 903. Further, it is set so that the execution of the program is terminated when the instruction 921 is reached. Also, [30] is used as a reference of a page table used for address conversion of the MMU unit 1302.
0] is given.
【0041】命令読み込み処理103ではプログラムカ
ウンタが指す命令を読み込む。この場合、プログラムカ
ウンタで指されたアドレス[0]はMMU部1302にお
いてはページ表1の基準になるアドレスが[300]であ
り、ページ表702が使用されるが、ページ表702の
使用は初回であるのでTLBはTLB Missにな
る。論理アドレス[0]は物理アドレス[0]に変換され、命
令読み込み先のアドレスとして使用され、キャッシュ部
1303を介して命令903の読み込みを行うが、キャ
ッシュにはこのアドレス[0]へのアクセスは初回なので
キャッシュはRead Missになる。そして、MM
U部消費電力計算処理104においてMMU動作毎の消
費電力表401よりTLB Missした場合の40[μ
W/MHz]が求められ、キャッシュ部消費電力計算処理10
5において、キャッシュ動作毎の消費電力表501より
Read Missした場合の100[μW/MHz]が求めら
れる(ライトバックモード)。In the instruction reading process 103, the instruction indicated by the program counter is read. In this case, the address [0] indicated by the program counter is the address used as the reference for page table 1 in the MMU unit 1302 is [300], and the page table 702 is used. Therefore, TLB becomes TLB Miss. The logical address [0] is converted to a physical address [0], is used as an instruction read destination address, and reads the instruction 903 via the cache unit 1303. The cache has access to this address [0]. Since it is the first time, the cache becomes Read Miss. And MM
40 [μ] when TLB Miss is obtained from the power consumption table 401 for each MMU operation in the U unit power consumption calculation processing 104
W / MHz] is calculated, and the cache unit power consumption calculation processing 10
In step 5, 100 [μW / MHz] in the case of Read Miss is obtained from the power consumption table 501 for each cache operation (write back mode).
【0042】ここで消費電力の計算は消費電力表40
1,501から該当のMMU部動作およびキャッシュ動
作の消費電力値を引くだけの簡単な処理であり、容易に
高速に計算される。Here, the calculation of the power consumption is performed in the power consumption table 40.
This is a simple process of subtracting the power consumption value of the corresponding MMU unit operation and cache operation from 1,501, and is easily calculated at high speed.
【0043】次に命令実行処理106によりLDR命令
903の動作がシミュレートされ、論理アドレス[80]は
ページ表703によって物理アドレス[80]に変換され、
このとき、このページ表の使用は初回であるのでTLB
Missとなり、キャッシュ部1303を介してアド
レス[80]にアクセスされるが、このアドレスはキャッシ
ュのリフィル動作によってもキャッシュ内に用意されて
いないアドレスであるので、キャッシュミスとなる。こ
うしてアドレス[80]の値300がレジスタr5に読み込
まれる。Next, the operation of the LDR instruction 903 is simulated by the instruction execution processing 106, and the logical address [80] is converted into the physical address [80] by the page table 703.
At this time, since this page table is used for the first time, TLB
The address becomes [Miss], and the address [80] is accessed via the cache unit 1303. However, since this address is not prepared in the cache even by the cache refill operation, a cache miss occurs. Thus, the value 300 of the address [80] is read into the register r5.
【0044】次に、CPU部消費電力計算処理107に
おいて、命令毎の消費電力表301よりLDR命令に相
当する15[μW/MHz]が求められる。Next, in the CPU unit power consumption calculation processing 107, 15 [μW / MHz] corresponding to the LDR instruction is obtained from the power consumption table 301 for each instruction.
【0045】次に、MMU部消費電力計算処理108に
おいて、MMU動作毎の消費電力表401よりTLB
Missに相当する40[μW/MHz]が求められ、キャッ
シュ部消費電力計算処理109において、キャッシュ動
作毎の消費電力表501よりRead Missした場
合の100[μW/MHz]が求められる。Next, in the MMU unit power consumption calculation processing 108, the TLB is obtained from the power consumption table 401 for each MMU operation.
40 [μW / MHz] corresponding to Miss is obtained, and 100 [μW / MHz] in the case of Read Missing is obtained from the power consumption table 501 for each cache operation in the cache unit power consumption calculation processing 109.
【0046】次に、プログラムコード終了判定処理11
0によりシミュレーション終了条件のコードに達してい
るかが判断され、この場合達していないので、実行サイ
クル更新処理112でサイクル数が2に設定され、プロ
グラムカウンタレジスタも1進められ、次の命令コード
904が命令読み込み処理103で読み込まれる。Next, program code end determination processing 11
It is determined by 0 whether or not the code of the simulation end condition has been reached. In this case, the code has not been reached. Therefore, the cycle number is set to 2 in the execution cycle update processing 112, the program counter register is advanced by 1, and the next instruction code 904 is set. It is read in the instruction reading process 103.
【0047】以下、命令読み込み処理103から実行サ
イクル更新処理112までが終了条件のコードに達する
まで繰り返される。図10および図11にその結果を示
す。Hereinafter, the processing from the instruction reading processing 103 to the execution cycle updating processing 112 is repeated until the end condition code is reached. 10 and 11 show the results.
【0048】図10において、1001はサイクル数、
1002は実行された命令、1003は命令読み込み時
でのMMU部1302の動作、1004は命令読み込み
時のキャッシュ部1303の動作、1005は命令を実
行したときのMMU部1302の動作、1006は命令
を実行したときのキャッシュ部1303の動作の結果で
ある。MMU部動作においてMissはTLB Mis
sであり、HitはTLB Hitである。また、キャ
ッシュ動作においてR Missはキャッシュ読み出し
ミス、R Hitは読み出しヒット、WB Hitはライ
トバックモードでの書き出しヒット、WB Missは
ライトバックモードで書き出しミス、WTHitはライ
トスルーモードでの書き出しヒット、WT Missは
ライトスルーモードでの書き出しミスを表す。Clea
nはダーティデータのメモリ領域への書き出し処理を表
し、括弧内の数字で示されたワード数が書き出される。
ダッシュはキャッシュアクセスの非発生を示す。In FIG. 10, 1001 is the number of cycles,
1002 is the executed instruction, 1003 is the operation of the MMU unit 1302 when reading the instruction, 1004 is the operation of the cache unit 1303 when reading the instruction, 1005 is the operation of the MMU unit 1302 when executing the instruction, and 1006 is the instruction. This is the result of the operation of the cache unit 1303 when executed. In operation of the MMU section, Miss is TLB Miss.
s, and Hit is TLB Hit. In the cache operation, R Miss is a cache read miss, R Hit is a read hit, WB Hit is a write hit in the write-back mode, WB Miss is a write miss in the write-back mode, WT Hit is a write hit in the write-through mode, WT Miss indicates a writing error in the write-through mode. Clea
n represents a process of writing dirty data to the memory area, and the number of words indicated by a number in parentheses is written.
A dash indicates that no cache access has occurred.
【0049】特にライトバックモードを区別した消費電
力の見積もりとして、図9の命令909において、ST
R命令であることから、書き込み処理であるが、この場
合、図7より論理アドレス[100]のページ表は[302]であ
ることから、論理アドレス[100]は物理アドレス[200]に
変換され、ライトバックモードでのキャッシュ動作対象
であることが分かる。ライトバックモードであるので、
図5の消費電力表の504より消費電力が求められ、命
令908において読み出し処理のキャッシュミスが生じ
ているため、このアドレスのデータはキャッシュ内に格
納されており、キャッシュヒットであるので消費電力値
として70[μW/MHz]が求められ、図10の1006に
WB Hit、図11の1106にキャッシュ動作の消
費電力として、7サイクル目に70[μW/MHz]が求めら
れている。In particular, as an estimate of the power consumption distinguishing the write-back mode, in the instruction 909 in FIG.
Since this is an R instruction, it is a write process. In this case, since the page table of the logical address [100] is [302] from FIG. 7, the logical address [100] is converted into the physical address [200]. It can be seen that the cache operation is performed in the write-back mode. Since it is in write-back mode,
The power consumption is obtained from the power consumption table 504 in FIG. 5, and a cache miss in the read processing has occurred in the instruction 908, and the data at this address is stored in the cache. 70 [μW / MHz] is calculated as 1006 in FIG. 10, WB Hit is calculated as 1006 in FIG. 10, and 70 [μW / MHz] is calculated as the power consumption of the cache operation in 1106 in FIG.
【0050】同様に、17サイクル目は命令914に相
当し、MCR命令はMMU部制御命令であり、ページ表
が置かれるアドレスの基準のアドレスを変更する。ここ
でページ表が置かれるアドレスの基準の値として[400]
が格納され、図7に示すページ表1に代わって、図8で
示すページ表2がアドレス変換に使われるようになる。
アドレス変換のテーブルが変わったためTLB内のテー
ブルはすべて無効となり、論理アドレスで格納されてい
るキャッシュのデータの内、図10のサイクル12にお
いてWB Hitとなっているデータについてはライト
バックモードでのライトキャッシュヒットであるのでメ
インメモリとの一致性がなく、また、ページ表が変更に
なると論理アドレスで格納されているキャッシュ内デー
タは無効となるためにメインメモリへの書き出し処理が
生じ、図10のサイクル17においてCleanと示さ
れているダーティデータの書き出しが生じている。Cl
ean(16)の“16”はワード数であり、これはキャッ
シュ内のダーティデータが16ワード単位で管理されて
いるため、16ワードが書き出し処理を受けることを示
しており、図5の表505よりダーティデータの書き出
し処理時の消費電力が求められる。このようにページ表
の変更に伴ってキャッシュのダーティデータの書き出し
が生じる場合の消費電力が求められる。Similarly, the 17th cycle corresponds to the instruction 914, and the MCR instruction is an MMU section control instruction, and changes the reference address of the address where the page table is placed. Here, the reference value of the address where the page table is placed is [400]
Is stored, and the page table 2 shown in FIG. 8 is used for the address conversion instead of the page table 1 shown in FIG.
Since the address translation table has been changed, all the tables in the TLB are invalidated, and among the cache data stored by the logical address, the data that has become WB Hit in cycle 12 in FIG. 10 is written in the write-back mode. Since it is a cache hit, there is no consistency with the main memory, and when the page table is changed, the data in the cache stored at the logical address becomes invalid, and a write process to the main memory occurs. In cycle 17, the writing of dirty data indicated as Clean has occurred. Cl
"16" of "ean (16)" is the number of words. This indicates that since dirty data in the cache is managed in units of 16 words, 16 words are subjected to the writing process. More power consumption during dirty data write processing is required. As described above, power consumption in a case where the dirty data is written out of the cache due to the change of the page table is required.
【0051】特に、ライトスルーモードを区別した消費
電力の見積もりとして、命令914においてページ表が
変更になったことにより、命令917において、命令9
09と同じく論理アドレス[100]への書き込みが生じて
いる場合でも、図8によれば論理アドレス[100]は物理
アドレス[600]に対応し、キャッシュの動作モードがラ
イトスルーモードであるので、図5によれば表503の
消費電力情報よってキャッシュの動作時の消費電力がラ
イトスルーモード時の消費電力の値から求められる。命
令916において読み出し処理のキャッシュミスが生じ
ているため、このアドレスのデータはキャッシュ内に格
納されており、キャッシュヒットであるので消費電力値
として80[μW/MHz]が求められ、図10の1006に
WT Hit、図11の1106にキャッシュ動作の消
費電力として、20サイクル目に80[μW/MHz]が求め
られている。In particular, as an estimate of power consumption in the write-through mode, the page table is changed in the instruction 914, and the
Even if a write to the logical address [100] occurs as in the case of 09, the logical address [100] corresponds to the physical address [600] and the cache operation mode is the write-through mode according to FIG. According to FIG. 5, the power consumption during the operation of the cache is obtained from the value of the power consumption in the write-through mode based on the power consumption information in Table 503. Since a cache miss in the read process has occurred in the instruction 916, the data at this address is stored in the cache, and since it is a cache hit, a power consumption value of 80 [μW / MHz] is obtained. WT Hit, and 80 [μW / MHz] in the 20th cycle as the power consumption of the cache operation in 1106 in FIG.
【0052】図11は図10で示されたMMU部動作に
対してMMU動作毎の消費電力表401を適用し、キャ
ッシュ部動作に対してキャッシュ動作毎の消費電力表5
01を適用し、CPU部動作に対して命令毎の消費電力
表301を適用し、それぞれの消費電力情報から求めた
消費電力を示す。1101はサイクル数、1102は実
行された命令、1103は命令読み込み時でのMMU部
の動作に対してMMU動作毎の消費電力表401の消費
電力情報から求めた消費電力、1104は命令読み込み
時でのキャッシュ部の動作に対してキャッシュ動作毎の
消費電力表501の消費電力情報から求めた消費電力、
1105は命令実行時にデータアクセスが発生した場合
のMMU部の動作に対してMMU動作毎の消費電力表4
01の消費電力情報から求めた消費電力、1106は命
令実行時にデータアクセスが発生した場合のキャッシュ
部の動作に対してキャッシュ動作毎の消費電力表501
の消費電力情報から求めた消費電力、1107は命令実
行時の各命令に対して命令毎の消費電力表301から求
めた消費電力を示し、1108は1102、1103、
1104、1105、1106から求めたサイクルごと
のプロセッサ全体での消費電力である。FIG. 11 shows a case where the power consumption table 401 for each MMU operation is applied to the operation of the MMU shown in FIG.
01, the power consumption table 301 for each instruction is applied to the operation of the CPU unit, and the power consumption obtained from the respective power consumption information is shown. 1101 is the number of cycles, 1102 is the executed instruction, 1103 is the power consumption obtained from the power consumption information of the power consumption table 401 for each MMU operation for the operation of the MMU unit at the time of reading the instruction, and 1104 is the time of reading the instruction. Power consumption obtained from the power consumption information of the power consumption table 501 for each cache operation for the operation of the cache unit of
Reference numeral 1105 denotes a power consumption table 4 for each MMU operation with respect to the operation of the MMU unit when data access occurs at the time of instruction execution.
Power consumption obtained from the power consumption information of No. 01 and 1106 are power consumption tables 501 for each cache operation with respect to the operation of the cache unit when data access occurs during instruction execution.
1107 indicates the power consumption obtained from the power consumption table 301 for each instruction at the time of executing the instruction, 1108 indicates 1102, 1103,
This is the power consumption of the entire processor per cycle obtained from 1104, 1105, and 1106.
【0053】シミュレーション終了条件に達すると、消
費電力出力処理111により、消費電力のシミュレーシ
ョン結果をディスプレー装置1201に出力するか、記
憶装置1204に出力する。When the simulation end condition is reached, the power consumption output processing 111 outputs a simulation result of the power consumption to the display device 1201 or the storage device 1204.
【0054】以上のように、本発明にかかわる実施の形
態によれば、請求項1および請求項2、請求項3、請求
項4にかかわる発明である半導体集積回路の消費電力シ
ミュレーション方法によって、MMUを内蔵し、論理ア
ドレスを使用して作られたプログラムコードに対して
も、シミュレーション実行前に、予め求められている命
令およびキャッシュ部およびMMU部の動作状態に対し
て、命令毎の消費電力情報およびキャッシュ部動作およ
びMMU動作ごとの消費電力情報に格納しておき、検索
集計するのみで与えられたプログラムコードに対する消
費電力を高速に求めることができる。As described above, according to the embodiment of the present invention, the MMU is provided by the method for simulating power consumption of a semiconductor integrated circuit according to the first, second, third, and fourth aspects of the present invention. Power consumption information for each instruction with respect to a predetermined instruction and the operating states of the cache unit and the MMU unit before executing the simulation, even for a program code created using a logical address. In addition, the power consumption information is stored in the power consumption information for each of the cache unit operation and the MMU operation, and the power consumption with respect to the given program code can be obtained at high speed only by performing search and aggregation.
【0055】特に、請求項2にかかわる発明では、MM
U部の動作毎の消費電力情報がTLBヒットの場合とT
LBミスの場合とを備えているため、TLBがヒットし
て、TLBアクセスのみでアドレス変換が行われる場合
と、TLBミスして、アドレス変換時にページ表をアク
セスする場合でのMMU動作の消費電力をそれぞれ正確
に見積もることができ、MMUを搭載するプロセッサの
消費電力を求めることができる。In particular, in the invention according to claim 2, the MM
The power consumption information for each operation of the U section is TLB hit and T
Since there is a case of LB miss, the power consumption of the MMU operation in the case where the TLB hits and the address translation is performed only by the TLB access, and in the case where the TLB miss occurs and the page table is accessed at the time of the address translation Can be accurately estimated, and the power consumption of the processor equipped with the MMU can be obtained.
【0056】また、請求項3にかかわる発明では、キャ
ッシュ部の動作毎の消費電力情報がライトバックモード
用とライトスルーモード用を備えているため、MMUに
よってキャッシュモードが切り替えられている場合にお
いて、キャッシュ動作におけるライトバックモードとラ
イトスルーモードでの消費電力をそれぞれ正確に提供す
ることができ、キャッシュ動作としてライトバックモー
ドとライトスルーモードを持つキャッシュメモリを持つ
プロセッサの消費電力を正確に求めることができる。According to the third aspect of the present invention, since the power consumption information for each operation of the cache unit is provided for the write-back mode and the write-through mode, when the cache mode is switched by the MMU, It is possible to accurately provide power consumption in write-back mode and write-through mode in cache operation, and to accurately determine the power consumption of a processor having a cache memory with write-back mode and write-through mode as cache operation. it can.
【0057】請求項4にかかわる発明では、キャッシュ
部の動作毎の消費電力情報がダーティデータの書き出し
項目を備えているため、タスクの切り替えに代表される
処理としてMMUが使用するページ表が切り替えられる
場合のように、ダーティデータの書き出しが発生する場
合のキャッシュ動作の消費電力を正確に見積ることがで
き、キャッシュメモリを搭載するプロセッサにおいて、
ダーティデータの書き出しが生じるプログラムにおいて
も、そのプロセッサにおける消費電力を正確に見積るこ
とができる。According to the fourth aspect of the present invention, since the power consumption information for each operation of the cache unit has a write-out item of dirty data, the page table used by the MMU is switched as a process typified by task switching. As in the case, when the writing of dirty data occurs, the power consumption of the cache operation can be accurately estimated.
Even in a program in which writing of dirty data occurs, the power consumption of the processor can be accurately estimated.
【0058】なお、本実施の形態では消費電力情報とし
て単純な表の形式を用いたが、値の代わりに関数として
定義しても同様の効果が得られることは言うまでもな
い。In the present embodiment, a simple table format is used as the power consumption information. However, it goes without saying that the same effect can be obtained by defining it as a function instead of a value.
【0059】[0059]
【発明の効果】以上に説明したように、本発明によれ
ば、シミュレーション実行前に、プロセッサの命令セッ
トの個々の命令、および、キャッシュの複数の動作、お
よびMMUの動作に対して、回路レベル、ゲートレベル
のシミュレーション、又は実チップの評価結果より消費
電力情報を格納しておき、シミュレーション実行中に与
えられたプログラムコードに対する命令動作およびキャ
ッシュ動作およびMMU動作をシミュレートするととも
に、消費電力情報から消費電力を検索し、与えられたプ
ログラムコードに対する消費電力を求めることができ
る。したがって、本発明によれば、キャッシュメモリお
よびMMUを備えたプロセッサにおいて、プログラムコ
ード実行時の消費電力を高速に求めることができる。As described above, according to the present invention, before the simulation is executed, the individual instructions of the instruction set of the processor, the plurality of operations of the cache, and the operations of the MMU are controlled at the circuit level. , Power consumption information is stored from a simulation result of a gate level or an evaluation result of a real chip, and an instruction operation, a cache operation, and an MMU operation with respect to a program code given during the simulation are simulated, and the power consumption information is stored. The power consumption can be searched to find the power consumption for a given program code. Therefore, according to the present invention, in the processor including the cache memory and the MMU, the power consumption at the time of executing the program code can be obtained at high speed.
【0060】特に、MMU動作をシミュレートすること
により、論理アドレスを使用するシステムにおいて、T
LBがヒットしてTLBアクセスのみでアドレス変換が
行われる場合と、TLBミスしてアドレス変換時にペー
ジ表をアクセスする場合での消費電力をそれぞれ正確に
見積もることができ、MMUを搭載するプロセッサの消
費電力の見積もりを実現することができる。In particular, by simulating the MMU operation, in a system using logical addresses, T
It is possible to accurately estimate the power consumption in the case where the address translation is performed only by the TLB access due to the hit of the LB and in the case where the page table is accessed at the time of the address translation due to the TLB miss. Power estimation can be achieved.
【0061】また、キャッシュ部の動作毎の消費電力情
報がライトバックモード用とライトスルーモード用を備
えているため、MMUによってキャッシュモードが切り
替えられている場合において、キャッシュ動作における
ライトバックモードとライトスルーモードでの消費電力
をそれぞれ正確に検索することができ、MMUを搭載
し、キャッシュ動作としてライトバックモードとライト
スルーモードを持つキャッシュメモリを持つプロセッサ
の消費電力を正確に求めることができる。Since the power consumption information for each operation of the cache unit includes information for the write-back mode and for the write-through mode, when the cache mode is switched by the MMU, the write-back mode and the write operation in the cache operation are performed. The power consumption in the through mode can be accurately searched for, and the power consumption of a processor equipped with an MMU and having a cache memory having a write-back mode and a write-through mode as a cache operation can be accurately obtained.
【0062】また、キャッシュ部の動作毎の消費電力情
報がダーティデータの書き出し項目を備えているため、
タスクの切り替えに代表される処理としてMMUが使用
するページ表が切り替えられる場合のように、ダーティ
データの書き出しが発生する場合のキャッシュ動作の消
費電力を正確に見積ることができ、MMUとキャッシュ
メモリを搭載するプロセッサにおいて、ダーティデータ
の書き出しが生じるプログラムにおいても、そのプロセ
ッサにおける消費電力を正確に見積ることができる。Also, since the power consumption information for each operation of the cache unit has a write item of dirty data,
As in the case where the page table used by the MMU is switched as a process typified by the task switching, the power consumption of the cache operation when the writing of dirty data occurs can be accurately estimated. Even in a program in which writing of dirty data occurs in a processor mounted on the processor, the power consumption of the processor can be accurately estimated.
【図面の簡単な説明】[Brief description of the drawings]
【図1】本発明の実施の形態における半導体集積回路の
消費電力シミュレーション方法でのシミュレーション実
行時の処理の流れを示すフローチャートである。FIG. 1 is a flowchart showing a flow of processing when a simulation is performed in a method for simulating power consumption of a semiconductor integrated circuit according to an embodiment of the present invention.
【図2】本発明の実施の形態におけるシミュレーション
実行時の命令セットの一例である。FIG. 2 is an example of an instruction set at the time of executing a simulation according to the embodiment of the present invention.
【図3】本発明の実施の形態におけるシミュレーション
実行時の命令毎の消費電力情報の一例である。FIG. 3 is an example of power consumption information for each instruction when executing a simulation according to the embodiment of the present invention.
【図4】本発明の実施の形態におけるシミュレーション
実行時のMMU動作毎の消費電力情報の一例である。FIG. 4 is an example of power consumption information for each MMU operation at the time of executing a simulation according to the embodiment of the present invention.
【図5】本発明の実施の形態におけるシミュレーション
実行時のキャッシュ動作毎の消費電力情報の一例であ
る。FIG. 5 is an example of power consumption information for each cache operation when executing a simulation according to the embodiment of the present invention.
【図6】本発明の実施の形態におけるシミュレーション
実行時の初期化処理におけるメモリ領域の内容の一例で
ある。FIG. 6 is an example of the contents of a memory area in initialization processing at the time of executing a simulation according to an embodiment of the present invention.
【図7】本発明の実施の形態におけるアドレス変換のペ
ージ表の一つである。FIG. 7 is one of page tables for address translation in the embodiment of the present invention.
【図8】本発明の実施の形態におけるアドレス変換のペ
ージ表の一つである。FIG. 8 is a page table of an address translation in the embodiment of the present invention.
【図9】本発明の実施の形態におけるシミュレーション
実行時に実行するプログラムの一例である。FIG. 9 is an example of a program executed at the time of executing a simulation according to the embodiment of the present invention.
【図10】本発明の実施の形態におけるシミュレーショ
ン実行時の結果である。FIG. 10 shows a result at the time of executing a simulation in the embodiment of the present invention.
【図11】本発明の実施の形態におけるシミュレーショ
ン実行時の結果に基づく消費電力の計算結果である。FIG. 11 is a calculation result of power consumption based on a result at the time of executing a simulation in the embodiment of the present invention.
【図12】本発明の実施の形態におけるシミュレーショ
ンを行う計算機の構成の一例である。FIG. 12 is an example of a configuration of a computer that performs a simulation according to the embodiment of the present invention.
【図13】本発明の実施の形態におけるシミュレーショ
ンモデルの一例である。FIG. 13 is an example of a simulation model according to the embodiment of the present invention.
101 初期化処理 102 プログラムコード読み込み処理 103 命令読み込み処理 104 命令読み込み時のMMU部の消費電力計算処理 105 命令読み込み時のキャッシュ部の消費電力計算
処理 106 命令実行処理 107 命令実行時のCPU部の消費電力計算処理 108 命令実行時のMMU部の消費電力計算処理 109 命令実行時のキャッシュ部の消費電力計算処理 201 命令セットの一例 301 命令毎の消費電力情報 401 MMU動作毎の消費電力情報の一例 501 キャッシュ動作毎の消費電力情報の一例 901 プロセッサで実行するプログラムの一例Reference Signs List 101 Initialization processing 102 Program code reading processing 103 Instruction reading processing 104 Power consumption calculation processing of the MMU unit at the time of instruction reading 105 Power consumption calculation processing of the cache unit at the time of instruction reading 106 Instruction execution processing 107 Consumption of CPU unit at the time of instruction execution Power calculation processing 108 Power consumption calculation processing of the MMU unit at the time of instruction execution 109 Power consumption calculation processing of the cache unit at the time of instruction execution 201 An example of an instruction set 301 Power consumption information of each instruction 401 Example of power consumption information of each MMU operation 501 Example of power consumption information for each cache operation 901 Example of program executed by processor
Claims (5)
ュおよびMMU(メモリ管理機構)を備えたプロセッサ
の命令動作を計算機中でシミュレートする方法であっ
て、 シミュレーション実行前に予め、 前記プロセッサの命令セットについて各々の命令が実行
されるときに消費される電力を求め、命令毎の消費電力
情報として記憶し、 前記キャッシュの複数動作について各々の動作に消費さ
れる電力を求め、キャッシュ動作毎の消費電力情報とし
て記憶し、 前記MMUの複数の動作について各々の動作に消費され
る電力を求め、MMU動作毎の消費電力情報として記憶
しておき、 与えられたプログラムコードに対するシミュレーション
実行時に、各々の命令に対して、命令動作およびキャッ
シュ動作およびMMU動作をシミュレートするととも
に、 前記命令毎の消費電力情報に基づいて実行中の命令に対
応するCPU部の消費電力を求め、 前記キャッシュ動作毎の消費電力情報に基づいてバスア
クセスにより発生するキャッシュ動作に対応したキャッ
シュ部の消費電力を求め、 前記のMMU動作毎の消費電力情報に基づいてアドレス
変換およびページ表アクセスにより発生するMMU動作
に対応したMMU部の消費電力を求め、 前記のCPU部の消費電力と前記キャッシュ部の消費電
力と前記MMU部の消費電力から前記プログラムコード
実行時における前記プロセッサの消費電力を求めること
を特徴とする半導体集積回路の消費電力シミュレーショ
ン方法。1. A method for simulating, in a computer, an instruction operation of a processor provided with a CPU (Central Processing Unit), a cache, and an MMU (Memory Management Mechanism), the method comprising: The power consumed when each instruction is executed for the set is obtained and stored as power consumption information for each instruction. The power consumed for each operation is obtained for a plurality of operations of the cache, and the power consumption for each cache operation is obtained. The power consumption is stored as power information, the power consumed for each operation of the plurality of operations of the MMU is obtained, and stored as power consumption information for each MMU operation. Simulates the instruction operation, cache operation and MMU operation In addition, a cache corresponding to a cache operation generated by a bus access based on the power consumption information for each cache operation is obtained based on the power consumption information for each instruction. The power consumption of the MMU unit corresponding to the MMU operation generated by the address translation and the page table access is obtained based on the power consumption information for each MMU operation. A power consumption simulation method for a semiconductor integrated circuit, wherein power consumption of the processor during execution of the program code is obtained from power consumption of a cache unit and power consumption of the MMU unit.
なくとも、前記MMUが内蔵するTLB(アドレス変換
バッファ)にヒットした場合の動作とミスした場合の動
作とを区別した消費電力情報であり、 与えられたプログラムコードに対するシミュレーション
実行時に、各々の命令に対して、前記CPU部から出力
される論理アドレスに対して前記TLBがヒットした場
合には前記TLBがヒットした場合の消費電力情報に基
づいて前記MMU部の消費電力を求め、前記TLBがミ
スした場合には前記TLBがミスした場合の消費電力情
報に基づいて前記MMU部の消費電力を求めることを特
徴とする請求項1に記載の半導体集積回路の消費電力シ
ミュレーション方法。2. The power consumption information for each MMU operation is at least power consumption information that distinguishes between an operation when a hit occurs in a TLB (address translation buffer) incorporated in the MMU and an operation when a miss occurs. When a simulation is performed for a given program code, for each instruction, if the TLB hits a logical address output from the CPU unit, based on the power consumption information when the TLB hits, 2. The semiconductor according to claim 1, wherein the power consumption of the MMU unit is obtained, and when the TLB misses, the power consumption of the MMU unit is obtained based on power consumption information when the TLB misses. A power consumption simulation method for an integrated circuit.
は、それぞれライトバックモード用とライトスルーモー
ド用とを備え、 与えられたプログラムコードに対するシミュレーション
実行時に、各々の命令に対して、 前記CPU部から出力される論理アドレスをアドレス変
換した結果がライトバックモードでキャッシュ動作を行
うアドレスであった場合には前記ライトバックモード用
の消費電力情報に基づいてキャッシュ動作毎の消費電力
を求め、 前記アドレス変換した結果がライトスルーモードでキャ
ッシュ動作を行うアドレスであった場合には前記ライト
スルーモード用の消費電力情報に基づいてキャッシュ動
作毎の消費電力を求めることを特徴とする請求項1また
は請求項2に記載の半導体集積回路の消費電力シミュレ
ーション方法。3. The power consumption information for each cache operation includes information for a write-back mode and an information for a write-through mode. If the result of the address conversion of the output logical address is an address for performing a cache operation in the write-back mode, the power consumption for each cache operation is obtained based on the power-consumption information for the write-back mode. 3. The power consumption for each cache operation is determined based on the power consumption information for the write-through mode when the result of the operation is an address for performing a cache operation in the write-through mode. 3. A method for simulating power consumption of a semiconductor integrated circuit according to item 1.
は、キャッシュ書き込み動作の際、前記キャッシュ内に
蓄えられたデータのみ更新され対応するアドレスのメイ
ンメモリ内のデータと不一致を起こしているダーティデ
ータのメインメモリへの書き出し動作を区別した情報で
あり、 与えられたプログラムコードに対するシミュレーション
実行時に、各々の命令に対して前記ダーティデータの書
き出しが発生した場合には、前記キャッシュ動作毎の消
費電力情報中のダーティデータ書き出し動作に対する消
費電力情報に基づいて前記キャッシュ部の消費電力を求
めることを特徴とする請求項1から請求項3までのいず
れかに記載の半導体集積回路の消費電力シミュレーショ
ン方法。4. The power consumption information for each cache operation includes, during a cache write operation, data of dirty data that is updated only in data stored in the cache and is inconsistent with data in a main memory at a corresponding address. This is information that distinguishes the write operation to the main memory. When the dirty data is written for each instruction during the simulation of a given program code, the power consumption information for each cache operation is included. 4. The power consumption simulation method for a semiconductor integrated circuit according to claim 1, wherein the power consumption of the cache unit is obtained based on power consumption information for the dirty data write operation.
算に必要な情報を記憶装置に保存しておき、シミュレー
ション実行後に前記記憶装置に保存しておいた消費電力
計算に必要な情報を基に当該シミュレーションで求めた
回路動作時の回路の消費電力を求めることを特徴とする
請求項1から請求項4までのいずれかに記載の半導体集
積回路の消費電力シミュレーション方法。5. During the execution of the simulation, information necessary for calculating the power consumption is stored in a storage device, and after the simulation, the simulation is performed based on the information required for calculating the power consumption stored in the storage device. 5. The method for simulating power consumption of a semiconductor integrated circuit according to claim 1, wherein the power consumption of the circuit during the circuit operation is obtained.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2001140462A JP2002334128A (en) | 2001-05-10 | 2001-05-10 | Method for simulating power consumption of semiconductor integrated circuit |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2001140462A JP2002334128A (en) | 2001-05-10 | 2001-05-10 | Method for simulating power consumption of semiconductor integrated circuit |
Publications (1)
Publication Number | Publication Date |
---|---|
JP2002334128A true JP2002334128A (en) | 2002-11-22 |
Family
ID=18987066
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2001140462A Pending JP2002334128A (en) | 2001-05-10 | 2001-05-10 | Method for simulating power consumption of semiconductor integrated circuit |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP2002334128A (en) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2007021392A2 (en) * | 2005-08-17 | 2007-02-22 | Sun Microsystems, Inc. | Inferential power monitor without voltage/current transducers |
WO2013114745A1 (en) | 2012-01-31 | 2013-08-08 | 日本電気株式会社 | Information processing device, and power consumption calculation method for information processing device |
US9495272B2 (en) | 2009-06-11 | 2016-11-15 | Oracle America, Inc. | Method and system for generating a power consumption model of at least one server |
US9563724B2 (en) | 2013-09-28 | 2017-02-07 | International Business Machines Corporation | Virtual power management multiprocessor system simulation |
US10663991B2 (en) | 2015-11-12 | 2020-05-26 | Oracle International Corporation | Determining parameters of air-cooling mechanisms |
-
2001
- 2001-05-10 JP JP2001140462A patent/JP2002334128A/en active Pending
Cited By (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2007021392A2 (en) * | 2005-08-17 | 2007-02-22 | Sun Microsystems, Inc. | Inferential power monitor without voltage/current transducers |
WO2007021392A3 (en) * | 2005-08-17 | 2007-11-29 | Sun Microsystems Inc | Inferential power monitor without voltage/current transducers |
US7869965B2 (en) | 2005-08-17 | 2011-01-11 | Oracle America, Inc. | Inferential power monitor without voltage/current transducers |
US9495272B2 (en) | 2009-06-11 | 2016-11-15 | Oracle America, Inc. | Method and system for generating a power consumption model of at least one server |
WO2013114745A1 (en) | 2012-01-31 | 2013-08-08 | 日本電気株式会社 | Information processing device, and power consumption calculation method for information processing device |
US9600388B2 (en) | 2012-01-31 | 2017-03-21 | Nec Corporation | Information processing apparatus that computes power consumption for CPU command |
US9563724B2 (en) | 2013-09-28 | 2017-02-07 | International Business Machines Corporation | Virtual power management multiprocessor system simulation |
US10002212B2 (en) | 2013-09-28 | 2018-06-19 | International Business Machines Corporation | Virtual power management multiprocessor system simulation |
US10663991B2 (en) | 2015-11-12 | 2020-05-26 | Oracle International Corporation | Determining parameters of air-cooling mechanisms |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7133968B2 (en) | Method and apparatus for resolving additional load misses in a single pipeline processor under stalls of instructions not accessing memory-mapped I/O regions | |
JP4225851B2 (en) | Trace element generation system for data processor | |
JP3830651B2 (en) | Microprocessor circuit, system, and method embodying a load target buffer for prediction of one or both of loop and stride | |
US7899661B2 (en) | Run-time switching for simulation with dynamic run-time accuracy adjustment | |
JP3016575B2 (en) | Multiple cache memory access methods | |
JP5027669B2 (en) | Microprocessor, integrated circuit, system and method | |
US9471727B2 (en) | Simulation with dynamic run-time accuracy adjustment | |
JP5608594B2 (en) | Preload instruction control | |
JPH10232827A (en) | Method and device for writing back prefetch cache | |
JP2012530979A (en) | System, method, and apparatus for cache flushing a given range of pages and TLB invalidating a given range of entries | |
JP2000231549A (en) | Microprocessor | |
US7330941B2 (en) | Global modified indicator to reduce power consumption on cache miss | |
US5946718A (en) | Shadow translation look-aside buffer and method of operation | |
JPS5975347A (en) | Simulation device of logical circuit | |
JP2575219B2 (en) | Data processing system and method for facilitating instruction execution | |
JPH05204644A (en) | Data processor | |
Lee et al. | Filter data cache: An energy-efficient small L0 data cache architecture driven bymiss cost reduction | |
JP3195303B2 (en) | Method and apparatus for maintaining coherency between an instruction cache and a data cache | |
Jindal et al. | Reusing trace buffers as victim caches | |
JP2003108439A (en) | Processor system | |
JP2002163150A (en) | Processor | |
Bardizbanyan et al. | Speculative tag access for reduced energy dissipation in set-associative L1 data caches | |
TWI407306B (en) | Mcache memory system and accessing method thereof and computer program product | |
JP2002334128A (en) | Method for simulating power consumption of semiconductor integrated circuit | |
JP4160228B2 (en) | Microprocessor |