



## Review: Memory Hierarchy of a Modern Computer System

- Take advantage of the principle of locality to:
- Present as much memory as in the cheapest technology
- Provide access at speed offered by the fastest technology



| · Compulsory (cold                                     | start): first reference to                                    | a block                        |
|--------------------------------------------------------|---------------------------------------------------------------|--------------------------------|
| - "Cold" fact of li                                    | fe: not a whole lot you can                                   | do about it                    |
| - Note: When run<br>Misses are insig                   | ning "billions" of instruction,<br>nificant                   | , Compulsory                   |
| • Capacity:                                            |                                                               |                                |
| - Cache cannot co<br>- Solution: increa                | ntain all blocks access by th<br>se cache size                | ie program                     |
| · Conflict (collision)                                 | ):                                                            |                                |
| - Multiple memory<br>- Solutions: increa               | v locations mapped to same c<br>ase cache size, or increase o | ache locatio:<br>associativity |
| <ul> <li>Two others:</li> </ul>                        |                                                               |                                |
| <ul> <li>Coherence (Inva<br/>updates memory</li> </ul> | lidation): other process (e.g                                 | ., I/O)                        |
| - Policy: Due to n                                     | on-optimal replacement polic                                  | зy                             |
| 3/4/10                                                 | CS162 ©UCB Spring 2010                                        | Lec 14 4                       |







|                               | Goals for Today                                                                |                  |
|-------------------------------|--------------------------------------------------------------------------------|------------------|
| • Finish dis                  | cussion of Caching/TLBs                                                        |                  |
| • Concept o                   | of Paging to Disk                                                              |                  |
| • Page Faul                   | ts and TLB Faults                                                              |                  |
| · Precise II                  | nterrupts                                                                      |                  |
| • Page Repl                   | acement Policies                                                               |                  |
| Note: Some si<br>adapted from | lides and/or pictures in the following<br>slides ©2005 Silberschatz, Galvin, a | are<br>nd Gagne. |
| Many slides ge                | enerated from my lecture notes by Ku                                           | ubiatowicz.      |
| /4/10                         | CS162 ©UCB Spring 2010                                                         | Lec 14.8         |





| What Actually Happens on a TLB Miss?                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                 | What happens on a Context Switch?                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                           |                                                         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|
| <ul> <li>Hardware traver</li> <li>On TLB miss, I<br/>table to fill TL</li> <li>» If PTE valid</li> <li>» If PTE mark<br/>kernel decide</li> <li>Software traver</li> <li>On TLB miss, I</li> <li>Kernel traverse</li> <li>» If PTE valid</li> <li>» If PTE valid</li> <li>» If PTE mark</li> <li>Most chip sets p</li> <li>Most chip sets p</li> <li>Modern operat<br/>since they use</li> <li>Examples:</li> <li>» shared segm</li> <li>» user-level po</li> </ul> | rsed page tables:<br>hardware in MMU looks at cur<br>B (may walk multiple levels)<br>, hardware fills TLB and process<br>ted as invalid, causes Page Fault,<br>es what to do afterwards<br>used Page tables (like MIPS<br>processor receives TLB fault<br>es page table to find PTE<br>, fills TLB and returns from fault<br>ted as invalid, internally calls Page<br>provide hardware traversal<br>ing systems tend to have mor<br>translation for many things<br>ents<br>protions of an operating system | rrent page<br>sor never knows<br>, after which<br>5)<br>It<br>ge Fault handler<br>re TLB faults | <ul> <li>Need to do<br/>addresses t</li> <li>Address S<br/>longer val</li> <li>Options?</li> <li>Invalidate<br/>» What i</li> <li>Include Pr<br/>» This is</li> <li>What if tro<br/>- For example<br/>vice verso<br/>- Must inva<br/>» Otherw</li> </ul> | something, since TLBs map virt<br>to physical addresses<br>Space just changed, so TLB entries<br>lid!<br>e TLB: simple but might be expensi<br>if switching frequently between proces<br>rocessID in TLB<br>an architectural solution: needs hardw<br>anslation tables change?<br>ple, to move page from memory to<br>a<br>lidate TLB entry!<br>vise, might think that page is still in m | ual<br>; no<br>ve<br>ses?<br>vare<br>disk or<br>nemory! |
| 3/4/10                                                                                                                                                                                                                                                                                                                                                                                                                                                              | CS162 ©UCB Spring 2010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Lec 14.11                                                                                       | 3/4/10                                                                                                                                                                                                                                                   | CS162 ©UCB Spring 2010                                                                                                                                                                                                                                                                                                                                                                    | Lec 14,12                                               |

























