Virtual Memory: 12 Multi-level Page Tables

  Рет қаралды 214,411

David Black-Schaffer

David Black-Schaffer

Күн бұрын

Пікірлер: 105
@freyaj4666
@freyaj4666 9 жыл бұрын
This series is awesome! I don't know how to survive college without all those youtube professors!
@TheWischmopps
@TheWischmopps 8 жыл бұрын
this is so true!
@raghavsrinivas9455
@raghavsrinivas9455 4 жыл бұрын
These links has more clear explanation. It si not about swapping of tables. Above video seems missing important details .Watch these : kzbin.info/www/bejne/ppS3cqKvr7xlqLs and kzbin.info/www/bejne/qoGafYyYe9eeZ5I.
@Alessandro_Furci
@Alessandro_Furci 5 жыл бұрын
David i spent over 3 hours (!!!!!) trying to understand Multi-level Page Tables searching on the Internet. Now i find your video. THANK YOU VERY MUCH MAN. Perfect lesson.
@smitjainsj
@smitjainsj 3 жыл бұрын
This is a million dollar video series about Memory Management.. big thanks to the creator
@biogirl18
@biogirl18 3 жыл бұрын
Oh, My. The best teacher I have even seen. Willing to pay for your full knowledge.
@罗林-k5n
@罗林-k5n 3 жыл бұрын
I am a software engineer , this series helps a lot, thank you youtube professor
@omkars764
@omkars764 9 жыл бұрын
These videos are awesome. Thanks for explaining them so well.
@IK-ow2zk
@IK-ow2zk 3 жыл бұрын
Thanks a lot for this course! You made an amazing visualization! It is brilliantly clear, and so recognizable!
@MichalMonday
@MichalMonday 4 жыл бұрын
It's great that it's clearly explained why it's needed (at 01:30). Previously I checked 3 different resources (course, book, website) and couldn't figure it out
@pythonprofreak7522
@pythonprofreak7522 5 жыл бұрын
I like all your instruction videos and they are good for new and refresher learners. You have done exceptionally good job! Thank you!
@catalinasdfghjkl
@catalinasdfghjkl 4 жыл бұрын
the best explanation on the internet
@ddnhan
@ddnhan 7 жыл бұрын
Thank you so much for making this video :D It helps me a lot to fully understand after reading the text book!
@nilspin
@nilspin 6 жыл бұрын
Question at 3:55 . Why 4kb + 4kb? In the video professor says "in order to do any meaningful computation" by which he means in order to perform any virtual-to-physical address translation we need atleast one 2nd level page in memory. My question is - but why? If an entry in 1st level page (in my TLB) says it's corresponding page is in Disk, can't I just fetch it from there like all other pages on disk that will follow?
@lfm3585
@lfm3585 4 жыл бұрын
Rephrasing this question: Is it possible for a program to be running and have none of its data in memory. I think this depends on what you mean by running. If the program isn't in memory then you couldn't be executing any of its instructions. I think you are right that the application can be completely paged out and considered running by the OS
@parasvaish3239
@parasvaish3239 2 жыл бұрын
Sure we can fetch the 2nd level of page table from the disk but 1. It still needs to be stored somewhere i.e. in RAM(since cache is small) so better keep a dedicated space in RAM from the start itself as fetching 2nd level table from disk every time will take up huge amount of time and eat up your performance. We can replace already present 2nd level table in RAM with another one as per our requirements.
@gumsumful
@gumsumful 8 жыл бұрын
I simply wanna say you rocked =D
@unknownxyz7885
@unknownxyz7885 5 ай бұрын
Thank you for clearing the concept of multi level page tables.
@MrDajiangyoude
@MrDajiangyoude 6 жыл бұрын
This is truly illustrative!!! period.
@klausdupont6335
@klausdupont6335 4 жыл бұрын
Incredibly well explained!
@kr7437a
@kr7437a 5 жыл бұрын
i love it: "All problems in computer science can be solved by another level of indirection."
@thelonearchitect
@thelonearchitect 6 жыл бұрын
Holy ! Thanks you so much for explaining so clearly !
@onwul
@onwul 8 жыл бұрын
Great video, thank you so much!
@960peps
@960peps 7 жыл бұрын
These videos are fantastic. Thanks !!
@cammiller7686
@cammiller7686 3 жыл бұрын
thorough and concise. thanks
@raytruong5882
@raytruong5882 4 жыл бұрын
Why can't all professors be like him
@silas3463
@silas3463 4 жыл бұрын
Hey David, really enjoying these informative videos :) I have a question about this video, when you ask "what the smallest amount of page table data should be kept in memory for a 32-bit application" you say that we need a 1st and 2nd level page table ( 3:44 )but wouldn't we only need a 4kB page table ENTRY for each page table?
@abir95571
@abir95571 4 жыл бұрын
You wouldn't want your program to start doing page swapping from the very beginning ... for the program to meaningfully translate some address it needs the first level page table and then any one of the 2nd level page table. Otherwise the program basically never "starts"
@aldoramirezmendoza2663
@aldoramirezmendoza2663 3 жыл бұрын
@@abir95571 But, If you don't use the program for a long time, the O.S could swap all 2nd level tables to disk, and that's not bad. So, you only have the first level table, that is only 4kB.
@m.preacher2829
@m.preacher2829 3 жыл бұрын
without 2nd level page table u cannot index the correct PA in memory. so at least one 2nd level page table in memory.
@tomaspinto3833
@tomaspinto3833 6 жыл бұрын
Very good, but i still don't understand why we need 4kb+4kb instead of just 4kb. With just one table in memory, each entry is pointing to 2**10 (correct me if this number is wrong) different Virtual Page Numbers associated to their corresponding Frame Page Numbers. Why are you saying you need a second 4kiB table for translations if the translations are already there?
@nilspin
@nilspin 6 жыл бұрын
I was confused about same. Why 4kb + 4kb? In the video professor says "in order to do any meaningful computation" by which he means in order to perform any virtual-to-physical address translation we need atleast *one* 2nd level page in memory (at around 3:55). My question is - but why? If an entry in 1st level page (in my TLB) says it's corresponding page is in Disk, can't I just fetch it from there like all other pages on disk that will follow?
@rubiskelter
@rubiskelter 8 жыл бұрын
Seems like you've read the OSTEP?
@eleftherioskostakis1834
@eleftherioskostakis1834 4 жыл бұрын
love you from Greece bro.
@jonathanharris2326
@jonathanharris2326 3 жыл бұрын
This is so helpful, thank you so much
@Acadflix
@Acadflix 3 жыл бұрын
This is good, Priceless content. Multilevel paging is good in best case (meaning when each program access pages in sequence) but in worst case when program access pages each having entry in difference page table then i think IO cost will be too high because you will have to bring 2nd level page table every time you try to access a page frame.
@warriorfb2010
@warriorfb2010 5 жыл бұрын
Very nice video. Great instruction
@vi3ruSak
@vi3ruSak 6 жыл бұрын
So, even when you are using two level page tables, it can still happen for single process that it must keep one 1st level PT and all 2nd level PTs in memory in the worst case ?
@hulaalol
@hulaalol 9 жыл бұрын
awesome explanation! thank you
@chilo7272
@chilo7272 2 жыл бұрын
amazing work. Wish we could pring out that presentation
@pp8471
@pp8471 6 жыл бұрын
Very good material. Thank you
@MyVip3r
@MyVip3r 3 жыл бұрын
5:54 How to find which level of page table we need from the rest of 0x00402 ?how you devide these bits ?
@fonera5131
@fonera5131 3 жыл бұрын
Throw 0x00402 into any hex to bin converter, split the binary result in the middle and you will get what he has there.
@jonathanma4206
@jonathanma4206 7 жыл бұрын
Is it possible for the first 10 bits to point to a page in the 1st level page table, and the second 10 bits not found in the 2nd level page table?
@johnc7331
@johnc7331 6 жыл бұрын
No because each level has a valid bit describing whether or not there is a page being used in that Page Directory Entry's page. For example, if a you have a 2 level page table, the top level will only be valid if in all the pages that it references, there is at least 1 page that references some address in memory. I hope I was clear in my explanation, if not just comment and I'll try and clarify!
@taoyang5123
@taoyang5123 3 жыл бұрын
Good video,just like OSTEP.Simple and best.
@panzerofthelake1623
@panzerofthelake1623 2 жыл бұрын
So basically multi level page tables are basically page tables where each page table entry connects to another page table?
@deepeshguragain2658
@deepeshguragain2658 8 жыл бұрын
Simply the Best........:-)
@andychang1179
@andychang1179 4 жыл бұрын
This guy is amazing
@flintthuang
@flintthuang 8 жыл бұрын
Is this multi-level page table a nested page table(EPT)?
@abhishekknegi007
@abhishekknegi007 4 жыл бұрын
Awsome explanation keep it up
@tothespace2122
@tothespace2122 11 ай бұрын
At 1:54 what does 4kB = 1024 PTEs mean? We have 1024 PTEs because we divided our adress bits like this: 10 for first level, 10 for second level and 12 for bits taht are directly mapped. So what does 4kB mean in the context of first level table?
@minhandrew3305
@minhandrew3305 10 ай бұрын
Each PTE requires 4 bytes (on this 32-bit system we are talking about), so 1024 PTEs x 4 bytes = 4096 bytes = 4 kB in total for this page table in a multi-level page table.
@cyberonymous4100
@cyberonymous4100 3 ай бұрын
Size of a page
@aaditya4125
@aaditya4125 8 жыл бұрын
the question @3:44, if we can have page table of less size, can we have the 1st level page table of 4kB and the 2nd level page table of 1kB each (since we will be left with 20 bits, so 2*10 bits, i.e. two 1kB page table) OR a 2kB page table ?
@석상주
@석상주 8 жыл бұрын
Do we need 2nd level page table for every entry in the first level page table?
@songlinyang9248
@songlinyang9248 6 жыл бұрын
Just the entries which the program need. Instead of all page table entries, we just need what we need.
@thesquake5368
@thesquake5368 5 жыл бұрын
@@songlinyang9248 So the ones that we don't need don't exist or are just simply kept on the disk ?
@konakallaankalarao776
@konakallaankalarao776 2 жыл бұрын
Awesome explanation
@w0nnafight
@w0nnafight Жыл бұрын
nobody asked your opinion
@jyotirmayaojha6516
@jyotirmayaojha6516 7 жыл бұрын
how do we know that a particular entry gives the physical address or is just another redirection to other page tables?
@M_Dragon
@M_Dragon 8 жыл бұрын
thank you so much!
@wolfcompany2
@wolfcompany2 3 жыл бұрын
5:16 How does 0000 0000 01 = 3 ? Because 0000 0000 01 is technically 0000 0000 0100 = 4 ? So shouldnt this be pointing to 0x0004 instead?
@parasvaish3239
@parasvaish3239 2 жыл бұрын
ig we are not matching tags over here instead we are using the value 0000 0000 01 as an offset from 1st memory location
@ppugalia9000
@ppugalia9000 4 жыл бұрын
Wow.. this paging mechanism is cool
@dharmikmistry8781
@dharmikmistry8781 4 жыл бұрын
awesome. thank you so much sir
@przemek4101
@przemek4101 8 жыл бұрын
Will you make a video about EPT in Intel CPUs (SLAT in other words).
@primitzisgate7
@primitzisgate7 8 жыл бұрын
what if we have N level page tables with TLB.Does it mean that first we look on TLB for the translation and if that fails then we go from 1 -> N level to find Physical Address ??
@munipallynaveenkumar9866
@munipallynaveenkumar9866 8 жыл бұрын
Thank you Very Much
@jenweatherwax7113
@jenweatherwax7113 4 жыл бұрын
Life saver!
@inordirectional
@inordirectional 6 жыл бұрын
Something I don't completely understand is how page table entries can point to disk in a fine-grained enough way. That is, what is actually in a page-table entry that is a reference to disk memory? Since page table entries are typically not that many bits long, they can't address the whole disk, which could be 1000GB, can they?
@raghavsrinivas9455
@raghavsrinivas9455 4 жыл бұрын
kzbin.info/www/bejne/qoGafYyYe9eeZ5I
@abhinavaman8008
@abhinavaman8008 3 жыл бұрын
I think we have page tables for each process. so number of entries in a page table is equal to the number of pages a process have not the number of pages secondary memory have. so 4MB would be the size if we have a page table for the entire secondary memory.
@abhijeetchauhan4111
@abhijeetchauhan4111 6 жыл бұрын
In last question, what is the size for each application?
@MyHarindu
@MyHarindu 8 жыл бұрын
if the logical address is 64 bits and the physical address is 32 bits . how do i calculate the no. of entries in the page table? (page size -4KB)no. of pagea doesnt match with the no. of frames right? so does some entries in the page table doesn't has ita corresponding frame no?? am i doing this wrong?
@iceszyeunicabautista3715
@iceszyeunicabautista3715 3 жыл бұрын
what is a page table? is it a RAM?
@OpenGL4ever
@OpenGL4ever Жыл бұрын
Yes, a page table is stored in RAM. But a TLB is SRAM on the CPU die.
@jstm
@jstm 7 жыл бұрын
Hi David, I want to clarify that this saves space method saves space by paging out unneeded page table to the disk, correct? For example if program A is running, then pauses, then its page table will be saved to the Disk, and when program A returns, its page table will be saved back to RAM? Also wondering why you would need 800 kb to store the 100 applications data, why wouldn't it be 1 * 4kb for the 1st level page table, and 100 * 4kb for the 2nd level page tables? Thanks
@OpenGL4ever
@OpenGL4ever Жыл бұрын
He says at 4:05 that you need 4 KiB + 4 Kib of memory for each application. This means one application needs at least 8 KiB. Then 100 applications will need 800 KiB.
@poisonza
@poisonza 9 жыл бұрын
appreciate the tutorials.. though multi level page tables need more explanation say.. single page table need 2^20 pages(page entries) ... 12 bit for offset 2 layered page tables need 2^10 pages(page entries) ? ... same 12 bit for offset since first 10 bits are used to access the second page table and second table only has 10 bits to represent the pages which is only 2^10? one of the way to make sense of this is to view 1st page table as chapters... 2^10 chapters * 2^10 pages but i am not sure whether this is the right way to think.
@aviadshiber6232
@aviadshiber6232 7 жыл бұрын
why each level need 10 bits? is that because we have total VPN of 20 bits and we divide it by 2 ? is it possible if the levels will not divide equally?
@SamMingolelli
@SamMingolelli 7 жыл бұрын
8 bits are the page table's address, and 2 are the offset within the page table. You have 2 page tables so each uses 8+2 bits = 20 bits.
@TomerS2210
@TomerS2210 6 жыл бұрын
נו מה אחי גודל דף זה ארבע קייבייט וגודל כתובת 32 ביטים זה 4 בתים. אז 4 קייבייט חלקי 4 בתים זה 1024 ביטים גודל כניסה. אז צריך 10 ביטים.
@difegui
@difegui 9 жыл бұрын
Hello! Thank you for this videos. I have a doubt: what would happen if instead of the address 0x004002204 would be 0x004003204? What happen when we find DISK in 2nd level table? I understood that all DISK parts were in 1st level in DISK Thank you!
@SrajanBhatnagar
@SrajanBhatnagar 8 жыл бұрын
+diego acetino I have the same doubt how was this number converted to bits ?
@OpenGL4ever
@OpenGL4ever Жыл бұрын
@@SrajanBhatnagar The number is in Hexadecimal. But difegui has one digit too many. A 32 bit hexadecimal number has only 8 digits.
@akshaygujare1148
@akshaygujare1148 8 жыл бұрын
Thank you
@mohamed_khoudjatelli9349
@mohamed_khoudjatelli9349 4 жыл бұрын
thank you :)
@benmarcus2577
@benmarcus2577 6 жыл бұрын
why does each program need it's own page table??
@Lisa-kk6go
@Lisa-kk6go 6 жыл бұрын
Each program has its own 32-bit virtual memory so it needs its own page table for the mapping.
@dudas6699
@dudas6699 11 ай бұрын
Holy shit, thank you for savin my ass. I finally understand
@pisanghangus2
@pisanghangus2 4 жыл бұрын
thanks
@deshanmithila6558
@deshanmithila6558 2 жыл бұрын
hi,can u plz explain how to translate 00402 to 0000 0000 01
@OpenGL4ever
@OpenGL4ever Жыл бұрын
It's a hexadecimal number. 00402000 is 0b0000 0000 0100 0000 0010 0000 0000 0000 Bit 0 to 11 is our offset = 0000 0000 0000 Bit 12 to 21 is our 2nd level table = 00 0000 0010 Bit 22 to 31 is our 1st level table = 0000 0000 01
@accio_biryani
@accio_biryani 6 жыл бұрын
You can be a great GATE tutor in India, we are short of them
@nicolastabet
@nicolastabet 8 ай бұрын
Legend
@songlinyang9248
@songlinyang9248 6 жыл бұрын
Awesome
@draganostojic6297
@draganostojic6297 Жыл бұрын
TLB miss and PT fault
@LnX53
@LnX53 8 жыл бұрын
why cant i like this video fack youtube :(
@randomTVSWE
@randomTVSWE 2 жыл бұрын
And the entries that dont go to a page table is directly mapped to physical memory?
@marinacuello7598
@marinacuello7598 Жыл бұрын
thank you so much!
@LightMinz
@LightMinz 8 жыл бұрын
Thank you
@taeukim1372
@taeukim1372 2 жыл бұрын
thanks
@w0nnafight
@w0nnafight Жыл бұрын
your welcome
Virtual Memory: 13 TLBs and Caches
8:00
David Black-Schaffer
Рет қаралды 147 М.
Virtual Memory: 3 What is Virtual Memory?
8:47
David Black-Schaffer
Рет қаралды 690 М.
진짜✅ 아님 가짜❌???
0:21
승비니 Seungbini
Рет қаралды 10 МЛН
КОНЦЕРТЫ:  2 сезон | 1 выпуск | Камызяки
46:36
ТНТ Смотри еще!
Рет қаралды 3,7 МЛН
번쩍번쩍 거리는 입
0:32
승비니 Seungbini
Рет қаралды 182 МЛН
Почему Катар богатый? #shorts
0:45
Послезавтра
Рет қаралды 2 МЛН
Virtual Memory: 5 Page Tables
6:32
David Black-Schaffer
Рет қаралды 336 М.
What's Virtual Memory? - Computerphile
22:40
Computerphile
Рет қаралды 181 М.
But, what is Virtual Memory?
20:11
Tech With Nikola
Рет қаралды 340 М.
Multi-level Paging (OS)
15:48
Casey Cole
Рет қаралды 26 М.
Segmented, Paged and Virtual Memory
7:48
Computer Science Lessons
Рет қаралды 267 М.
Modern Page Tables: Multi-Level Paging
17:24
David Evans
Рет қаралды 23 М.
AT&T Archives: The UNIX Operating System
27:27
AT&T Tech Channel
Рет қаралды 2 МЛН
Virtual Memory: 11 TLB Example
4:26
David Black-Schaffer
Рет қаралды 261 М.
진짜✅ 아님 가짜❌???
0:21
승비니 Seungbini
Рет қаралды 10 МЛН