summaryrefslogtreecommitdiff
path: root/sys/vm/vm_page.h
diff options
context:
space:
mode:
Diffstat (limited to 'sys/vm/vm_page.h')
-rw-r--r--sys/vm/vm_page.h185
1 files changed, 2 insertions, 183 deletions
diff --git a/sys/vm/vm_page.h b/sys/vm/vm_page.h
index 299ca111e9f..782dfb6e027 100644
--- a/sys/vm/vm_page.h
+++ b/sys/vm/vm_page.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: vm_page.h,v 1.12 2001/04/07 17:13:44 niklas Exp $ */
+/* $OpenBSD: vm_page.h,v 1.13 2001/06/27 04:52:40 art Exp $ */
/* $NetBSD: vm_page.h,v 1.24 1998/02/10 14:09:03 mrg Exp $ */
/*
@@ -96,7 +96,6 @@
* queues (P) [or both].
*/
-#if defined(UVM)
/*
* locking note: the mach version of this data structure had bit
* fields for the flags, and the bit fields were divided into two
@@ -110,7 +109,6 @@
*/
#include <uvm/uvm_extern.h>
-#endif /* UVM */
#include <vm/pglist.h>
struct vm_page {
@@ -119,12 +117,8 @@ struct vm_page {
TAILQ_ENTRY(vm_page) hashq; /* hash table links (O)*/
TAILQ_ENTRY(vm_page) listq; /* pages in same object (O)*/
-#if !defined(UVM) /* uvm uses obju */
- vm_object_t object; /* which object am I in (O,P)*/
-#endif
vaddr_t offset; /* offset into object (O,P) */
-#if defined(UVM)
struct uvm_object *uobject; /* object (O,P) */
struct vm_anon *uanon; /* anon (O,P) */
u_short flags; /* object flags [O] */
@@ -134,13 +128,9 @@ struct vm_page {
u_int loan_count; /* number of active loans
* to read: [O or P]
* to modify: [O _and_ P] */
-#else
- u_short wire_count; /* wired down maps refs (P) */
- u_short flags; /* see below */
-#endif
paddr_t phys_addr; /* physical address of page */
-#if defined(UVM) && defined(UVM_PAGE_TRKOWN)
+#if defined(UVM_PAGE_TRKOWN)
/* debugging fields to track page ownership */
pid_t owner; /* proc that set PG_BUSY */
char *owner_tag; /* why it was set busy */
@@ -152,7 +142,6 @@ struct vm_page {
*
* Note: PG_FILLED and PG_DIRTY are added for the filesystems.
*/
-#if defined(UVM)
/*
* locking rules:
@@ -184,35 +173,6 @@ struct vm_page {
#define PQ_SWAPBACKED (PQ_ANON|PQ_AOBJ)
#define PQ_ENCRYPT 0x0040 /* page needs {en,de}cryption */
-#else
-#define PG_INACTIVE 0x0001 /* page is in inactive list (P) */
-#define PG_ACTIVE 0x0002 /* page is in active list (P) */
-#define PG_LAUNDRY 0x0004 /* page is being cleaned now (P) */
-#define PG_CLEAN 0x0008 /* page has not been modified
- There exists a case where this bit
- will be cleared, although the page
- is not physically dirty, which is
- when a collapse operation moves
- pages between two different pagers.
- The bit is then used as a marker
- for the pageout daemon to know it
- should be paged out into the target
- pager. */
-#define PG_BUSY 0x0010 /* page is in transit (O) */
-#define PG_WANTED 0x0020 /* someone is waiting for page (O) */
-#define PG_TABLED 0x0040 /* page is in VP table (O) */
-#define PG_COPYONWRITE 0x0080 /* must copy page before changing (O) */
-#define PG_FICTITIOUS 0x0100 /* physical page doesn't exist (O) */
-#define PG_FAKE 0x0200 /* page is placeholder for pagein (O) */
-#define PG_FILLED 0x0400 /* client flag to set when filled */
-#define PG_DIRTY 0x0800 /* client flag to set when dirty */
-#define PG_FREE 0x1000 /* XXX page is on free list */
-#define PG_FAULTING 0x2000 /* page is being faulted in */
-#define PG_PAGEROWNED 0x4000 /* DEBUG: async paging op in progress */
-#define PG_PTPAGE 0x8000 /* DEBUG: is a user page table page */
-#endif
-
-#if defined(MACHINE_NEW_NONCONTIG)
/*
* physical memory layout structure
*
@@ -239,16 +199,12 @@ struct vm_physseg {
vaddr_t end; /* (PF# of last page in segment) + 1 */
vaddr_t avail_start; /* PF# of first free page in segment */
vaddr_t avail_end; /* (PF# of last free page in segment) +1 */
-#if defined(UVM)
int free_list; /* which free list they belong on */
-#endif
struct vm_page *pgs; /* vm_page structures (from start) */
struct vm_page *lastpg; /* vm_page structure for end */
struct pmap_physseg pmseg; /* pmap specific (MD) data */
};
-#endif /* MACHINE_NEW_NONCONTIG */
-
#if defined(_KERNEL)
/*
@@ -274,9 +230,6 @@ struct pglist vm_page_queue_active; /* active memory queue */
extern
struct pglist vm_page_queue_inactive; /* inactive memory queue */
-
-#if defined(MACHINE_NEW_NONCONTIG)
-
/*
* physical memory config is stored in vm_physmem.
*/
@@ -284,89 +237,18 @@ struct pglist vm_page_queue_inactive; /* inactive memory queue */
extern struct vm_physseg vm_physmem[VM_PHYSSEG_MAX];
extern int vm_nphysseg;
-#else
-#if defined(MACHINE_NONCONTIG)
-/* OLD NONCONTIG CODE: NUKE NUKE NUKE ONCE CONVERTED */
-extern
-u_long first_page; /* first physical page number */
-extern
-int vm_page_count; /* How many pages do we manage? */
-extern
-vm_page_t vm_page_array; /* First resident page in table */
-
-#define VM_PAGE_INDEX(pa) \
- (pmap_page_index((pa)) - first_page)
-#else
-/* OLD CONTIG CODE: NUKE NUKE NUKE ONCE CONVERTED */
-extern
-long first_page; /* first physical page number */
- /* ... represented in vm_page_array */
-extern
-long last_page; /* last physical page number */
- /* ... represented in vm_page_array */
- /* [INCLUSIVE] */
-extern
-vm_offset_t first_phys_addr; /* physical address for first_page */
-extern
-vm_offset_t last_phys_addr; /* physical address for last_page */
-extern
-vm_page_t vm_page_array; /* First resident page in table */
-
-#define VM_PAGE_INDEX(pa) \
- (atop((pa)) - first_page)
-
-#endif /* MACHINE_NONCONTIG */
-#endif /* MACHINE_NEW_NONCONTIG */
-
/*
* prototypes
*/
-#if defined(MACHINE_NEW_NONCONTIG)
static struct vm_page *PHYS_TO_VM_PAGE __P((paddr_t));
static int vm_physseg_find __P((paddr_t, int *));
-#endif
-
-#if !defined(UVM)
-void vm_page_activate __P((vm_page_t));
-vm_page_t vm_page_alloc __P((vm_object_t, vm_offset_t));
-vm_offset_t vm_page_alloc_contig(vm_offset_t, vm_offset_t,
- vm_offset_t, vm_offset_t);
-int vm_page_alloc_memory __P((vm_size_t size, vm_offset_t low,
- vm_offset_t high, vm_offset_t alignment, vm_offset_t boundary,
- struct pglist *rlist, int nsegs, int waitok));
-void vm_page_free_memory __P((struct pglist *list));
-#if defined(MACHINE_NONCONTIG) || defined(MACHINE_NEW_NONCONTIG)
-void vm_page_bootstrap __P((vm_offset_t *, vm_offset_t *));
-vm_offset_t vm_bootstrap_steal_memory __P((vm_size_t));
-#endif
-void vm_page_copy __P((vm_page_t, vm_page_t));
-void vm_page_deactivate __P((vm_page_t));
-void vm_page_free __P((vm_page_t));
-void vm_page_insert __P((vm_page_t, vm_object_t, vm_offset_t));
-vm_page_t vm_page_lookup __P((vm_object_t, vm_offset_t));
-#if defined(MACHINE_NEW_NONCONTIG)
-void vm_page_physload __P((vm_offset_t, vm_offset_t,
- vm_offset_t, vm_offset_t));
-void vm_page_physrehash __P((void));
-#endif
-void vm_page_remove __P((vm_page_t));
-void vm_page_rename __P((vm_page_t, vm_object_t, vm_offset_t));
-#if !defined(MACHINE_NONCONTIG) && !defined(MACHINE_NEW_NONCONTIG)
-void vm_page_startup __P((vm_offset_t *, vm_offset_t *));
-#endif
-void vm_page_unwire __P((vm_page_t));
-void vm_page_wire __P((vm_page_t));
-boolean_t vm_page_zero_fill __P((vm_page_t));
-#endif
/*
* macros and inlines
*/
#define VM_PAGE_TO_PHYS(entry) ((entry)->phys_addr)
-#if defined(MACHINE_NEW_NONCONTIG)
-
/*
* when VM_PHYSSEG_MAX is 1, we can simplify these functions
*/
@@ -470,36 +352,8 @@ PHYS_TO_VM_PAGE(pa)
return(NULL);
}
-#elif defined(MACHINE_NONCONTIG)
-
-/* OLD NONCONTIG CODE: NUKE NUKE NUKE ONCE CONVERTED */
-#define IS_VM_PHYSADDR(pa) \
- (pmap_page_index(pa) >= 0)
-
-#define PHYS_TO_VM_PAGE(pa) \
- (&vm_page_array[pmap_page_index(pa) - first_page])
-
-#else
-
-/* OLD CONTIG CODE: NUKE NUKE NUKE ONCE CONVERTED */
-#define IS_VM_PHYSADDR(pa) \
- ((pa) >= first_phys_addr && (pa) <= last_phys_addr)
-
-#define PHYS_TO_VM_PAGE(pa) \
- (&vm_page_array[atop(pa) - first_page ])
-
-#endif /* (OLD) MACHINE_NONCONTIG */
-
-#if defined(UVM)
-
#define VM_PAGE_IS_FREE(entry) ((entry)->pqflags & PQ_FREE)
-#else /* UVM */
-
-#define VM_PAGE_IS_FREE(entry) ((entry)->flags & PG_FREE)
-
-#endif /* UVM */
-
extern
simple_lock_data_t vm_page_queue_lock; /* lock on active and inactive
page queues */
@@ -527,13 +381,6 @@ simple_lock_data_t vm_page_queue_free_lock;
/*
* XXXCDC: different versions of this should die
*/
-#if !defined(MACHINE_NONCONTIG) && !defined(MACHINE_NEW_NONCONTIG)
-#define VM_PAGE_INIT(mem, obj, offset) { \
- (mem)->flags = PG_BUSY | PG_CLEAN | PG_FAKE; \
- vm_page_insert((mem), (obj), (offset)); \
- (mem)->wire_count = 0; \
-}
-#else /* MACHINE_NONCONTIG */
#define VM_PAGE_INIT(mem, obj, offset) { \
(mem)->flags = PG_BUSY | PG_CLEAN | PG_FAKE; \
if (obj) \
@@ -542,10 +389,8 @@ simple_lock_data_t vm_page_queue_free_lock;
(mem)->object = NULL; \
(mem)->wire_count = 0; \
}
-#endif /* MACHINE_NONCONTIG */
#if VM_PAGE_DEBUG
-#if defined(MACHINE_NEW_NONCONTIG)
/*
* VM_PAGE_CHECK: debugging check of a vm_page structure
@@ -567,32 +412,6 @@ VM_PAGE_CHECK(mem)
return;
}
-#elif defined(MACHINE_NONCONTIG)
-
-/* OLD NONCONTIG CODE: NUKE NUKE NUKE ONCE CONVERTED */
-#define VM_PAGE_CHECK(mem) { \
- if ((((unsigned int) mem) < ((unsigned int) &vm_page_array[0])) || \
- (((unsigned int) mem) > \
- ((unsigned int) &vm_page_array[vm_page_count])) || \
- ((mem->flags & (PG_ACTIVE | PG_INACTIVE)) == \
- (PG_ACTIVE | PG_INACTIVE))) \
- panic("vm_page_check: not valid!"); \
-}
-
-#else
-
-/* OLD CONTIG CODE: NUKE NUKE NUKE ONCE CONVERTED */
-#define VM_PAGE_CHECK(mem) { \
- if ((((unsigned int) mem) < ((unsigned int) &vm_page_array[0])) || \
- (((unsigned int) mem) > \
- ((unsigned int) &vm_page_array[last_page-first_page])) || \
- ((mem->flags & (PG_ACTIVE | PG_INACTIVE)) == \
- (PG_ACTIVE | PG_INACTIVE))) \
- panic("vm_page_check: not valid!"); \
-}
-
-#endif
-
#else /* VM_PAGE_DEBUG */
#define VM_PAGE_CHECK(mem)
#endif /* VM_PAGE_DEBUG */