FreeNOS
IntelPageTable.cpp
Go to the documentation of this file.
1/*
2 * Copyright (C) 2015 Niek Linnenbank
3 *
4 * This program is free software: you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation, either version 3 of the License, or
7 * (at your option) any later version.
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program. If not, see <http://www.gnu.org/licenses/>.
16 */
17
18#include "IntelConstant.h"
19#include "IntelPageTable.h"
20
21#define PAGE_NONE 0
22#define PAGE_PRESENT 1
23#define PAGE_READ 0
24#define PAGE_EXEC 0
25#define PAGE_WRITE 2
26#define PAGE_USER 4
27
35#define TABENTRY(vaddr) \
36 (((vaddr) >> PAGESHIFT) & 0x3ff)
37
39 Address phys,
40 Memory::Access access)
41{
42 // Check if the address is already mapped
43 if (m_pages[ TABENTRY(virt) ] & PAGE_PRESENT)
45
46 // Insert mapping
47 m_pages[ TABENTRY(virt) ] = phys | PAGE_PRESENT | flags(access);
49}
50
56
58{
59 if (!(m_pages[ TABENTRY(virt) ] & PAGE_PRESENT))
61
62 *phys = (m_pages[ TABENTRY(virt) ] & PAGEMASK);
64}
65
80
82{
83 u32 f = 0;
84
86 if (access & Memory::User) f |= PAGE_USER;
87
88 return f;
89}
#define TABENTRY(vaddr)
Entry inside the page table of a given virtual address.
u32 entry[]
Definition IntelACPI.h:1
u32 flags
Definition IntelACPI.h:3
#define PAGE_PRESENT
#define PAGE_USER
#define PAGE_WRITE
#define PAGE_NONE
MemoryContext::Result map(Address virt, Address phys, Memory::Access access)
Map a virtual address to a physical address.
MemoryContext::Result access(Address virt, Memory::Access *access) const
Get Access flags for a virtual address.
u32 m_pages[1024]
Array of page table entries.
MemoryContext::Result translate(Address virt, Address *phys) const
Translate virtual address to physical address.
u32 flags(Memory::Access access) const
Convert MemoryAccess to page table flags.
MemoryContext::Result unmap(Address virt)
Remove virtual address mapping.
Result
Result codes.
#define PAGEMASK
Mask to find the page.
unsigned int u32
Unsigned 32-bit number.
Definition Types.h:53
unsigned long Address
A memory address.
Definition Types.h:131
Access
Memory access flags.
Definition Memory.h:39
@ User
Definition Memory.h:44
@ Readable
Definition Memory.h:41
@ Writable
Definition Memory.h:42