2008-11-19 13:26:10 +01:00
|
|
|
|
|
|
|
#ifndef _PAGETABLE_H
|
|
|
|
#define _PAGETABLE_H 1
|
|
|
|
|
|
|
|
#include <stdint.h>
|
2010-03-08 12:04:59 +01:00
|
|
|
#include <machine/vm.h>
|
2008-11-19 13:26:10 +01:00
|
|
|
|
2010-03-22 22:25:22 +01:00
|
|
|
#include "vm.h"
|
2009-09-21 16:49:49 +02:00
|
|
|
|
2008-11-19 13:26:10 +01:00
|
|
|
/* An i386 pagetable. */
|
|
|
|
typedef struct {
|
|
|
|
/* Directory entries in VM addr space - root of page table. */
|
|
|
|
u32_t *pt_dir; /* page aligned (I386_VM_DIR_ENTRIES) */
|
|
|
|
u32_t pt_dir_phys; /* physical address of pt_dir */
|
|
|
|
|
|
|
|
/* Pointers to page tables in VM address space. */
|
|
|
|
u32_t *pt_pt[I386_VM_DIR_ENTRIES];
|
|
|
|
|
|
|
|
/* When looking for a hole in virtual address space, start
|
|
|
|
* looking here. This is in linear addresses, i.e.,
|
|
|
|
* not as the process sees it but the position in the page
|
|
|
|
* page table. This is just a hint.
|
|
|
|
*/
|
|
|
|
u32_t pt_virtop;
|
|
|
|
} pt_t;
|
|
|
|
|
|
|
|
/* Mapping flags. */
|
|
|
|
#define PTF_WRITE I386_VM_WRITE
|
|
|
|
#define PTF_PRESENT I386_VM_PRESENT
|
|
|
|
#define PTF_USER I386_VM_USER
|
2009-04-23 17:11:16 +02:00
|
|
|
#define PTF_GLOBAL I386_VM_GLOBAL
|
2008-11-19 13:26:10 +01:00
|
|
|
#define PTF_MAPALLOC I386_VM_PTAVAIL1 /* Page allocated by pt code. */
|
2010-04-13 13:08:08 +02:00
|
|
|
#define PTF_NOCACHE (I386_VM_PWT | I386_VM_PCD)
|
2008-11-19 13:26:10 +01:00
|
|
|
|
|
|
|
/* For arch-specific PT routines to check if no bits outside
|
|
|
|
* the regular flags are set.
|
|
|
|
*/
|
2010-04-13 13:08:08 +02:00
|
|
|
#define PTF_ALLFLAGS (PTF_WRITE|PTF_PRESENT|PTF_USER|PTF_GLOBAL|PTF_NOCACHE)
|
2008-11-19 13:26:10 +01:00
|
|
|
|
2009-09-21 16:49:49 +02:00
|
|
|
#if SANITYCHECKS
|
|
|
|
#define PT_SANE(p) { pt_sanitycheck((p), __FILE__, __LINE__); }
|
|
|
|
#else
|
|
|
|
#define PT_SANE(p)
|
|
|
|
#endif
|
|
|
|
|
2008-11-19 13:26:10 +01:00
|
|
|
#endif
|
|
|
|
|
2009-09-21 16:49:49 +02:00
|
|
|
|