Page 1 of 1
What to do with the rest of the pages?
Posted: Tue May 02, 2017 10:33 am
by ThisMayWork
Hello everyone!
My kernel is now able to manage physical memory (using a bitmap), I enabled paging and I can also map virtual to physical addresses. I identity-mapped the first 4MB so I can use the video buffer and to prevent anything below 1MB from going crazy and I also mapped my kernel to 3GB. For that, I used two page tables (which are allocated using my physical memory manager). My question is, what do I do with the rest of the virtual memory addresses? Do I identity map them as well?
Re: What to do with the rest of the pages?
Posted: Tue May 02, 2017 10:52 am
by Boris
Think not in pages but in memory regions.
Your kernel and apps will want a stack, heap, and manually mapped regions.
Decide where they should go. Then imagine allocator for them.
Tips :
- stack grows downwards. Many threads = many stacks.
- you can have holes in the heap
Re: What to do with the rest of the pages?
Posted: Tue May 02, 2017 11:45 am
by iansjack
You map virtual addresses to physical pages as and when you need to use the memory.
Re: What to do with the rest of the pages?
Posted: Wed May 03, 2017 6:16 am
by ThisMayWork
Until I get to the stage of a heap allocator, or even plan the memory layout, what is the "typical" approach to handle the "free" pages? Let's say that for some reason my kernel starts behaving unexpectedly (happens quite often
) and overwrites part of the memory it is not supposed to. If the pages are identity-mapped, will it be easier for me to debug? Thank you for your answers!
EDIT: I realize what I am asking might be a little vague and a matter of personal preference but I would appreciate some tips and pointers.
Re: What to do with the rest of the pages?
Posted: Wed May 03, 2017 6:55 am
by Kevin
Pages that you don't intend to use shouldn't be mapped at all. Then accessing them will cause a Page Fault, which is relatively easy to debug.
Re: What to do with the rest of the pages?
Posted: Wed May 03, 2017 7:04 am
by Brendan
Hi,
ThisMayWork wrote:My kernel is now able to manage physical memory (using a bitmap), I enabled paging and I can also map virtual to physical addresses. I identity-mapped the first 4MB so I can use the video buffer and to prevent anything below 1MB from going crazy and I also mapped my kernel to 3GB. For that, I used two page tables (which are allocated using my physical memory manager). My question is, what do I do with the rest of the virtual memory addresses? Do I identity map them as well?
Typically the first thing you do is split virtual address spaces into zones - maybe one huge area for processes (e.g. "user space" from 0x00000000 to 0xBFFFFFFFF) and another huge area for the kernel itself (e.g. "kernel space" from 0xC0000000 to 0xFFFFFFFF).
Then those zones are split into "sub-zones". More specifically; "user space" is split into sub-zones by the process (e.g. into ".text", ".rodata", ".data" and ".bss" by the linker script, and then the remainder used for shared libraries and/or garbage collection and/or malloc/free and/or whatever the process feels like) where how user-space is split up into sub-zones is none of the kernel's concern (kernel only provides functionality that allows a process to do whatever it wants); and kernel space is split into sub-zones by the kernel (e.g. into ".text", ".rodata", ".data" and ".bss" by the kernel's linker script, and then the remainder used for kernel modules and/or garbage collection and/or malloc/free and/or whatever the kernel feels like).
For an example, for my micro-kernels I always use one part of kernel-space (e.g. from 0xFFC00000 to 0xFFFFFFFF) for
"recursive mapping" page tables (to make virtual memory management easier), and another (relatively large) part of kernel-space (e.g. from 0xC0000000 to 0xDFFFFFFF) for message buffers (where this "message buffer area" is managed explicitly by my kernel's message handling code).
ThisMayWork wrote:Until I get to the stage of a heap allocator, or even plan the memory layout, what is the "typical" approach to handle the "free" pages?
Typically, if you have no use for an area of the virtual address space then you leave that area marked as "not present" in page tables, etc; so that if software accesses something it shouldn't it causes a page fault, which increase the chance of detecting bugs (e.g. dodgy pointers, etc).
Cheers,
Brendan