pdsim.h revision 1.1 1 1.1 yamt /* $NetBSD: pdsim.h,v 1.1 2006/10/09 12:32:46 yamt Exp $ */
2 1.1 yamt
3 1.1 yamt /*-
4 1.1 yamt * Copyright (c)2006 YAMAMOTO Takashi,
5 1.1 yamt * All rights reserved.
6 1.1 yamt *
7 1.1 yamt * Redistribution and use in source and binary forms, with or without
8 1.1 yamt * modification, are permitted provided that the following conditions
9 1.1 yamt * are met:
10 1.1 yamt * 1. Redistributions of source code must retain the above copyright
11 1.1 yamt * notice, this list of conditions and the following disclaimer.
12 1.1 yamt * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 yamt * notice, this list of conditions and the following disclaimer in the
14 1.1 yamt * documentation and/or other materials provided with the distribution.
15 1.1 yamt *
16 1.1 yamt * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17 1.1 yamt * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 1.1 yamt * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19 1.1 yamt * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20 1.1 yamt * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21 1.1 yamt * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22 1.1 yamt * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23 1.1 yamt * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24 1.1 yamt * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25 1.1 yamt * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 1.1 yamt * SUCH DAMAGE.
27 1.1 yamt */
28 1.1 yamt
29 1.1 yamt #include <sys/null.h>
30 1.1 yamt #include <sys/hash.h>
31 1.1 yamt #include <sys/queue.h>
32 1.1 yamt #include <assert.h>
33 1.1 yamt #include <stdio.h>
34 1.1 yamt #include <stdlib.h>
35 1.1 yamt #include <string.h>
36 1.1 yamt #include <stdarg.h>
37 1.1 yamt #include <inttypes.h>
38 1.1 yamt
39 1.1 yamt #define PAGE_SHIFT 12
40 1.1 yamt #define PAGE_SIZE (1 << PAGE_SHIFT)
41 1.1 yamt #define PAGE_MASK (PAGE_SIZE - 1)
42 1.1 yamt
43 1.1 yamt #define PDPOL_EVCNT_DEFINE(name) int pdpol_evcnt_##name = 0;
44 1.1 yamt #define PDPOL_EVCNT_INCR(ev) pdpol_evcnt_##ev++
45 1.1 yamt
46 1.1 yamt #define TRUE 1
47 1.1 yamt #define FALSE 0
48 1.1 yamt typedef int boolean_t;
49 1.1 yamt typedef off_t voff_t;
50 1.1 yamt
51 1.1 yamt struct vm_page;
52 1.1 yamt struct vm_anon;
53 1.1 yamt
54 1.1 yamt struct uvm_object;
55 1.1 yamt struct vm_anon {
56 1.1 yamt struct vm_page *an_page; /* XXX */
57 1.1 yamt };
58 1.1 yamt
59 1.1 yamt struct vm_page {
60 1.1 yamt TAILQ_ENTRY(vm_page) pageq;
61 1.1 yamt struct uvm_object *uobject;
62 1.1 yamt off_t offset;
63 1.1 yamt int pqflags;
64 1.1 yamt #define PQ_SWAPBACKED (PQ_ANON|PQ_AOBJ)
65 1.1 yamt #define PQ_FREE 0x0001
66 1.1 yamt #define PQ_ANON 0x0002
67 1.1 yamt #define PQ_AOBJ 0x0004
68 1.1 yamt #define PQ_PRIVATE1 0x0100
69 1.1 yamt #define PQ_PRIVATE2 0x0200
70 1.1 yamt #define PQ_PRIVATE3 0x0400
71 1.1 yamt #define PQ_PRIVATE4 0x0800
72 1.1 yamt #define PQ_PRIVATE5 0x1000
73 1.1 yamt #define PQ_PRIVATE6 0x2000
74 1.1 yamt #define PQ_PRIVATE7 0x4000
75 1.1 yamt #define PQ_PRIVATE8 0x8000
76 1.1 yamt
77 1.1 yamt int _mdflags;
78 1.1 yamt #define MDPG_REFERENCED 1
79 1.1 yamt #define MDPG_SPECULATIVE 2
80 1.1 yamt
81 1.1 yamt /* dummy members */
82 1.1 yamt struct vm_anon *uanon;
83 1.1 yamt int wire_count;
84 1.1 yamt int flags;
85 1.1 yamt #define PG_BUSY 1
86 1.1 yamt };
87 1.1 yamt
88 1.1 yamt TAILQ_HEAD(pglist, vm_page);
89 1.1 yamt
90 1.1 yamt boolean_t pmap_clear_reference(struct vm_page *);
91 1.1 yamt boolean_t pmap_is_referenced(struct vm_page *);
92 1.1 yamt
93 1.1 yamt struct uvmexp {
94 1.1 yamt int npages;
95 1.1 yamt int pdscans;
96 1.1 yamt int freetarg;
97 1.1 yamt int free;
98 1.1 yamt
99 1.1 yamt /* XXX */
100 1.1 yamt int filepages;
101 1.1 yamt int execpages;
102 1.1 yamt int anonpages;
103 1.1 yamt int pddeact;
104 1.1 yamt int pdreact;
105 1.1 yamt };
106 1.1 yamt extern struct uvmexp uvmexp;
107 1.1 yamt
108 1.1 yamt #define UVM_LOCK_ASSERT_PAGEQ() /* nothing */
109 1.1 yamt #define KASSERT(x) assert(x)
110 1.1 yamt
111 1.1 yamt static void panic(const char *, ...) __unused;
112 1.1 yamt static void
113 1.1 yamt panic(const char *fmt, ...)
114 1.1 yamt {
115 1.1 yamt va_list ap;
116 1.1 yamt
117 1.1 yamt va_start(ap, fmt);
118 1.1 yamt vfprintf(stderr, fmt, ap);
119 1.1 yamt va_end(ap);
120 1.1 yamt fprintf(stderr, "\n");
121 1.1 yamt abort();
122 1.1 yamt }
123 1.1 yamt
124 1.1 yamt #define MAXID 102400
125 1.1 yamt
126 1.1 yamt struct uvm_object {
127 1.1 yamt struct vm_page *pages[MAXID];
128 1.1 yamt };
129 1.1 yamt
130 1.1 yamt struct uvm_pctparam {
131 1.1 yamt int pct_pct;
132 1.1 yamt };
133 1.1 yamt #define UVM_PCTPARAM_APPLY(pct, x) \
134 1.1 yamt (((x) * (pct)->pct_pct) / 100)
135 1.1 yamt #define uvm_pctparam_init(pct, x, f) (pct)->pct_pct = x
136 1.1 yamt
137 1.1 yamt #define UVM_OBJ_IS_VTEXT(o) FALSE
138 1.1 yamt #define UVM_OBJ_IS_AOBJ(o) FALSE
139 1.1 yamt #define UVM_OBJ_IS_VNODE(o) TRUE
140 1.1 yamt
141 1.1 yamt #define uvm_swapisfull() TRUE
142 1.1 yamt #define uvmpd_trydropswap(p) (panic("dropswap"), 0)
143 1.1 yamt
144 1.1 yamt #define MAX(a,b) (((a) > (b)) ? (a) : (b))
145 1.1 yamt #define MIN(a,b) (((a) < (b)) ? (a) : (b))
146 1.1 yamt
147 1.1 yamt #if ((__STDC_VERSION__ - 0) >= 199901L)
148 1.1 yamt #define WARN(...) fprintf(stderr, __VA_ARGS__)
149 1.1 yamt #else /* ((__STDC_VERSION__ - 0) >= 199901L) */
150 1.1 yamt #define WARN(a...) fprintf(stderr, a)
151 1.1 yamt #endif /* ((__STDC_VERSION__ - 0) >= 199901L) */
152 1.1 yamt
153 1.1 yamt #if defined(DEBUG)
154 1.1 yamt #if ((__STDC_VERSION__ - 0) >= 199901L)
155 1.1 yamt #define DPRINTF(...) printf(__VA_ARGS__)
156 1.1 yamt #else /* ((__STDC_VERSION__ - 0) >= 199901L) */
157 1.1 yamt #define DPRINTF(a...) printf(a) /* GCC */
158 1.1 yamt #endif /* ((__STDC_VERSION__ - 0) >= 199901L) */
159 1.1 yamt #define dump(s) pdsim_dump(s)
160 1.1 yamt void dump(const char *);
161 1.1 yamt #else
162 1.1 yamt #if ((__STDC_VERSION__ - 0) >= 199901L)
163 1.1 yamt #define DPRINTF(...) /* nothing */
164 1.1 yamt #else /* ((__STDC_VERSION__ - 0) >= 199901L) */
165 1.1 yamt #define DPRINTF(a...) /* nothing */ /* GCC */
166 1.1 yamt #endif /* ((__STDC_VERSION__ - 0) >= 199901L) */
167 1.1 yamt #define dump(s) /* nothing */
168 1.1 yamt #endif
169 1.1 yamt
170 1.1 yamt #include "uvm/uvm_pdpolicy.h"
171