mem: Add missig timing and current parameters to DRAM configs
This patch adds missing timing and current parameters to the existing DRAM configs. These missing timing and current parameters are required by DRAMPower for the DRAM power calculations. The missing values are datasheet values of the specified DRAMs, and the appropriate references are added for the variuos configs.
This commit is contained in:
parent
f9fce9ba07
commit
00b37ffe50
1 changed files with 192 additions and 17 deletions
|
@ -122,6 +122,15 @@ class DRAMCtrl(AbstractMemory):
|
|||
# to be instantiated for a multi-channel configuration
|
||||
channels = Param.Unsigned(1, "Number of channels")
|
||||
|
||||
# For power modelling we need to know if the DRAM has a DLL or not
|
||||
dll = Param.Bool(True, "DRAM has DLL or not")
|
||||
|
||||
# DRAMPower provides in addition to the core power, the possibility to
|
||||
# include RD/WR termination and IO power. This calculation assumes some
|
||||
# default values. The integration of DRAMPower with gem5 does not include
|
||||
# IO and RD/WR termination power by default. This might be added as an
|
||||
# additional feature in the future.
|
||||
|
||||
# timing behaviour and constraints - all in nanoseconds
|
||||
|
||||
# the base clock period of the DRAM
|
||||
|
@ -193,14 +202,108 @@ class DRAMCtrl(AbstractMemory):
|
|||
tXAW = Param.Latency("X activation window")
|
||||
activation_limit = Param.Unsigned("Max number of activates in window")
|
||||
|
||||
# time to exit power-down mode
|
||||
# Exit power-down to next valid command delay
|
||||
tXP = Param.Latency("0ns", "Power-up Delay")
|
||||
|
||||
# Exit Powerdown to commands requiring a locked DLL
|
||||
tXPDLL = Param.Latency("0ns", "Power-up Delay with locked DLL")
|
||||
|
||||
# time to exit self-refresh mode
|
||||
tXS = Param.Latency("0ns", "Self-refresh exit latency")
|
||||
|
||||
# time to exit self-refresh mode with locked DLL
|
||||
tXSDLL = Param.Latency("0ns", "Self-refresh exit latency DLL")
|
||||
|
||||
# Currently rolled into other params
|
||||
######################################################################
|
||||
|
||||
# tRC - assumed to be tRAS + tRP
|
||||
|
||||
# Power Behaviour and Constraints
|
||||
# DRAMs like LPDDR and WideIO have 2 external voltage domains. These are
|
||||
# defined as VDD and VDD2. Each current is defined for each voltage domain
|
||||
# separately. For example, current IDD0 is active-precharge current for
|
||||
# voltage domain VDD and current IDD02 is active-precharge current for
|
||||
# voltage domain VDD2.
|
||||
# By default all currents are set to 0mA. Users who are only interested in
|
||||
# the performance of DRAMs can leave them at 0.
|
||||
|
||||
# Operating 1 Bank Active-Precharge current
|
||||
IDD0 = Param.Current("0mA", "Active precharge current")
|
||||
|
||||
# Operating 1 Bank Active-Precharge current multiple voltage Range
|
||||
IDD02 = Param.Current("0mA", "Active precharge current VDD2")
|
||||
|
||||
# Precharge Power-down Current: Slow exit
|
||||
IDD2P0 = Param.Current("0mA", "Precharge Powerdown slow")
|
||||
|
||||
# Precharge Power-down Current: Slow exit multiple voltage Range
|
||||
IDD2P02 = Param.Current("0mA", "Precharge Powerdown slow VDD2")
|
||||
|
||||
# Precharge Power-down Current: Fast exit
|
||||
IDD2P1 = Param.Current("0mA", "Precharge Powerdown fast")
|
||||
|
||||
# Precharge Power-down Current: Fast exit multiple voltage Range
|
||||
IDD2P12 = Param.Current("0mA", "Precharge Powerdown fast VDD2")
|
||||
|
||||
# Precharge Standby current
|
||||
IDD2N = Param.Current("0mA", "Precharge Standby current")
|
||||
|
||||
# Precharge Standby current multiple voltage range
|
||||
IDD2N2 = Param.Current("0mA", "Precharge Standby current VDD2")
|
||||
|
||||
# Active Power-down current: slow exit
|
||||
IDD3P0 = Param.Current("0mA", "Active Powerdown slow")
|
||||
|
||||
# Active Power-down current: slow exit multiple voltage range
|
||||
IDD3P02 = Param.Current("0mA", "Active Powerdown slow VDD2")
|
||||
|
||||
# Active Power-down current : fast exit
|
||||
IDD3P1 = Param.Current("0mA", "Active Powerdown fast")
|
||||
|
||||
# Active Power-down current : fast exit multiple voltage range
|
||||
IDD3P12 = Param.Current("0mA", "Active Powerdown fast VDD2")
|
||||
|
||||
# Active Standby current
|
||||
IDD3N = Param.Current("0mA", "Active Standby current")
|
||||
|
||||
# Active Standby current multiple voltage range
|
||||
IDD3N2 = Param.Current("0mA", "Active Standby current VDD2")
|
||||
|
||||
# Burst Read Operating Current
|
||||
IDD4R = Param.Current("0mA", "READ current")
|
||||
|
||||
# Burst Read Operating Current multiple voltage range
|
||||
IDD4R2 = Param.Current("0mA", "READ current VDD2")
|
||||
|
||||
# Burst Write Operating Current
|
||||
IDD4W = Param.Current("0mA", "WRITE current")
|
||||
|
||||
# Burst Write Operating Current multiple voltage range
|
||||
IDD4W2 = Param.Current("0mA", "WRITE current VDD2")
|
||||
|
||||
# Refresh Current
|
||||
IDD5 = Param.Current("0mA", "Refresh current")
|
||||
|
||||
# Refresh Current multiple voltage range
|
||||
IDD52 = Param.Current("0mA", "Refresh current VDD2")
|
||||
|
||||
# Self-Refresh Current
|
||||
IDD6 = Param.Current("0mA", "Self-refresh Current")
|
||||
|
||||
# Self-Refresh Current multiple voltage range
|
||||
IDD62 = Param.Current("0mA", "Self-refresh Current VDD2")
|
||||
|
||||
# Main voltage range of the DRAM
|
||||
VDD = Param.Voltage("0V", "Main Voltage Range")
|
||||
|
||||
# Second voltage range defined by some DRAMs
|
||||
VDD2 = Param.Voltage("0V", "2nd Voltage Range")
|
||||
|
||||
# A single DDR3-1600 x64 channel (one command and address bus), with
|
||||
# timings based on a DDR3-1600 4 Gbit datasheet (Micron MT41J512M8) in
|
||||
# an 8x8 configuration, amounting to 4 Gbyte of memory.
|
||||
# an 8x8 configuration.
|
||||
class DDR3_1600_x64(DRAMCtrl):
|
||||
# 8x8 configuration, 8 devices each with an 8-bit interface
|
||||
device_bus_width = 8
|
||||
|
@ -253,6 +356,15 @@ class DDR3_1600_x64(DRAMCtrl):
|
|||
# <=85C, half for >85C
|
||||
tREFI = '7.8us'
|
||||
|
||||
# Current values from datasheet
|
||||
IDD0 = '75mA'
|
||||
IDD2N = '50mA'
|
||||
IDD3N = '57mA'
|
||||
IDD4W = '165mA'
|
||||
IDD4R = '187mA'
|
||||
IDD5 = '220mA'
|
||||
VDD = '1.5V'
|
||||
|
||||
# A single DDR3-2133 x64 channel refining a selected subset of the
|
||||
# options for the DDR-1600 configuration, based on the same DDR3-1600
|
||||
# 4 Gbit datasheet (Micron MT41J512M8). Most parameters are kept
|
||||
|
@ -272,9 +384,18 @@ class DDR3_2133_x64(DDR3_1600_x64):
|
|||
tRRD = '5ns'
|
||||
tXAW = '25ns'
|
||||
|
||||
# Current values from datasheet
|
||||
IDD0 = '70mA'
|
||||
IDD2N = '37mA'
|
||||
IDD3N = '44mA'
|
||||
IDD4W = '157mA'
|
||||
IDD4R = '191mA'
|
||||
IDD5 = '250mA'
|
||||
VDD = '1.5V'
|
||||
|
||||
# A single DDR4-2400 x64 channel (one command and address bus), with
|
||||
# timings based on a DDR4-2400 4 Gbit datasheet (Samsung K4A4G085WD)
|
||||
# in an 8x8 configuration, amounting to 4 Gbyte of memory.
|
||||
# timings based on a DDR4-2400 4 Gbit datasheet (Micron MT40A512M8)
|
||||
# in an 8x8 configuration.
|
||||
class DDR4_2400_x64(DRAMCtrl):
|
||||
# 8x8 configuration, 8 devices each with an 8-bit interface
|
||||
device_bus_width = 8
|
||||
|
@ -288,8 +409,8 @@ class DDR4_2400_x64(DRAMCtrl):
|
|||
# 8x8 configuration, so 8 devices
|
||||
devices_per_rank = 8
|
||||
|
||||
# Use a single rank
|
||||
ranks_per_channel = 1
|
||||
# Match our DDR3 configurations which is dual rank
|
||||
ranks_per_channel = 2
|
||||
|
||||
# DDR4 has 2 (x16) or 4 (x4 and x8) bank groups
|
||||
# Set to 4 for x4, x8 case
|
||||
|
@ -329,7 +450,7 @@ class DDR4_2400_x64(DRAMCtrl):
|
|||
|
||||
tXAW = '21ns'
|
||||
activation_limit = 4
|
||||
tRFC = '260ns'
|
||||
tRFC = '350ns'
|
||||
|
||||
tWR = '15ns'
|
||||
|
||||
|
@ -348,10 +469,25 @@ class DDR4_2400_x64(DRAMCtrl):
|
|||
# <=85C, half for >85C
|
||||
tREFI = '7.8us'
|
||||
|
||||
# Current values from datasheet
|
||||
IDD0 = '64mA'
|
||||
IDD02 = '4mA'
|
||||
IDD2N = '50mA'
|
||||
IDD3N = '67mA'
|
||||
IDD3N2 = '3mA'
|
||||
IDD4W = '180mA'
|
||||
IDD4R = '160mA'
|
||||
IDD5 = '192mA'
|
||||
VDD = '1.2V'
|
||||
VDD2 = '2.5V'
|
||||
|
||||
# A single LPDDR2-S4 x32 interface (one command/address bus), with
|
||||
# default timings based on a LPDDR2-1066 4 Gbit part in a 1x32
|
||||
# configuration.
|
||||
# default timings based on a LPDDR2-1066 4 Gbit part (Micron MT42L128M32D1)
|
||||
# in a 1x32 configuration.
|
||||
class LPDDR2_S4_1066_x32(DRAMCtrl):
|
||||
# No DLL in LPDDR2
|
||||
dll = False
|
||||
|
||||
# 1x32 configuration, 1 device with a 32-bit interface
|
||||
device_bus_width = 32
|
||||
|
||||
|
@ -386,8 +522,7 @@ class LPDDR2_S4_1066_x32(DRAMCtrl):
|
|||
tRAS = '42ns'
|
||||
tWR = '15ns'
|
||||
|
||||
# 6 CK read to precharge delay
|
||||
tRTP = '11.256ns'
|
||||
tRTP = '7.5ns'
|
||||
|
||||
# 8 beats across an x32 DDR interface translates to 4 clocks @ 533 MHz.
|
||||
# Note this is a BL8 DDR device.
|
||||
|
@ -415,9 +550,28 @@ class LPDDR2_S4_1066_x32(DRAMCtrl):
|
|||
tXAW = '50ns'
|
||||
activation_limit = 4
|
||||
|
||||
# Current values from datasheet
|
||||
IDD0 = '15mA'
|
||||
IDD02 = '70mA'
|
||||
IDD2N = '2mA'
|
||||
IDD2N2 = '30mA'
|
||||
IDD3N = '2.5mA'
|
||||
IDD3N2 = '30mA'
|
||||
IDD4W = '10mA'
|
||||
IDD4W2 = '190mA'
|
||||
IDD4R = '3mA'
|
||||
IDD4R2 = '220mA'
|
||||
IDD5 = '40mA'
|
||||
IDD52 = '150mA'
|
||||
VDD = '1.8V'
|
||||
VDD2 = '1.2V'
|
||||
|
||||
# A single WideIO x128 interface (one command and address bus), with
|
||||
# default timings based on an estimated WIO-200 8 Gbit part.
|
||||
class WideIO_200_x128(DRAMCtrl):
|
||||
# No DLL for WideIO
|
||||
dll = False
|
||||
|
||||
# 1x128 configuration, 1 device with a 128-bit interface
|
||||
device_bus_width = 128
|
||||
|
||||
|
@ -475,10 +629,15 @@ class WideIO_200_x128(DRAMCtrl):
|
|||
tXAW = '50ns'
|
||||
activation_limit = 2
|
||||
|
||||
# The WideIO specification does not provide current information
|
||||
|
||||
# A single LPDDR3 x32 interface (one command/address bus), with
|
||||
# default timings based on a LPDDR3-1600 4 Gbit part in a 1x32
|
||||
# configuration
|
||||
# default timings based on a LPDDR3-1600 4 Gbit part (Micron
|
||||
# EDF8132A1MC) in a 1x32 configuration.
|
||||
class LPDDR3_1600_x32(DRAMCtrl):
|
||||
# No DLL for LPDDR3
|
||||
dll = False
|
||||
|
||||
# 1x32 configuration, 1 device with a 32-bit interface
|
||||
device_bus_width = 32
|
||||
|
||||
|
@ -491,7 +650,8 @@ class LPDDR3_1600_x32(DRAMCtrl):
|
|||
# 1x32 configuration, so 1 device
|
||||
devices_per_rank = 1
|
||||
|
||||
# Use a single rank
|
||||
# Technically the datasheet is a dual-rank package, but for
|
||||
# comparison with the LPDDR2 config we stick to a single rank
|
||||
ranks_per_channel = 1
|
||||
|
||||
# LPDDR3 has 8 banks in all configurations
|
||||
|
@ -500,8 +660,7 @@ class LPDDR3_1600_x32(DRAMCtrl):
|
|||
# 800 MHz
|
||||
tCK = '1.25ns'
|
||||
|
||||
# Fixed at 15 ns
|
||||
tRCD = '15ns'
|
||||
tRCD = '18ns'
|
||||
|
||||
# 12 CK read latency, 6 CK write latency @ 800 MHz, 1.25 ns cycle time
|
||||
tCL = '15ns'
|
||||
|
@ -512,8 +671,8 @@ class LPDDR3_1600_x32(DRAMCtrl):
|
|||
# Greater of 4 CK or 7.5 ns, 4 CK @ 800 MHz = 5 ns
|
||||
tRTP = '7.5ns'
|
||||
|
||||
# Pre-charge one bank 15 ns (all banks 18 ns)
|
||||
tRP = '15ns'
|
||||
# Pre-charge one bank 18 ns (all banks 21 ns)
|
||||
tRP = '18ns'
|
||||
|
||||
# 8 beats across a x32 DDR interface translates to 4 clocks @ 800 MHz.
|
||||
# Note this is a BL8 DDR device.
|
||||
|
@ -540,3 +699,19 @@ class LPDDR3_1600_x32(DRAMCtrl):
|
|||
# Irrespective of size, tFAW is 50 ns
|
||||
tXAW = '50ns'
|
||||
activation_limit = 4
|
||||
|
||||
# Current values from datasheet
|
||||
IDD0 = '8mA'
|
||||
IDD02 = '60mA'
|
||||
IDD2N = '0.8mA'
|
||||
IDD2N2 = '26mA'
|
||||
IDD3N = '2mA'
|
||||
IDD3N2 = '34mA'
|
||||
IDD4W = '2mA'
|
||||
IDD4W2 = '190mA'
|
||||
IDD4R = '2mA'
|
||||
IDD4R2 = '230mA'
|
||||
IDD5 = '28mA'
|
||||
IDD52 = '150mA'
|
||||
VDD = '1.8V'
|
||||
VDD2 = '1.2V'
|
||||
|
|
Loading…
Reference in a new issue