## DESIGN OF DIGITAL CIRCUITS (252-0028-00L), SPRING 2018 OPTIONAL HW 1: DRAM REFRESH

## **SOLUTIONS**

Instructor: Prof. Onur Mutlu

TAs: Juan Gomez Luna, Hasan Hassan, Arash Tavakkol, Minesh Patel, Jeremie Kim, Giray Yaglikci

Released: Thursday, Apr 12, 2018

## 1 DRAM Refresh

A new supercomputer has a DRAM-based memory system with the following configuration:

- The total capacity is 1 ExaByte (EB).
- The DRAM row size is 8 KiloByte (KB).
- The minimum retention time among all DRAM rows in the system is 64 ms. In order to ensure that no data is lost, every DRAM row is refreshed once every 64 ms. (Note: For each calculation in this question, you may leave your answer in simplified form in terms of powers of 2 and powers of 10.)
- (a) How many DRAM rows does the memory system have?

Capacity =  $2^{60}$  and row size =  $2^{13}$ , so there are  $2^{47}$  rows.

(b) How many DRAM refreshes happen in 64ms?

Because each row needs to be refreshed every 64ms, all rows need to be refreshed within 64ms. Thus, the number of refreshes = number of rows =  $2^{47}$ .

(c) What is the total power consumption of DRAM refresh in 64ms? (Hint: you will need to figure out how much power a refresh operation consumes. You can find useful information in the technical note by Micron https://safari.ethz.ch/digitaltechnik/spring2018/lib/exe/fetch.php?media=tn4704.pdf. Use the current (IDD) numbers specified in the datasheet posted on the website https://safari.ethz.ch/digitaltechnik/spring2018/lib/exe/fetch.php?media=1gb\_ddr3\_sdram.pdf. Clearly state all the assumptions and show how you derive the power numbers. You are welcome to use other data sheets as well. Make sure you specify how you obtain the power numbers and show your calculations and thought process.)

Given that we know the number of refreshes from (b),  $P_{total} = N_{refresh} * P_{refresh}$ .  $P_{refresh}$  is the power consumption of a refresh operation. To find that number, we can use  $P_{refresh} = IDD5B * V_{DD}$ , where IDD5B is the current consumption of a refresh operation. Here we are assuming that IDD5B is only used for refreshing one row, which is actually not true in real DRAM. Both IDD5B and  $V_{DD}$  can be found in the datasheet. There are many different IDD5B parameters to pick from in the datasheet depending on the types of DRAM we are assuming.

If we assume DDR3-1333 with IDD5B=160mA,  $P_{refresh}=160mA*1.5V=240mW$ . Thus,  $P_{total}=0.24W*2^{47}=3.38*10^{13}W$ . An approximate number is fine.

(d) What is the total energy consumption of DRAM refresh during a day?

 $Energy = Power * Time. Power is P_{total}$  from part (c). Time is a day, i.e., T = 24hrs \* 60mins \* 60secs. Thus, Energy is  $E = 2.91 * 10^{18}J$ .

This question is an extended version of the question on Slide 37 in Lecture 4: Slides: https://safari.ethz.ch/digitaltechnik/spring2018/lib/exe/fetch.php?media=onur-digitaldesign-2018-lecture4-mysteries-basics-afterlecture.pdf.

Video: https://youtu.be/WZeYoDkzAmc.

## 2 Main Memory Potpourri

A machine has a 4 GB DRAM main memory system. Each row is refreshed every 64 ms.

Note: This question is open ended. We provide one possible set of solutions. There could be other possible right solutions.

(a) The machine's designer runs two applications A and B (each run alone) on the machine. Although applications A and B have a similar number of memory requests, application A spends a surprisingly larger fraction of cycles stalling for memory than application B does? What might be the reasons for this?

A large number of application A's memory requests are row-buffer conflicts, whereas a large number of application B's memory requests are row-buffer hits.

Hence, application A's requests take longer to service and it spends more time stalling for memory.

(b) Application A also consumes a much larger amount of memory energy than application B does. What might be the reasons for this?

A row-buffer conflict consumes more energy than a a row-buffer hit. A row-buffer conflict requires a precharge, an activate and a read/write, whereas a row-buffer hit only requires a read/write.

Hence, application A consumes more memory energy.

(c) When applications A and B are run together on the machine, application A's performance degrades significantly, while application B's performance does not degrade as much. Why might this happen?

When the applications are run together, they interfere with each other. Hence, both applications' performance degrades when they run together. However, if a memory scheduler that favors row-buffer hits over row-buffer conflicts (like FR-FCFS) is used, it would favor application B's requests over application A's requests.

Therefore, application A's performance degrades more.

(d) The designer decides to use a smarter policy to refresh the memory. A row is refreshed only if it has not been accessed in the past 64 ms. Do you think this is a good idea? Why or why not?

This can reduce refresh energy significantly if a large fraction of the rows in memory contain data and are accessed (within the 64 ms refresh window), as these rows do not have to be refreshed explicitly. However, if only a small number of rows contain data and only these rows are accessed, this policy will not provide much reduction in refresh energy as a large fraction of rows are still refreshed at the 64 ms rate.

(e) When this new refresh policy is applied, the refresh energy consumption drops significantly during a run of application B. In contrast, during a run of application A, the refresh energy consumption reduces only slightly. Is this possible? Why or why not?

This is possible. If application B has a large working set, it could access a large fraction of the memory rows (within the 64 ms refresh window) and hence these rows do not have to be refreshed explicitly. On the other hand, application A could have a much smaller working set and hence a large fraction of rows still have to be refreshed at the 64 ms rate.