ChangeLog revision 10428
12632Sstever@eecs.umich.eduChange Log: 22632Sstever@eecs.umich.edu 32632Sstever@eecs.umich.eduDRAMPower v4.0 - * DRAMPower can now be compiled as a library. This enables a user 42632Sstever@eecs.umich.edu to access the tool through an API and log commands and their 52632Sstever@eecs.umich.edu corresponding time stamps, removing the need to store large 62632Sstever@eecs.umich.edu command traces on disk. In addition, cycle counting variables 72632Sstever@eecs.umich.edu have been changed to int64 to support longer simulations. 84479Sbinkertn@umich.edu The library can be compiled without Xerces to remove an optional 92632Sstever@eecs.umich.edu dependency and reduce the size of the binary. 102632Sstever@eecs.umich.edu * Improved robustness. The latest build is automatically checked 114479Sbinkertn@umich.edu out on a test server, compiled, and tested to verify that the 122632Sstever@eecs.umich.edu output matches an expected reference. The code is also compiled 132632Sstever@eecs.umich.edu with a large number of warning flags enabled and treats all 142632Sstever@eecs.umich.edu warnings as errors. 156498Snate@binkert.org * Bug fix: Fixed bug in io/termination energy calculation. 162632Sstever@eecs.umich.edu * Bug fix: Fixed bug in calculation of auto precharge cycle. 174479Sbinkertn@umich.edu 184479Sbinkertn@umich.eduDRAMPower v3.1 - * Added IO and Termination Power measures from Micron's DRAM Power 194479Sbinkertn@umich.edu Calculator, for all supported DRAM generations. In the case of 204479Sbinkertn@umich.edu Wide IO DRAMs, these measures are already included in the provided 216498Snate@binkert.org current specifications. This feature enables support for multi-rank 224479Sbinkertn@umich.edu DRAM DIMMs (DDR2/3/4) and stacking of multiple Wide IO DRAM dies 234479Sbinkertn@umich.edu (equivalent to ranks). To indicate use of multi-rank DRAMs or 244479Sbinkertn@umich.edu multiple Wide IO DRAM dies/layers, the 'nbrOfRanks' parameter in 254479Sbinkertn@umich.edu the memory specification XMLs can be employed. Note: The DRAM 264479Sbinkertn@umich.edu command scheduler does not support multi-rank/multi-die DRAMs yet. 274479Sbinkertn@umich.edu Only the power estimation component of DRAMPower has been updated 284479Sbinkertn@umich.edu to support them. The current measures for dual-rank DRAMs only 294479Sbinkertn@umich.edu reflect those for the active rank and not the idle rank. The 304479Sbinkertn@umich.edu default state of the idle rank is assumed to be the same as the 314479Sbinkertn@umich.edu current memory state, for background power estimation. Hence, 324479Sbinkertn@umich.edu rank information in the command trace is not required. 334479Sbinkertn@umich.edu * Added warning messages: New warning messages are provided, to 344479Sbinkertn@umich.edu identify if the memory or bank state is inconsistent in the 354479Sbinkertn@umich.edu user-defined traces. Towards this, a state check is performed on 364479Sbinkertn@umich.edu every memory command issued. 374479Sbinkertn@umich.edu * Improved run-time options: Users can now point directly to the 384479Sbinkertn@umich.edu memory specification XML, instead of just the memory ID. Also, 394479Sbinkertn@umich.edu users can optionally include IO and termination power estimates 404479Sbinkertn@umich.edu (for both single and dual rank DRAMs) using '-r' flag in the 416498Snate@binkert.org command line options. 424479Sbinkertn@umich.edu * Bug fixes: (1) Refresh handler in the DRAM Command Scheduler was 434479Sbinkertn@umich.edu kept ON in the Self-Refresh mode, when it can be turned OFF. This 444479Sbinkertn@umich.edu bug has now been fixed. (2) Precharge All (PREA) always considered 454479Sbinkertn@umich.edu precharging of all banks. It has now been modified to consider 464479Sbinkertn@umich.edu precharging of the open/active banks alone. 476498Snate@binkert.org 484479Sbinkertn@umich.eduDRAMPower v3.0 - * Added support for LPDDR3 and DDR4 memories, besides the already 494479Sbinkertn@umich.edu supported DDR2/DDR3, LPDDR/LPDDR2 and WIDE IO DRAM memories. 504479Sbinkertn@umich.edu * Added DRAM Command Scheduler: To support users of DRAMPower 514479Sbinkertn@umich.edu without access to DRAM controllers, we have added a simple DRAM 524479Sbinkertn@umich.edu command scheduler that dynamically schedules DRAM commands as if 534479Sbinkertn@umich.edu it were a memory controller. The scheduler assumes closed-page 544479Sbinkertn@umich.edu policy, employs ASAP scheduling for DRAM commands (i.e. schedules 554479Sbinkertn@umich.edu commands as soon as timing constraints are met), performs FCFS 564479Sbinkertn@umich.edu scheduling on DRAM transactions and supports all the different 574479Sbinkertn@umich.edu DRAM generations supported by the power model. The generated DRAM 584479Sbinkertn@umich.edu command schedule is also analyzable for real-time applications. 594479Sbinkertn@umich.edu Users can also select speculative usage of power-down or 606498Snate@binkert.org self-refresh modes (if needed) for idle periods between 614479Sbinkertn@umich.edu transactions. It should be noted that using this command scheduler 624479Sbinkertn@umich.edu is optional and it can be (de-)selected during run-time and users 634479Sbinkertn@umich.edu can switch back to the previously used DRAM command interface as 644479Sbinkertn@umich.edu in the earlier versions. 654479Sbinkertn@umich.edu * Improved run-time options: Users can specify the memory and the 666498Snate@binkert.org trace file to be used by DRAMPower using command line options. 674479Sbinkertn@umich.edu Additionally, if the DRAM command scheduler is being used, the 686498Snate@binkert.org users can specify the degree of bank interleaving required, the 694479Sbinkertn@umich.edu request size and power-down or self-refresh options. Also, for 706498Snate@binkert.org DDR4 memories the bank group interleaving can be specified using 716498Snate@binkert.org command line options. 726498Snate@binkert.org * Bug fixes: (1) For command traces ending with a RD/WR/RDA/WRA 736498Snate@binkert.org command, the tool did not consider completion of operations when 746498Snate@binkert.org estimating the total trace energy. The missing cycles are now 754479Sbinkertn@umich.edu taken into account. 764479Sbinkertn@umich.edu (2) The IDD5 (REF current) specification for WIDE IO SDR memory 774479Sbinkertn@umich.edu specifications only included 2 banks for refreshes instead of all 784479Sbinkertn@umich.edu four. We would like to thank David Roberts from AMD for spotting 794479Sbinkertn@umich.edu the issue in our DATE'13 article. These measures have been updated. 804479Sbinkertn@umich.edu (3) When estimating precharge cycle for commands with 814479Sbinkertn@umich.edu auto-precharge, (RDA/WRA), the command analysis tool employed the 826498Snate@binkert.org last activation cycle in the entire DRAM instead of the particular 836498Snate@binkert.org DRAM bank. This bug has been fixed in this release. 846498Snate@binkert.org 856498Snate@binkert.orgDRAMPower v2.1 - * Added support for variation-aware power estimation, for a 866498Snate@binkert.org selection of DDR3 memories manufactured using 50nm process 876498Snate@binkert.org technology, based on the Monte-Carlo analysis presented in our 886498Snate@binkert.org DAC'13 article. 896498Snate@binkert.org 906498Snate@binkert.orgDRAMPower v2.0 - * Added support for LPDDR/LPDDR2 and WIDE IO DRAM memories, besides 916498Snate@binkert.org the already supported DDR2/DDR3 memories. 926498Snate@binkert.org * Faster analysis: The trace analysis component in DRAMPower v2.0 936498Snate@binkert.org triggers the evaluation only during memory state transitions 946498Snate@binkert.org (between active, precharged, active and precharged power-down, 956498Snate@binkert.org refresh, self-refresh and power-up states) and not on every clock 966498Snate@binkert.org cycle, as was the case till the last version. This optimization 976498Snate@binkert.org speeds up the power simulations using DRAMPower by several times 986498Snate@binkert.org over cycle-accurate analysis, resulting in fast power analysis, 996498Snate@binkert.org without affecting the accuracy of the trace analysis or the 1006498Snate@binkert.org reported power and energy estimates. 1016498Snate@binkert.org * Verification effort: Our power model was verified by the 1024479Sbinkertn@umich.edu Microelectronic System Design group at TU Kaiserslautern using 1034479Sbinkertn@umich.edu circuit-level SPICE simulations of a DRAM cross-section. As a 1044479Sbinkertn@umich.edu result of this verification effort, a couple of power equations 1054479Sbinkertn@umich.edu have been modified for Refresh and Self-refresh operations. The 1064479Sbinkertn@umich.edu difference between the power and energy estimates reported by our 1074479Sbinkertn@umich.edu updated model and the equivalent circuit-level simulations is 1084479Sbinkertn@umich.edu < 2% for all memory operations of any granularity for all memories 1094479Sbinkertn@umich.edu supported by DRAMPower. 1104479Sbinkertn@umich.edu 1114479Sbinkertn@umich.eduDRAMPower v1.2 - * Supports different power-down and self-refresh modes in DDR2 and 1124479Sbinkertn@umich.edu DDR3 DRAM memories. 1134479Sbinkertn@umich.edu * Bug fix: Refresh power consumption equation in DRAMPower v1, 1144479Sbinkertn@umich.edu incorrectly subtracted IDD2n (precharge background current) 1152632Sstever@eecs.umich.edu instead of IDD3n (active background current) from IDD5 (total 1162632Sstever@eecs.umich.edu refresh current). This error has been rectified in this version. 1172632Sstever@eecs.umich.edu 1182632Sstever@eecs.umich.eduDRAMPower v1.0 - * Performs cycle-accurate memory command trace analysis and estimates 1192632Sstever@eecs.umich.edu power and energy consumption numbers for the trace. 1204479Sbinkertn@umich.edu * It supports the basic memory operations like read, write, refresh, 1216498Snate@binkert.org activate and (auto) precharge in DDR2 and DDR3 memories. 1226498Snate@binkert.org