Can I access unmapped pages from the fault handler?

Question about which tools to use, bugs, the best way to implement a function, etc should go here. Don't forget to see if your question is answered in the wiki first! When in doubt post here.
Post Reply
User avatar
~
Member
Member
Posts: 1228
Joined: Tue Mar 06, 2007 11:17 am
Libera.chat IRC: ArcheFire

Can I access unmapped pages from the fault handler?

Post by ~ »

Can I access unmapped addresses from the page fault handler?

Or do I need to disable paging entirely in CR0 (bit 31==0)?
alexfru
Member
Member
Posts: 1112
Joined: Tue Mar 04, 2014 5:27 am

Re: Can I access unmapped pages from the fault handler?

Post by alexfru »

You need to have a mapping or disabled page translation in order to access RAM.
linguofreak
Member
Member
Posts: 510
Joined: Wed Mar 09, 2011 3:55 am

Re: Can I access unmapped pages from the fault handler?

Post by linguofreak »

~ wrote:Can I access unmapped addresses from the page fault handler?

Or do I need to disable paging entirely in CR0 (bit 31==0)?
If you mean "When I get a not-present fault for a virtual address, can I access the faulting virtual address from the page fault handler?", then the answer is, by definition, no. You haven't told the MMU what physical page you want mapped to that virtual address, so that address doesn't correspond to any actual memory, so there's nothing at that address to access. Even disabling paging won't help, because all that will do is access a physical address for you, but that physical address won't be related in any way to the faulting virtual address, other than that they happen to be represented by the same string of bits.

If you mean, "Can I access arbitrary pages of physical memory from a page fault handler, such as the page I plan to use for a virtual address that's being swapped in?", the the answer is "not directly by their physical address, but you can map them in the course of handling the page fault, or, if physical memory is much smaller than the available virtual address space, you can premap all of physical memory at some offset in kernelspace".
User avatar
Octacone
Member
Member
Posts: 1138
Joined: Fri Aug 07, 2015 6:13 am

Re: Can I access unmapped pages from the fault handler?

Post by Octacone »

If you want to find out the exact address at which the fault has occurred just look it up in CR2.
If you want to know if you can access that specific faulty address, then it depends. If the address was mapped, it can be done. If the address wasn't mapped, then why would you?
OS: Basic OS
About: 32 Bit Monolithic Kernel Written in C++ and Assembly, Custom FAT 32 Bootloader
User avatar
~
Member
Member
Posts: 1228
Joined: Tue Mar 06, 2007 11:17 am
Libera.chat IRC: ArcheFire

Re: Can I access unmapped pages from the fault handler?

Post by ~ »

My page directory and page tables are never mapped in any virtual address (they are invisible to any actual code and data).

It avoids polluting the virtual address space with paging structures that are dummies from the point of view of a process.

If I request a non-existent page table entry, it page faults and I cannot access paging structures in any way without disabling paging because they will never be virtually mapped for any reason. So I need to disable paging to modify the page entries.

For example I map around the first physical 1.5MB for my current kernel, but if I want to malloc(15) a test space at 100MB, it page faults with all paging structures themselves fully unmapped to avoid polluting my virtual address space for nothing.

If paging structures support working from virtually unmapped regions outside page tables, they probably are meant to be kept like that to make more virtual space, and disabling PG bit 31 at CR0 probably doesn't affect the cache.

Just disabling paging is probably faster than having to map new things with a visor page, if priorities are taken into account when requests to allocate or free RAM are made.
User avatar
iansjack
Member
Member
Posts: 4705
Joined: Sat Mar 31, 2012 3:07 am
Location: Chichester, UK

Re: Can I access unmapped pages from the fault handler?

Post by iansjack »

I've got to say that that sounds a particularly inefficient methodology. Also it constrains you to place your kernel in any identity mapped space.

Why not just have a map of all physical memory accessible only to the kernel? That solves a lot of problems and is very versatile.
User avatar
~
Member
Member
Posts: 1228
Joined: Tue Mar 06, 2007 11:17 am
Libera.chat IRC: ArcheFire

Re: Can I access unmapped pages from the fault handler?

Post by ~ »

I have a bitmap for all physical RAM that is always identity mapped and will never be swapped to disk.

The page tables are unmapped, but I know which bits to free from the bitmap by inspecting the physical addresses in the paging structures.

Since the page directory and page tables are always unmapped, I need to disable paging to allocate or free pages (mapping them to temporary visor pages probably wouldn't speed up the system in this case compared to remap them fast and disable paging only for instructions that do the trick), but in exchange I don't pollute my virtual space randomly by adding page tables when I can leave them out.

User programs allocate in 4-page blocks, and single-page allocations for paging are individual although affected by 4-page alignment. But having always 4 contiguous pages can speed up by reducing fragmentation. 4 pages are marked at once for application-type allocations, but only 1 page is marked at once for paging structures from the paged memory manager, so I know that a nibble in the memory bitmap with 1's and 0's is from the memory manager, and all 1's nibbles are reserved by actual programs.
Octocontrabass
Member
Member
Posts: 5581
Joined: Mon Mar 25, 2013 7:01 pm

Re: Can I access unmapped pages from the fault handler?

Post by Octocontrabass »

~ wrote:Since the page directory and page tables are always unmapped, I need to disable paging to allocate or free pages (mapping them to temporary visor pages probably wouldn't speed up the system in this case compared to remap them fast and disable paging only for instructions that do the trick), but in exchange I don't pollute my virtual space randomly by adding page tables when I can leave them out.
Disabling paging flushes the TLB. Flushing the TLB is extremely slow! Using INVLPG to flush single pages from the TLB is much, much faster.

If you're worried about polluting your virtual address space, perhaps you'd like recursive mapping. With recursive mapping, only the currently active page tables are mapped, and they're always mapped to a fixed virtual address.
User avatar
iansjack
Member
Member
Posts: 4705
Joined: Sat Mar 31, 2012 3:07 am
Location: Chichester, UK

Re: Can I access unmapped pages from the fault handler?

Post by iansjack »

~ wrote:4 pages are marked at once for application-type allocations, but only 1 page is marked at once for paging structures from the paged memory manager, so I know that a nibble in the memory bitmap with 1's and 0's is from the memory manager, and all 1's nibbles are reserved by actual programs.
How do you know that all 1s isn't 4 pages for paging structures?
User avatar
~
Member
Member
Posts: 1228
Joined: Tue Mar 06, 2007 11:17 am
Libera.chat IRC: ArcheFire

Re: Can I access unmapped pages from the fault handler?

Post by ~ »

iansjack wrote:
~ wrote:4 pages are marked at once for application-type allocations, but only 1 page is marked at once for paging structures from the paged memory manager, so I know that a nibble in the memory bitmap with 1's and 0's is from the memory manager, and all 1's nibbles are reserved by actual programs.
How do you know that all 1s isn't 4 pages for paging structures?
No pointers point to them other than paging (maybe other hardware things in the future), so nothing will deallocate them (they won't be requested).

The allocator only cares about finding free 4-page blocks marked at once for applications and 1 page for paging (the allocator won't allocate a partially-allocated 4-page block for applications, only for paging).

I only disable paging at the point where an instruction will actually affect unmapped paging structures, and then I reenable it along with interrupts, so other processes and IRQs have a normal chance of running.

I will have to run formal programs to see if the execution speed is normal, but I need to investigate it to the end of implementation.
Post Reply