a DRAM page-mode scheduling policy for the many

advertisement
[Paper Review]
Minimalist Open-page:
A DRAM Page-mode Scheduling Policy
for the Many-core Era
Dimitris Kaseridis+, Jeffrey Stuecheli*+, and Lizy Kurian John+
MICRO’11
+ The
University of Texas at Austin
* IBM Corp.
Korea University, VLSI Signal Processing Lab.
Jinil Chung (정진일)
(jinil_chung@korea.ac.kr)
jinil_chung@korea.ac.kr
Abstract
DRAM: balance between performance,
power, and storage density
To realize good performance,
Must mange the structural and timing
restrictions of the DRAM devices
Use of “Page-mode” feature can
mitigate many DRAM constraints
[IEEE Spectrum(link)]
Aggressive page-mode results in
many conflicts (e.g. bank conflict)
when multiple workloads in manycore systems map to the same DRAM
In this paper, Minimalist approach
“just enough” page-mode accesses to get benefits, avoiding unfairness
 Proposed address hashing + data prefetch engine + per request priority
jinil_chung@korea.ac.kr
(2)
1. Introduction
Row buffer (or “page-mode”) Access
Open-page policy
Closed-page policy
Page-mode
gain
Reducing row access
latency
None
(single col. access
per row activation)
Multiple
requests in
many core
system
Introducing priority
inversion and
fairness/starvation
problems
Avoiding
complexities of row
buffer management
This paper proposed combination of open/closed-page policy based on …
1) Page-mode gain with only a small number of page accesses
 Propose a fair DRAM address mapping scheme: low RBL & high BLP
2) Page-mode hit with spatial locality which can be captured in prefetch engines
 Propose an intuitive criticality-based memory request priority scheme
NOT temporal locality!
jinil_chung@korea.ac.kr
RBL: Row-buffer Locality
BLP: Bank-level Parallelism
(3)
2. Background
DRAM timing constraint results in “dead time”
before and after random access
MC(Memory Controller)’s job is to reduce
performance-limiting gaps using parallelism
1) tRC (row cycle time; ACT-to-ACT @same BK)
: MC activates a page  wait for tRC @same BK
: multiple threads access diff. row @same BK 
latency overhead (tRC delay)
2) tRP (row precharge time; PRE-to-ACT @same BK)
: In open-page policy, MC activates other page 
tRP penalty @same BK (=close current page before
new page is opened)
tRC (e.g. 48ns)
tRP (e.g. 12ns)
tRAS (e.g. 36ns)
ACT
jinil_chung@korea.ac.kr
PRE
ACT
@same bank
(4)
3. Motivation
Use of “page-mode” …
1)
2)
3)
4)
Next page
Latency Effects: Due to tRC & tRP, overall latency increase  small # of access?
Power Reduction: only Activate Power reduction  small # of access is enough
Bank Utilization: drop off quickly as access increase  small # of access is enough
Other DRAM complexities: small # of access is needed for soften restrictions
ex) tFAW (Four page Activate time Window; 30ns), cache block transfer delay=3ns
-. single access per ACT: limited peak utilization (6ns*4/30ns=80%)
-. two~ accesses per ACT: not limited peak utilization (12ns*4/30ns>100%)
62%
If B/U is high, the probability
that new request will conflict w/
a busy bank is greater.
16%
Closedpage policy
jinil_chung@korea.ac.kr
Closedpage policy
(5)
3. Motivation
3.1 Row-buffer locality in Modern Processors
: in current WS/Server class designs
 large last-level cache
(e.g. IBM PowerPC 7)
Temporal locality: hits to
the large Last-level cache
Row buffers exploit only
Spatial locality
Using prefetch engines,
It can be predict spatial locality
RBL: Row-buffer Locality
jinil_chung@korea.ac.kr
(6)
3. Motivation
3.2 Bank and Row Buffer Locality Interplay with Address Mapping
-. DRAM device address: row, column, and bank
Workload A: long sequential access seq.
Workload B: single operation
(DRAM all col.  low order real addr.)
e.g. FR-FCFS
(DRAM all col.  low order real addr.)
Workload A: higher priority
 Slow B0
Workload B: higher priority
 Slow A4
e.g. ATLAS, PAR-BS
(DRAM col. & bank  low order real
addr.)
High BLP (Bank-level Parallelism)
 B0 can be serviced w/o degrading
traffic to the workload A
e.g. Minimalist
jinil_chung@korea.ac.kr
(7)
4. Minimalist Open-page Mode
4.1 DRAM Address Mapping Scheme
-. The basic difference that the Column access bits are split in two places.
+. 2 LSB bits are located right after the Block bits
+. 5 MSB bits are located just before the Row bits
-. (Not shown in the figure) higher order address bits are XOR-ed with the bank bits
produce the actual bank selection bits  reducing row buffer conflict [Zhang et
al./MICRO’00]
For sequential access of
4 cache lines
7-bit
jinil_chung@korea.ac.kr
5-bit
2-bit
(8)
4. Minimalist Open-page Mode
4.2 Data Prefetch Engine [IBM PowerPC 6]
: predictable “page-mode” opportunities  need for accurate prefetch engine
: each core includes HW prefetcher w/ prefetch depth distance predictor
1) Multi-line Prefetch Requests
-. Multi-line prefetch operation: single request (to indicate specific seq. of cache lines)
-. Reducing command BW and queue resource
jinil_chung@korea.ac.kr
(9)
4. Minimalist Open-page Mode
4.3 Memory Request Queue Scheduling Scheme
: In OOO execution, the importance of each request can vary both between and
within applications  need for dynamic priority scheme
1) DRAM Memory Requests Priority Calculation
-. different priority based on criticality to performance
-. Increase priority of each request every 100ns time interval  time-based
-. 2 categories: read (normal) and prefetch  read request is higher priority
-. MLP information from MSHR in each core: many misses  less important
-. Distance information from Prefetch engine (4.2)
Read request
MLP: Memory Level Parallelism
MSHR: Miss Status Holding Register
jinil_chung@korea.ac.kr
( 10 )
4. Minimalist Open-page Mode
4.3 Memory Request Queue Scheduling Scheme (cont.)
2) DRAM Page Closure (Precharge) Policy
-. Using autoprecharge  increasing command BW
3) Overall Memory Requests Scheduling Scheme (Priority Rules 1)
-. Same rules are used by all of MC  No need for communication among MC
-. if MC is servicing the multiple transfers from a multi-line prefetch request, it can
be interrupted by a higher priority request  very critical request can be serviced w/
the smallest latency
4) Handling write operations
-. dynamic priority scheme
not apply to write
-. Using VWQ(Virtual Write Queue)
 causing minimal write instructions
jinil_chung@korea.ac.kr
( 11 )
5. Evaluation
-. 8 core CMP system using the Simics functional model extended w/ the GEMS toolset
-. Simulate DDR3 1333MHz DRAM using memory controller policy for each experiment
-. Minimalist open-page scheme is compared against three open-page policies: Table 5
1) PAR-BS (Parallelism-aware Batch Scheduler)
2) ATLAS (Adaptive per-Thread Least-Attained-Service) memory scheduler
3) FR-FCFS (First-Ready, First-Come-First-Served): baseline
jinil_chung@korea.ac.kr
( 12 )
5. Evaluation
5.1 Throughput
-. Overall, “Minimalist Hash+Priority" demonstrated the best throughput
improvement over the other schemes, achieving a 10% improvement.
-. This is compared against ATLAS and PAR-BS that achieved 3.2% and 2.8%
throughput improvements over the whole workload suite.
jinil_chung@korea.ac.kr
( 13 )
5. Evaluation
5.2 Fairness
-. Minimalist improves fairness up to 15% with an overall improvement of 7.5%,
3.4% and 2.5% for FR-FCFS, PAR-BS and ATLAS, respectively.
jinil_chung@korea.ac.kr
( 14 )
5. Evaluation
5.3 Row Buffer Access per Activation
-. The observed page-access rate for the aggressive open-page policies fall
significantly short  The high page hit rate is simply not possible given the
interleaving of requests between the eight executing programs.
-. With the Minimalist scheme, the achieved page-access rate is close to 3.5,
compared to the ideal rate of four.
jinil_chung@korea.ac.kr
( 15 )
5. Evaluation
5.4 Target Page-hit Count Sensitivity
-. The Minimalist system requires a target number of page hits to be selected that
indicates the maximum number of pages hits the scheme attempts to achieve per
row activation.
-. a target number of 4 pages hits provides the best results.
(that different system configuration may shift the optimal page-mode hit count.)
jinil_chung@korea.ac.kr
( 16 )
5. Evaluation
5.5 DRAM Energy Consumption
-. To estimate the power consumption we used the Micron power calculator
-. Approximately the same as FR-FCFS. PAR-BS, ATLAS and “Minimalist
Hash+Priority" provide a small decrease of approximately 5% to the overall energy
consumption.
-. The energy results are essentially a balance between the decrease in page-mode
hits (resulting in high DRAM activation power) and the increase in system
performance (decreasing runtime).
jinil_chung@korea.ac.kr
( 17 )
Conclusions
Minimalist Open-page memory scheduling policy
-. Page-mode gain w/ small number of page accesses for each page activation
-. Assign per-request priority using request stream information in MLP and data
prefetch engine
Improving throughput and fairness
-. Throughput increased by 10% on average (compared to FR-FCSC)
-. No need for thread based priority information
-. No need for communication/coordination among multiple MC or OS
jinil_chung@korea.ac.kr
( 18 )
Appendix. Detailed simulation information
jinil_chung@korea.ac.kr
( 19 )
Appendix. Detailed simulation information
jinil_chung@korea.ac.kr
( 20 )
Appendix. Detailed simulation information
jinil_chung@korea.ac.kr
( 21 )
Thanks,
jinil_chung@korea.ac.kr
( 22 )
Download