MIT6.S081笔记:lecture 4
data:image/s3,"s3://crabby-images/829bb/829bb8615cede921ab9aeaaeeb44793b3e5ccde9" alt=""
MIT6.S081笔记:lecture 4 Page Tables
Isolation
- why use virtual memory?
- make bad code doesn’t affect the os
- want sth really seperates these memories from different programs
data:image/s3,"s3://crabby-images/fb320/fb320b712245263a30d1bc11cbc81425c919d0c4" alt="image-20230613135851754"
How to give isolation?
Address Spaces
- give applications including the kernel its own address space
data:image/s3,"s3://crabby-images/02574/025745700f4bb33b3b06b1bf0d88e1ffdbbeacbd" alt="image-20230613140224359"
How to multiplex all these different address spaces on a single physical memory?
PAGE TABLES (HW: memory management unit)
Blueprint
data:image/s3,"s3://crabby-images/d25ce/d25ce319c7ad3e2abdc7ced75eb84c28637f95e3" alt="image-20230613144656206"
- every app has its own map which basically defines its address space
PAGE TABLE
- not per address, per page! each page is 4kB
data:image/s3,"s3://crabby-images/b0ec6/b0ec60d9cbf846271cd3b3c32b8f2727de76cba2" alt="image-20230613145933296"
- in xv6, virtual memory is less than physical memory space
- and it’s inefficient to store all entries(2^27)
RISC-V PAGE TABLE
- Use cache(TLB) to avoid 3 times of memory translations
- When switching page table, also need to flush the TLB
Kernel memory address space layout
data:image/s3,"s3://crabby-images/8e9db/8e9db22cd70ef9f563f5f48e98faa4cb27cff0de" alt="image-20230613161038236"
- every process has a corresponding kernel stack
- Post title:MIT6.S081笔记:lecture 4
- Post author:sixwalter
- Create time:2023-08-05 11:14:26
- Post link:https://coelien.github.io/2023/08/05/course-learning/MIT6.S081/lec4/
- Copyright Notice:All articles in this blog are licensed under BY-NC-SA unless stating additionally.
Comments