Home | History | Annotate | Line # | Download | only in uvm
uvm_extern.h revision 1.232.12.1
      1  1.232.12.1    martin /*	$NetBSD: uvm_extern.h,v 1.232.12.1 2025/05/09 12:59:58 martin Exp $	*/
      2         1.1       mrg 
      3         1.1       mrg /*
      4         1.1       mrg  * Copyright (c) 1997 Charles D. Cranor and Washington University.
      5         1.1       mrg  * All rights reserved.
      6         1.1       mrg  *
      7         1.1       mrg  * Redistribution and use in source and binary forms, with or without
      8         1.1       mrg  * modification, are permitted provided that the following conditions
      9         1.1       mrg  * are met:
     10         1.1       mrg  * 1. Redistributions of source code must retain the above copyright
     11         1.1       mrg  *    notice, this list of conditions and the following disclaimer.
     12         1.1       mrg  * 2. Redistributions in binary form must reproduce the above copyright
     13         1.1       mrg  *    notice, this list of conditions and the following disclaimer in the
     14         1.1       mrg  *    documentation and/or other materials provided with the distribution.
     15         1.1       mrg  *
     16         1.1       mrg  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
     17         1.1       mrg  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     18         1.1       mrg  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     19         1.1       mrg  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
     20         1.1       mrg  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
     21         1.1       mrg  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
     22         1.1       mrg  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
     23         1.1       mrg  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
     24         1.1       mrg  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
     25         1.1       mrg  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     26         1.4       mrg  *
     27         1.4       mrg  * from: Id: uvm_extern.h,v 1.1.2.21 1998/02/07 01:16:53 chs Exp
     28         1.1       mrg  */
     29         1.1       mrg 
     30        1.44       mrg /*-
     31        1.45       mrg  * Copyright (c) 1991, 1992, 1993
     32        1.44       mrg  *	The Regents of the University of California.  All rights reserved.
     33        1.44       mrg  *
     34        1.44       mrg  * Redistribution and use in source and binary forms, with or without
     35        1.44       mrg  * modification, are permitted provided that the following conditions
     36        1.44       mrg  * are met:
     37        1.44       mrg  * 1. Redistributions of source code must retain the above copyright
     38        1.44       mrg  *    notice, this list of conditions and the following disclaimer.
     39        1.44       mrg  * 2. Redistributions in binary form must reproduce the above copyright
     40        1.44       mrg  *    notice, this list of conditions and the following disclaimer in the
     41        1.44       mrg  *    documentation and/or other materials provided with the distribution.
     42        1.83       agc  * 3. Neither the name of the University nor the names of its contributors
     43        1.44       mrg  *    may be used to endorse or promote products derived from this software
     44        1.44       mrg  *    without specific prior written permission.
     45        1.44       mrg  *
     46        1.44       mrg  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     47        1.44       mrg  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     48        1.44       mrg  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     49        1.44       mrg  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     50        1.44       mrg  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     51        1.44       mrg  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     52        1.44       mrg  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     53        1.44       mrg  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     54        1.44       mrg  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     55        1.44       mrg  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     56        1.44       mrg  * SUCH DAMAGE.
     57        1.44       mrg  *
     58        1.44       mrg  *	@(#)vm_extern.h	8.5 (Berkeley) 5/3/95
     59        1.44       mrg  */
     60        1.44       mrg 
     61         1.8     perry #ifndef _UVM_UVM_EXTERN_H_
     62         1.8     perry #define _UVM_UVM_EXTERN_H_
     63         1.1       mrg 
     64         1.1       mrg /*
     65         1.1       mrg  * uvm_extern.h: this file defines the external interface to the VM system.
     66         1.1       mrg  *
     67         1.1       mrg  * this should be the only file included by non-VM parts of the kernel
     68         1.1       mrg  * which need access to VM services.   if you want to know the interface
     69         1.1       mrg  * to the MI VM layer without knowing the details, this is the file to
     70         1.1       mrg  * learn.
     71         1.1       mrg  *
     72         1.1       mrg  * NOTE: vm system calls are prototyped in syscallargs.h
     73         1.1       mrg  */
     74         1.1       mrg 
     75       1.232  riastrad #include <sys/types.h>
     76       1.232  riastrad 
     77         1.1       mrg /*
     78         1.1       mrg  * defines
     79         1.1       mrg  */
     80         1.1       mrg 
     81         1.1       mrg /*
     82         1.1       mrg  * the following defines are for uvm_map and functions which call it.
     83         1.1       mrg  */
     84         1.1       mrg 
     85         1.1       mrg /* protections bits */
     86         1.1       mrg #define UVM_PROT_MASK	0x07	/* protection mask */
     87         1.1       mrg #define UVM_PROT_NONE	0x00	/* protection none */
     88         1.1       mrg #define UVM_PROT_ALL	0x07	/* everything */
     89         1.1       mrg #define UVM_PROT_READ	0x01	/* read */
     90         1.1       mrg #define UVM_PROT_WRITE  0x02	/* write */
     91         1.1       mrg #define UVM_PROT_EXEC	0x04	/* exec */
     92         1.1       mrg 
     93         1.1       mrg /* protection short codes */
     94         1.1       mrg #define UVM_PROT_R	0x01	/* read */
     95         1.1       mrg #define UVM_PROT_W	0x02	/* write */
     96         1.1       mrg #define UVM_PROT_RW	0x03    /* read-write */
     97         1.1       mrg #define UVM_PROT_X	0x04	/* exec */
     98         1.1       mrg #define UVM_PROT_RX	0x05	/* read-exec */
     99         1.1       mrg #define UVM_PROT_WX	0x06	/* write-exec */
    100         1.1       mrg #define UVM_PROT_RWX	0x07	/* read-write-exec */
    101         1.1       mrg 
    102         1.1       mrg /* 0x08: not used */
    103         1.1       mrg 
    104         1.1       mrg /* inherit codes */
    105         1.1       mrg #define UVM_INH_MASK	0x30	/* inherit mask */
    106         1.1       mrg #define UVM_INH_SHARE	0x00	/* "share" */
    107         1.1       mrg #define UVM_INH_COPY	0x10	/* "copy" */
    108         1.1       mrg #define UVM_INH_NONE	0x20	/* "none" */
    109         1.1       mrg #define UVM_INH_DONATE	0x30	/* "donate" << not used */
    110         1.1       mrg 
    111         1.1       mrg /* 0x40, 0x80: not used */
    112         1.1       mrg 
    113         1.1       mrg /* bits 0x700: max protection, 0x800: not used */
    114         1.1       mrg 
    115         1.1       mrg /* bits 0x7000: advice, 0x8000: not used */
    116       1.107      yamt /* advice: matches MADV_* from sys/mman.h and POSIX_FADV_* from sys/fcntl.h */
    117         1.1       mrg #define UVM_ADV_NORMAL	0x0	/* 'normal' */
    118         1.1       mrg #define UVM_ADV_RANDOM	0x1	/* 'random' */
    119         1.1       mrg #define UVM_ADV_SEQUENTIAL 0x2	/* 'sequential' */
    120       1.156     pooka #define UVM_ADV_WILLNEED 0x3	/* pages will be needed */
    121       1.156     pooka #define UVM_ADV_DONTNEED 0x4	/* pages won't be needed */
    122       1.156     pooka #define UVM_ADV_NOREUSE	0x5	/* pages will be used only once */
    123         1.1       mrg #define UVM_ADV_MASK	0x7	/* mask */
    124         1.1       mrg 
    125        1.98      yamt /* bits 0xffff0000: mapping flags */
    126       1.206       chs #define UVM_FLAG_FIXED		0x00010000 /* find space */
    127       1.206       chs #define UVM_FLAG_OVERLAY	0x00020000 /* establish overlay */
    128       1.206       chs #define UVM_FLAG_NOMERGE	0x00040000 /* don't merge map entries */
    129       1.206       chs #define UVM_FLAG_COPYONW	0x00080000 /* set copy_on_write flag */
    130       1.206       chs #define UVM_FLAG_AMAPPAD	0x00100000 /* for bss: pad amap */
    131       1.206       chs #define UVM_FLAG_TRYLOCK	0x00200000 /* fail if we can not lock map */
    132       1.206       chs #define UVM_FLAG_NOWAIT		0x00400000 /* not allowed to sleep */
    133       1.206       chs #define UVM_FLAG_WAITVA		0x00800000 /* wait for va */
    134       1.206       chs #define UVM_FLAG_VAONLY		0x02000000 /* unmap: no pages are mapped */
    135       1.206       chs #define UVM_FLAG_COLORMATCH	0x04000000 /* match color given in off */
    136       1.206       chs #define UVM_FLAG_UNMAP		0x08000000 /* unmap existing entries */
    137         1.1       mrg 
    138       1.205  christos #define UVM_FLAG_BITS "\177\020\
    139       1.205  christos F\0\3\
    140       1.205  christos :\0PROT=NONE\0\
    141       1.205  christos :\1PROT=R\0\
    142       1.205  christos :\2PROT=W\0\
    143       1.205  christos :\3PROT=RW\0\
    144       1.205  christos :\4PROT=X\0\
    145       1.205  christos :\5PROT=RX\0\
    146       1.205  christos :\6PROT=WX\0\
    147       1.205  christos :\7PROT=RWX\0\
    148       1.205  christos F\4\2\
    149       1.205  christos :\0INH=SHARE\0\
    150       1.205  christos :\1INH=COPY\0\
    151       1.205  christos :\2INH=NONE\0\
    152       1.205  christos :\3INH=DONATE\0\
    153       1.205  christos F\10\3\
    154       1.205  christos :\0MAXPROT=NONE\0\
    155       1.205  christos :\1MAXPROT=R\0\
    156       1.205  christos :\2MAXPROT=W\0\
    157       1.205  christos :\3MAXPROT=RW\0\
    158       1.205  christos :\4MAXPROT=X\0\
    159       1.205  christos :\5MAXPROT=RX\0\
    160       1.205  christos :\6MAXPROT=WX\0\
    161       1.205  christos :\7MAXPROT=RWX\0\
    162       1.205  christos F\14\3\
    163       1.205  christos :\0ADV=NORMAL\0\
    164       1.205  christos :\1ADV=RANDOM\0\
    165       1.205  christos :\2ADV=SEQUENTIAL\0\
    166       1.205  christos :\3ADV=WILLNEED\0\
    167       1.205  christos :\4ADV=DONTNEED\0\
    168       1.205  christos :\5ADV=NOREUSE\0\
    169       1.205  christos b\20FIXED\0\
    170       1.205  christos b\21OVERLAY\0\
    171       1.205  christos b\22NOMERGE\0\
    172       1.205  christos b\23COPYONW\0\
    173       1.205  christos b\24AMAPPAD\0\
    174       1.205  christos b\25TRYLOCK\0\
    175       1.205  christos b\26NOWAIT\0\
    176       1.205  christos b\27WAITVA\0\
    177       1.205  christos b\30VAONLY\0\
    178       1.206       chs b\31COLORMATCH\0\
    179       1.206       chs b\32UNMAP\0\
    180       1.206       chs "
    181       1.205  christos 
    182         1.1       mrg /* macros to extract info */
    183         1.1       mrg #define UVM_PROTECTION(X)	((X) & UVM_PROT_MASK)
    184         1.1       mrg #define UVM_INHERIT(X)		(((X) & UVM_INH_MASK) >> 4)
    185         1.1       mrg #define UVM_MAXPROTECTION(X)	(((X) >> 8) & UVM_PROT_MASK)
    186         1.1       mrg #define UVM_ADVICE(X)		(((X) >> 12) & UVM_ADV_MASK)
    187         1.1       mrg 
    188         1.1       mrg #define UVM_MAPFLAG(PROT,MAXPROT,INH,ADVICE,FLAGS) \
    189       1.114      yamt 	(((MAXPROT) << 8)|(PROT)|(INH)|((ADVICE) << 12)|(FLAGS))
    190         1.1       mrg 
    191        1.67       chs /* magic offset value: offset not known(obj) or don't care(!obj) */
    192        1.38    kleink #define UVM_UNKNOWN_OFFSET ((voff_t) -1)
    193         1.1       mrg 
    194         1.1       mrg /*
    195       1.100      yamt  * the following defines are for uvm_km_alloc/free's flags
    196         1.1       mrg  */
    197       1.100      yamt #define UVM_KMF_WIRED	0x1			/* allocation type: wired */
    198       1.100      yamt #define UVM_KMF_PAGEABLE 0x2			/* allocation type: pageable */
    199       1.100      yamt #define UVM_KMF_VAONLY	0x4			/* allocation type: VA only */
    200       1.100      yamt #define	UVM_KMF_TYPEMASK (UVM_KMF_VAONLY | UVM_KMF_PAGEABLE | UVM_KMF_WIRED)
    201       1.100      yamt #define UVM_KMF_CANFAIL	0x8			/* caller handles failure */
    202       1.100      yamt #define UVM_KMF_ZERO	0x10			/* want zero filled memory */
    203       1.115  drochner #define UVM_KMF_EXEC	0x20			/* need executable mapping */
    204         1.1       mrg #define UVM_KMF_TRYLOCK	UVM_FLAG_TRYLOCK	/* try locking only */
    205        1.75   thorpej #define UVM_KMF_NOWAIT	UVM_FLAG_NOWAIT		/* not allowed to sleep */
    206       1.100      yamt #define UVM_KMF_WAITVA	UVM_FLAG_WAITVA		/* sleep for va */
    207       1.176      matt #define UVM_KMF_COLORMATCH UVM_FLAG_COLORMATCH	/* start at color in align */
    208         1.1       mrg 
    209         1.1       mrg /*
    210        1.15   thorpej  * the following defines the strategies for uvm_pagealloc_strat()
    211        1.15   thorpej  */
    212       1.152       abs #define	UVM_PGA_STRAT_NORMAL	0	/* priority (low id to high) walk */
    213        1.15   thorpej #define	UVM_PGA_STRAT_ONLY	1	/* only specified free list */
    214        1.15   thorpej #define	UVM_PGA_STRAT_FALLBACK	2	/* ONLY falls back on NORMAL */
    215       1.216        ad #define	UVM_PGA_STRAT_NUMA	3	/* strongly prefer ideal bucket */
    216        1.15   thorpej 
    217        1.15   thorpej /*
    218        1.24       chs  * flags for uvm_pagealloc_strat()
    219        1.24       chs  */
    220        1.39   thorpej #define UVM_PGA_USERESERVE	0x0001	/* ok to use reserve pages */
    221        1.39   thorpej #define	UVM_PGA_ZERO		0x0002	/* returned page must be zero'd */
    222        1.24       chs 
    223        1.24       chs /*
    224       1.209  jdolecek  * flags for ubc_uiomove()
    225        1.53       chs  */
    226       1.194  riastrad #define UBC_READ	0x001	/* reading from object */
    227       1.194  riastrad #define UBC_WRITE	0x002	/* writing to object */
    228       1.194  riastrad #define UBC_FAULTBUSY	0x004	/* nobody else is using these pages, so busy
    229       1.194  riastrad 				 * them at alloc and unbusy at release (e.g.,
    230       1.194  riastrad 				 * for writes extending a file) */
    231       1.224        ad #define	UBC_ISMAPPED	0x008	/* object may be mapped by a process */
    232        1.53       chs 
    233        1.53       chs /*
    234        1.97       chs  * flags for ubc_release()
    235        1.97       chs  */
    236       1.194  riastrad #define UBC_UNMAP	0x010	/* unmap pages now -- don't leave the
    237       1.194  riastrad 				 * mappings cached indefinitely */
    238       1.130      yamt 
    239       1.130      yamt /*
    240       1.194  riastrad  * flags for ubc_uiomove()
    241       1.130      yamt  */
    242       1.194  riastrad #define	UBC_PARTIALOK	0x100	/* return early on error; otherwise, zero all
    243       1.194  riastrad 				 * remaining bytes after error */
    244        1.97       chs 
    245        1.97       chs /*
    246        1.53       chs  * flags for uvn_findpages().
    247        1.53       chs  */
    248        1.67       chs #define UFP_ALL		0x00
    249        1.67       chs #define UFP_NOWAIT	0x01
    250        1.67       chs #define UFP_NOALLOC	0x02
    251        1.67       chs #define UFP_NOCACHE	0x04
    252        1.67       chs #define UFP_NORDONLY	0x08
    253        1.67       chs #define UFP_DIRTYONLY	0x10
    254        1.67       chs #define UFP_BACKWARD	0x20
    255       1.222        ad #define UFP_NOBUSY	0x40
    256        1.53       chs 
    257        1.53       chs /*
    258        1.33   thorpej  * lockflags that control the locking behavior of various functions.
    259        1.33   thorpej  */
    260        1.33   thorpej #define	UVM_LK_ENTER	0x00000001	/* map locked on entry */
    261        1.33   thorpej #define	UVM_LK_EXIT	0x00000002	/* leave map locked on exit */
    262        1.33   thorpej 
    263        1.33   thorpej /*
    264       1.149  christos  * Default number of pages to allocate on the stack
    265       1.149  christos  */
    266       1.149  christos #define	UBC_MAX_PAGES	8
    267       1.149  christos 
    268       1.149  christos /*
    269       1.155     rmind  * Value representing inactive emap.
    270       1.155     rmind  */
    271       1.155     rmind #define	UVM_EMAP_INACTIVE	(0)
    272       1.155     rmind 
    273       1.155     rmind /*
    274         1.1       mrg  * structures
    275         1.1       mrg  */
    276         1.1       mrg 
    277        1.97       chs struct buf;
    278         1.1       mrg struct core;
    279        1.97       chs struct loadavg;
    280         1.1       mrg struct mount;
    281         1.1       mrg struct pglist;
    282         1.1       mrg struct proc;
    283         1.1       mrg struct uio;
    284         1.1       mrg struct uvm_object;
    285         1.1       mrg struct vm_anon;
    286         1.1       mrg struct vmspace;
    287        1.10   thorpej struct pmap;
    288         1.1       mrg struct vnode;
    289        1.65       chs struct vm_map_entry;
    290        1.65       chs struct vm_map;
    291        1.65       chs struct vm_page;
    292        1.97       chs struct vmtotal;
    293        1.53       chs 
    294         1.1       mrg /*
    295       1.108      yamt  * uvm_pctparam: parameter to be shown as percentage to user.
    296       1.108      yamt  */
    297       1.108      yamt 
    298       1.108      yamt #define	UVM_PCTPARAM_SHIFT	8
    299       1.108      yamt #define	UVM_PCTPARAM_SCALE	(1 << UVM_PCTPARAM_SHIFT)
    300       1.108      yamt #define	UVM_PCTPARAM_APPLY(pct, x) \
    301       1.108      yamt 	(((x) * (pct)->pct_scaled) >> UVM_PCTPARAM_SHIFT)
    302       1.108      yamt struct uvm_pctparam {
    303       1.118      yamt 	int pct_pct;	/* percent [0, 100] */ /* should be the first member */
    304       1.108      yamt 	int pct_scaled;
    305       1.118      yamt 	int (*pct_check)(struct uvm_pctparam *, int);
    306       1.108      yamt };
    307       1.108      yamt 
    308       1.108      yamt /*
    309         1.1       mrg  * uvmexp: global data structures that are exported to parts of the kernel
    310         1.1       mrg  * other than the vm system.
    311         1.1       mrg  */
    312         1.1       mrg 
    313         1.1       mrg struct uvmexp {
    314         1.9       mrg 	/* vm_page constants */
    315         1.1       mrg 	int pagesize;   /* size of a page (PAGE_SIZE): must be power of 2 */
    316         1.1       mrg 	int pagemask;   /* page mask */
    317         1.1       mrg 	int pageshift;  /* page shift */
    318         1.1       mrg 
    319         1.9       mrg 	/* vm_page counters */
    320         1.1       mrg 	int npages;     /* number of pages we manage */
    321         1.1       mrg 	int free;       /* number of free pages */
    322         1.3       chs 	int paging;	/* number of pages in the process of being paged out */
    323         1.1       mrg 	int wired;      /* number of wired pages */
    324        1.57       chs 
    325        1.63       chs 	/*
    326        1.57       chs 	 * Adding anything before this line will break binary compatibility
    327        1.57       chs 	 * with top(1) on NetBSD 1.5.
    328        1.54    simonb 	 */
    329        1.57       chs 
    330        1.67       chs 	int ncolors;	/* number of page color buckets: must be p-o-2 */
    331        1.67       chs 	int colormask;	/* color bucket mask */
    332        1.67       chs 
    333        1.55    simonb 	int zeropages;		/* number of zero'd pages */
    334         1.3       chs 	int reserve_pagedaemon; /* number of pages reserved for pagedaemon */
    335        1.55    simonb 	int reserve_kernel;	/* number of pages reserved for kernel */
    336       1.137        ad 	unsigned anonpages;	/* number of pages used by anon mappings */
    337       1.137        ad 	unsigned filepages;	/* number of pages used by cached file data */
    338       1.137        ad 	unsigned execpages;	/* number of pages used by cached exec data */
    339         1.1       mrg 
    340         1.9       mrg 	/* pageout params */
    341         1.9       mrg 	int freemin;    /* min number of free pages */
    342         1.9       mrg 	int freetarg;   /* target number of free pages */
    343         1.9       mrg 	int wiredmax;   /* max number of wired pages */
    344         1.1       mrg 
    345         1.9       mrg 	/* swap */
    346         1.1       mrg 	int nswapdev;	/* number of configured swap devices in system */
    347         1.1       mrg 	int swpages;	/* number of PAGE_SIZE'ed swap pages */
    348        1.84        pk 	int swpgavail;	/* number of swap pages currently available */
    349         1.3       chs 	int swpginuse;	/* number of swap pages in use */
    350        1.23       chs 	int swpgonly;	/* number of swap pages in use, not also in RAM */
    351         1.1       mrg 	int nswget;	/* number of times fault calls uvm_swap_get() */
    352         1.1       mrg 
    353       1.110    simonb 	/* stat counters.  XXX: should be 64-bit counters */
    354       1.214        ad 	int faults;		/* page fault count */
    355       1.214        ad 	int traps;		/* trap count */
    356       1.214        ad 	int intrs;		/* interrupt count */
    357       1.214        ad 	int swtch;		/* context switch count */
    358       1.214        ad 	int softs;		/* software interrupt count */
    359       1.214        ad 	int syscalls;		/* system calls */
    360         1.7       mrg 	int pageins;		/* pagein operation count */
    361         1.7       mrg 				/* pageouts are in pdpageouts below */
    362       1.160     rmind 	int _unused1;
    363       1.160     rmind 	int _unused2;
    364         1.7       mrg 	int pgswapin;		/* pages swapped in */
    365         1.7       mrg 	int pgswapout;		/* pages swapped out */
    366         1.7       mrg 	int forks;  		/* forks */
    367         1.1       mrg 	int forks_ppwait;	/* forks where parent waits */
    368         1.1       mrg 	int forks_sharevm;	/* forks where vmspace is shared */
    369        1.40   thorpej 	int pga_zerohit;	/* pagealloc where zero wanted and zero
    370        1.40   thorpej 				   was available */
    371        1.40   thorpej 	int pga_zeromiss;	/* pagealloc where zero wanted and zero
    372        1.40   thorpej 				   not available */
    373        1.50   thorpej 	int zeroaborts;		/* number of times page zeroing was
    374        1.50   thorpej 				   aborted */
    375        1.60   thorpej 	int colorhit;		/* pagealloc where we got optimal color */
    376        1.60   thorpej 	int colormiss;		/* pagealloc where we didn't */
    377       1.146        ad 	int cpuhit;		/* pagealloc where we allocated locally */
    378       1.146        ad 	int cpumiss;		/* pagealloc where we didn't */
    379         1.1       mrg 
    380       1.110    simonb 	/* fault subcounters.  XXX: should be 64-bit counters */
    381         1.1       mrg 	int fltnoram;	/* number of times fault was out of ram */
    382         1.1       mrg 	int fltnoanon;	/* number of times fault was out of anons */
    383         1.1       mrg 	int fltpgwait;	/* number of times fault had to wait on a page */
    384         1.1       mrg 	int fltpgrele;	/* number of times fault found a released page */
    385         1.1       mrg 	int fltrelck;	/* number of times fault relock called */
    386         1.1       mrg 	int fltrelckok;	/* number of times fault relock is a success */
    387         1.1       mrg 	int fltanget;	/* number of times fault gets anon page */
    388         1.1       mrg 	int fltanretry;	/* number of times fault retrys an anon get */
    389         1.1       mrg 	int fltamcopy;	/* number of times fault clears "needs copy" */
    390         1.1       mrg 	int fltnamap;	/* number of times fault maps a neighbor anon page */
    391         1.1       mrg 	int fltnomap;	/* number of times fault maps a neighbor obj page */
    392         1.1       mrg 	int fltlget;	/* number of times fault does a locked pgo_get */
    393         1.1       mrg 	int fltget;	/* number of times fault does an unlocked get */
    394         1.1       mrg 	int flt_anon;	/* number of times fault anon (case 1a) */
    395         1.1       mrg 	int flt_acow;	/* number of times fault anon cow (case 1b) */
    396         1.1       mrg 	int flt_obj;	/* number of times fault is on object page (2a) */
    397         1.1       mrg 	int flt_prcopy;	/* number of times fault promotes with copy (2b) */
    398         1.1       mrg 	int flt_przero;	/* number of times fault promotes with zerofill (2b) */
    399         1.1       mrg 
    400       1.110    simonb 	/* daemon counters.  XXX: should be 64-bit counters */
    401         1.1       mrg 	int pdwoke;	/* number of times daemon woke up */
    402         1.1       mrg 	int pdrevs;	/* number of times daemon rev'd clock hand */
    403       1.160     rmind 	int _unused3;
    404         1.1       mrg 	int pdfreed;	/* number of pages daemon freed since boot */
    405        1.78       wiz 	int pdscans;	/* number of pages daemon scanned since boot */
    406         1.1       mrg 	int pdanscan;	/* number of anonymous pages scanned by daemon */
    407         1.1       mrg 	int pdobscan;	/* number of object pages scanned by daemon */
    408         1.1       mrg 	int pdreact;	/* number of pages daemon reactivated since boot */
    409         1.1       mrg 	int pdbusy;	/* number of times daemon found a busy page */
    410         1.1       mrg 	int pdpageouts;	/* number of times daemon started a pageout */
    411         1.1       mrg 	int pdpending;	/* number of times daemon got a pending pagout */
    412         1.1       mrg 	int pddeact;	/* number of pages daemon deactivates */
    413        1.69       chs 	int pdreanon;	/* anon pages reactivated due to thresholds */
    414        1.69       chs 	int pdrefile;	/* file pages reactivated due to thresholds */
    415        1.69       chs 	int pdreexec;	/* executable pages reactivated due to thresholds */
    416       1.207       mrg 
    417       1.207       mrg 	int bootpages;  /* number of pages stolen at boot */
    418        1.54    simonb };
    419        1.54    simonb 
    420        1.54    simonb /*
    421        1.54    simonb  * The following structure is 64-bit alignment safe.  New elements
    422        1.54    simonb  * should only be added to the end of this structure so binary
    423        1.54    simonb  * compatibility can be preserved.
    424        1.54    simonb  */
    425        1.54    simonb struct uvmexp_sysctl {
    426        1.54    simonb 	int64_t	pagesize;
    427        1.54    simonb 	int64_t	pagemask;
    428        1.54    simonb 	int64_t	pageshift;
    429        1.54    simonb 	int64_t	npages;
    430        1.54    simonb 	int64_t	free;
    431        1.54    simonb 	int64_t	active;
    432        1.54    simonb 	int64_t	inactive;
    433        1.54    simonb 	int64_t	paging;
    434        1.54    simonb 	int64_t	wired;
    435        1.54    simonb 	int64_t	zeropages;
    436        1.54    simonb 	int64_t	reserve_pagedaemon;
    437        1.54    simonb 	int64_t	reserve_kernel;
    438        1.54    simonb 	int64_t	freemin;
    439        1.54    simonb 	int64_t	freetarg;
    440       1.160     rmind 	int64_t	inactarg;		/* unused */
    441        1.54    simonb 	int64_t	wiredmax;
    442        1.54    simonb 	int64_t	nswapdev;
    443        1.54    simonb 	int64_t	swpages;
    444        1.54    simonb 	int64_t	swpginuse;
    445        1.54    simonb 	int64_t	swpgonly;
    446        1.54    simonb 	int64_t	nswget;
    447       1.160     rmind 	int64_t	unused1;		/* unused; was nanon */
    448       1.146        ad 	int64_t cpuhit;
    449       1.146        ad 	int64_t cpumiss;
    450        1.54    simonb 	int64_t	faults;
    451        1.54    simonb 	int64_t	traps;
    452        1.54    simonb 	int64_t	intrs;
    453        1.54    simonb 	int64_t	swtch;
    454        1.54    simonb 	int64_t	softs;
    455        1.54    simonb 	int64_t	syscalls;
    456        1.54    simonb 	int64_t	pageins;
    457       1.160     rmind 	int64_t	swapins;		/* unused */
    458       1.160     rmind 	int64_t	swapouts;		/* unused */
    459       1.214        ad 	int64_t	pgswapin;		/* unused */
    460        1.54    simonb 	int64_t	pgswapout;
    461        1.54    simonb 	int64_t	forks;
    462        1.54    simonb 	int64_t	forks_ppwait;
    463        1.54    simonb 	int64_t	forks_sharevm;
    464        1.54    simonb 	int64_t	pga_zerohit;
    465        1.54    simonb 	int64_t	pga_zeromiss;
    466        1.54    simonb 	int64_t	zeroaborts;
    467        1.54    simonb 	int64_t	fltnoram;
    468        1.54    simonb 	int64_t	fltnoanon;
    469        1.54    simonb 	int64_t	fltpgwait;
    470        1.54    simonb 	int64_t	fltpgrele;
    471        1.54    simonb 	int64_t	fltrelck;
    472        1.54    simonb 	int64_t	fltrelckok;
    473        1.54    simonb 	int64_t	fltanget;
    474        1.54    simonb 	int64_t	fltanretry;
    475        1.54    simonb 	int64_t	fltamcopy;
    476        1.54    simonb 	int64_t	fltnamap;
    477        1.54    simonb 	int64_t	fltnomap;
    478        1.54    simonb 	int64_t	fltlget;
    479        1.54    simonb 	int64_t	fltget;
    480        1.54    simonb 	int64_t	flt_anon;
    481        1.54    simonb 	int64_t	flt_acow;
    482        1.54    simonb 	int64_t	flt_obj;
    483        1.54    simonb 	int64_t	flt_prcopy;
    484        1.54    simonb 	int64_t	flt_przero;
    485        1.54    simonb 	int64_t	pdwoke;
    486        1.54    simonb 	int64_t	pdrevs;
    487       1.160     rmind 	int64_t	unused4;
    488        1.54    simonb 	int64_t	pdfreed;
    489        1.54    simonb 	int64_t	pdscans;
    490        1.54    simonb 	int64_t	pdanscan;
    491        1.54    simonb 	int64_t	pdobscan;
    492        1.54    simonb 	int64_t	pdreact;
    493        1.54    simonb 	int64_t	pdbusy;
    494        1.54    simonb 	int64_t	pdpageouts;
    495        1.54    simonb 	int64_t	pdpending;
    496        1.54    simonb 	int64_t	pddeact;
    497        1.55    simonb 	int64_t	anonpages;
    498        1.69       chs 	int64_t	filepages;
    499        1.69       chs 	int64_t	execpages;
    500        1.60   thorpej 	int64_t colorhit;
    501        1.60   thorpej 	int64_t colormiss;
    502        1.61   thorpej 	int64_t ncolors;
    503       1.207       mrg 	int64_t bootpages;
    504       1.207       mrg 	int64_t poolpages;
    505       1.214        ad 	int64_t countsyncone;
    506       1.214        ad 	int64_t countsyncall;
    507       1.219        ad 	int64_t anonunknown;
    508       1.219        ad 	int64_t anonclean;
    509       1.219        ad 	int64_t anondirty;
    510       1.219        ad 	int64_t fileunknown;
    511       1.219        ad 	int64_t fileclean;
    512       1.219        ad 	int64_t filedirty;
    513       1.222        ad 	int64_t fltup;
    514       1.222        ad 	int64_t fltnoup;
    515         1.1       mrg };
    516         1.1       mrg 
    517        1.31   thorpej #ifdef _KERNEL
    518        1.97       chs /* we need this before including uvm_page.h on some platforms */
    519        1.45       mrg extern struct uvmexp uvmexp;
    520        1.45       mrg #endif
    521         1.1       mrg 
    522        1.45       mrg /*
    523        1.45       mrg  * Finally, bring in standard UVM headers.
    524        1.45       mrg  */
    525        1.45       mrg #include <sys/vmmeter.h>
    526        1.45       mrg #include <sys/queue.h>
    527       1.116        he #include <sys/lock.h>
    528       1.180      para #ifdef _KERNEL
    529       1.180      para #include <sys/vmem.h>
    530       1.180      para #endif
    531        1.45       mrg #include <uvm/uvm_param.h>
    532        1.45       mrg #include <uvm/uvm_prot.h>
    533        1.45       mrg #include <uvm/uvm_pmap.h>
    534       1.196  christos #if defined(_KERNEL) || defined(_KMEMUSER)
    535        1.45       mrg #include <uvm/uvm_map.h>
    536        1.45       mrg #include <uvm/uvm_pager.h>
    537       1.203  christos #endif
    538        1.45       mrg 
    539       1.203  christos #ifdef _KERNEL
    540        1.45       mrg /*
    541       1.200    cherry  * Include the uvm_hotplug(9) API unconditionally until
    542       1.200    cherry  * uvm_page_physload() et. al. are obsoleted
    543       1.200    cherry  *
    544       1.200    cherry  * After this, MD code will have to explicitly include it if needed.
    545       1.200    cherry  */
    546       1.200    cherry #include <uvm/uvm_physseg.h>
    547       1.201    cherry #endif
    548       1.200    cherry 
    549       1.200    cherry /*
    550       1.138      yamt  * helpers for calling ubc_release()
    551       1.138      yamt  */
    552       1.138      yamt #ifdef PMAP_CACHE_VIVT
    553       1.224        ad #define UBC_VNODE_FLAGS(vp) \
    554       1.225       rin     ((((vp)->v_iflag & VI_TEXT) != 0 ? UBC_UNMAP : 0) | \
    555       1.224        ad     (((vp)->v_vflag & VV_MAPPED) != 0 ? UBC_ISMAPPED : 0))
    556       1.138      yamt #else
    557       1.224        ad #define UBC_VNODE_FLAGS(vp) \
    558       1.224        ad     (((vp)->v_vflag & VV_MAPPED) != 0 ? UBC_ISMAPPED : 0)
    559       1.138      yamt #endif
    560       1.138      yamt 
    561       1.196  christos #if defined(_KERNEL) || defined(_KMEMUSER)
    562       1.138      yamt /*
    563        1.45       mrg  * Shareable process virtual address space.
    564        1.45       mrg  * May eventually be merged with vm_map.
    565        1.45       mrg  * Several fields are temporary (text, data stuff).
    566        1.45       mrg  */
    567        1.45       mrg struct vmspace {
    568        1.45       mrg 	struct	vm_map vm_map;	/* VM address map */
    569       1.227     kamil 	volatile int vm_refcnt;	/* number of references */
    570       1.128  christos 	void *	vm_shm;		/* SYS5 shared memory private data XXX */
    571        1.45       mrg /* we copy from vm_startcopy to the end of the structure on fork */
    572        1.45       mrg #define vm_startcopy vm_rssize
    573        1.59   thorpej 	segsz_t vm_rssize;	/* current resident set size in pages */
    574       1.211  christos 	segsz_t vm_rssmax;	/* max resident size in pages */
    575        1.45       mrg 	segsz_t vm_tsize;	/* text size (pages) XXX */
    576        1.45       mrg 	segsz_t vm_dsize;	/* data size (pages) XXX */
    577        1.45       mrg 	segsz_t vm_ssize;	/* stack size (pages) */
    578       1.153       mrg 	segsz_t vm_issize;	/* initial unmapped stack size (pages) */
    579       1.128  christos 	void *	vm_taddr;	/* user virtual address of text XXX */
    580       1.128  christos 	void *	vm_daddr;	/* user virtual address of data XXX */
    581       1.128  christos 	void *vm_maxsaddr;	/* user VA at max stack growth */
    582       1.128  christos 	void *vm_minsaddr;	/* user VA at top of stack */
    583       1.142  christos 	size_t vm_aslr_delta_mmap;	/* mmap() random delta for ASLR */
    584        1.45       mrg };
    585       1.111      yamt #define	VMSPACE_IS_KERNEL_P(vm)	VM_MAP_IS_KERNEL(&(vm)->vm_map)
    586       1.196  christos #endif
    587        1.45       mrg 
    588        1.45       mrg #ifdef _KERNEL
    589        1.43       mrg 
    590        1.43       mrg /*
    591        1.70   thorpej  * used to keep state while iterating over the map for a core dump.
    592        1.70   thorpej  */
    593        1.70   thorpej struct uvm_coredump_state {
    594        1.70   thorpej 	void *cookie;		/* opaque for the caller */
    595        1.70   thorpej 	vaddr_t start;		/* start of region */
    596       1.102      matt 	vaddr_t realend;	/* real end of region */
    597       1.102      matt 	vaddr_t end;		/* virtual end of region */
    598        1.70   thorpej 	vm_prot_t prot;		/* protection of region */
    599        1.70   thorpej 	int flags;		/* flags; see below */
    600        1.70   thorpej };
    601        1.70   thorpej 
    602        1.70   thorpej #define	UVM_COREDUMP_STACK	0x01	/* region is user stack */
    603        1.70   thorpej 
    604        1.70   thorpej /*
    605        1.43       mrg  * the various kernel maps, owned by MD code
    606        1.43       mrg  */
    607        1.65       chs extern struct vm_map *kernel_map;
    608        1.65       chs extern struct vm_map *phys_map;
    609        1.79   thorpej 
    610        1.79   thorpej /*
    611       1.223   thorpej  *	uvm_voaddr:
    612       1.223   thorpej  *
    613       1.223   thorpej  *	This structure encapsulates UVM's unique virtual object address
    614       1.223   thorpej  *	for an individual byte inside a pageable page. Pageable pages can
    615       1.226   thorpej  *	be owned by either a uvm_object or a vm_anon.
    616       1.223   thorpej  *
    617       1.223   thorpej  *	In each case, the byte offset into the owning object
    618       1.223   thorpej  *	(uvm_object or vm_anon) is included in the ID, so that
    619       1.223   thorpej  *	two different offsets into the same page have distinct
    620       1.223   thorpej  *	IDs.
    621       1.223   thorpej  *
    622       1.223   thorpej  *	Note that the page does not necessarily have to be resident
    623       1.223   thorpej  *	in order to know the virtual object address.  However, it
    624       1.223   thorpej  *	is required that any pending copy-on-write is resolved.
    625       1.223   thorpej  *
    626       1.223   thorpej  *	When someone wants a virtual object address, an extra reference
    627       1.223   thorpej  *	is taken on the owner while the caller uses the ID.  This
    628       1.223   thorpej  *	ensures that the identity is stable for the duration of its
    629       1.223   thorpej  *	use.
    630       1.223   thorpej  */
    631       1.223   thorpej struct uvm_voaddr {
    632       1.226   thorpej 	uintptr_t object;
    633       1.223   thorpej 	voff_t offset;
    634       1.223   thorpej };
    635       1.223   thorpej 
    636       1.223   thorpej /*
    637         1.1       mrg  * macros
    638         1.1       mrg  */
    639         1.1       mrg 
    640        1.45       mrg #define vm_resident_count(vm) (pmap_resident_count((vm)->vm_map.pmap))
    641         1.1       mrg 
    642        1.44       mrg 
    643        1.44       mrg /* vm_machdep.c */
    644       1.170     pooka int		vmapbuf(struct buf *, vsize_t);
    645        1.91  junyoung void		vunmapbuf(struct buf *, vsize_t);
    646       1.213       chs void		ktext_write(void *, const void *, size_t);
    647        1.31   thorpej 
    648         1.1       mrg /* uvm_aobj.c */
    649       1.213       chs struct uvm_object	*uao_create(voff_t, int);
    650       1.190  riastrad void			uao_set_pgfl(struct uvm_object *, int);
    651        1.91  junyoung void			uao_detach(struct uvm_object *);
    652        1.91  junyoung void			uao_reference(struct uvm_object *);
    653         1.1       mrg 
    654        1.53       chs /* uvm_bio.c */
    655        1.91  junyoung void			ubc_init(void);
    656       1.191  riastrad void			ubchist_init(void);
    657       1.130      yamt int			ubc_uiomove(struct uvm_object *, struct uio *, vsize_t,
    658       1.134      yamt 			    int, int);
    659       1.174   hannken void			ubc_zerorange(struct uvm_object *, off_t, size_t, int);
    660       1.173     rmind void			ubc_purge(struct uvm_object *);
    661        1.53       chs 
    662         1.1       mrg /* uvm_fault.c */
    663       1.112  drochner #define uvm_fault(m, a, p) uvm_fault_internal(m, a, p, 0)
    664       1.112  drochner int		uvm_fault_internal(struct vm_map *, vaddr_t, vm_prot_t, int);
    665       1.112  drochner 			/* handle a page fault */
    666         1.1       mrg 
    667         1.1       mrg /* uvm_glue.c */
    668         1.1       mrg #if defined(KGDB)
    669       1.128  christos void			uvm_chgkprot(void *, size_t, int);
    670         1.1       mrg #endif
    671       1.126   thorpej void			uvm_proc_fork(struct proc *, struct proc *, bool);
    672        1.91  junyoung void			uvm_lwp_fork(struct lwp *, struct lwp *,
    673        1.91  junyoung 			    void *, size_t, void (*)(void *), void *);
    674       1.188       dsl int			uvm_coredump_walkmap(struct proc *,
    675       1.188       dsl 			    int (*)(struct uvm_coredump_state *), void *);
    676       1.187       dsl int			uvm_coredump_count_segs(struct proc *);
    677        1.91  junyoung void			uvm_proc_exit(struct proc *);
    678        1.91  junyoung void			uvm_lwp_exit(struct lwp *);
    679       1.218        ad void			uvm_idle(void);
    680        1.91  junyoung void			uvm_init_limits(struct proc *);
    681       1.173     rmind bool			uvm_kernacc(void *, size_t, vm_prot_t);
    682       1.141     perry __dead void		uvm_scheduler(void);
    683       1.160     rmind vaddr_t			uvm_uarea_alloc(void);
    684       1.160     rmind void			uvm_uarea_free(vaddr_t);
    685       1.184      matt vaddr_t			uvm_uarea_system_alloc(struct cpu_info *);
    686       1.171      matt void			uvm_uarea_system_free(vaddr_t);
    687       1.161     rmind vaddr_t			uvm_lwp_getuarea(lwp_t *);
    688       1.161     rmind void			uvm_lwp_setuarea(lwp_t *, vaddr_t);
    689       1.119       chs int			uvm_vslock(struct vmspace *, void *, size_t, vm_prot_t);
    690       1.119       chs void			uvm_vsunlock(struct vmspace *, void *, size_t);
    691       1.135        ad void			uvm_cpu_attach(struct cpu_info *);
    692         1.1       mrg 
    693         1.1       mrg 
    694         1.1       mrg /* uvm_init.c */
    695       1.199    cherry void			uvm_md_init(void);
    696        1.91  junyoung void			uvm_init(void);
    697         1.1       mrg 
    698         1.1       mrg /* uvm_io.c */
    699       1.197  christos int			uvm_io(struct vm_map *, struct uio *, int);
    700         1.1       mrg 
    701         1.1       mrg /* uvm_km.c */
    702       1.100      yamt vaddr_t			uvm_km_alloc(struct vm_map *, vsize_t, vsize_t,
    703       1.100      yamt 			    uvm_flag_t);
    704       1.198      maxv int			uvm_km_protect(struct vm_map *, vaddr_t, vsize_t,
    705       1.198      maxv 			    vm_prot_t);
    706       1.100      yamt void			uvm_km_free(struct vm_map *, vaddr_t, vsize_t,
    707       1.100      yamt 			    uvm_flag_t);
    708       1.100      yamt 
    709        1.91  junyoung struct vm_map		*uvm_km_suballoc(struct vm_map *, vaddr_t *,
    710       1.126   thorpej 			    vaddr_t *, vsize_t, int, bool,
    711       1.180      para 			    struct vm_map *);
    712       1.180      para int			uvm_km_kmem_alloc(vmem_t *, vmem_size_t, vm_flag_t,
    713       1.180      para 			    vmem_addr_t *);
    714       1.180      para void			uvm_km_kmem_free(vmem_t *, vmem_addr_t, vmem_size_t);
    715       1.180      para bool			uvm_km_va_starved_p(void);
    716        1.65       chs 
    717         1.1       mrg /* uvm_map.c */
    718        1.91  junyoung int			uvm_map(struct vm_map *, vaddr_t *, vsize_t,
    719        1.91  junyoung 			    struct uvm_object *, voff_t, vsize_t,
    720        1.91  junyoung 			    uvm_flag_t);
    721        1.91  junyoung int			uvm_map_pageable(struct vm_map *, vaddr_t,
    722       1.126   thorpej 			    vaddr_t, bool, int);
    723        1.91  junyoung int			uvm_map_pageable_all(struct vm_map *, int, vsize_t);
    724       1.126   thorpej bool			uvm_map_checkprot(struct vm_map *, vaddr_t,
    725        1.91  junyoung 			    vaddr_t, vm_prot_t);
    726        1.91  junyoung int			uvm_map_protect(struct vm_map *, vaddr_t,
    727       1.126   thorpej 			    vaddr_t, vm_prot_t, bool);
    728       1.204     joerg int			uvm_map_protect_user(struct lwp *, vaddr_t, vaddr_t,
    729       1.204     joerg 			    vm_prot_t);
    730       1.185    martin struct vmspace		*uvmspace_alloc(vaddr_t, vaddr_t, bool);
    731        1.91  junyoung void			uvmspace_init(struct vmspace *, struct pmap *,
    732       1.185    martin 			    vaddr_t, vaddr_t, bool);
    733       1.185    martin void			uvmspace_exec(struct lwp *, vaddr_t, vaddr_t, bool);
    734        1.91  junyoung struct vmspace		*uvmspace_fork(struct vmspace *);
    735       1.111      yamt void			uvmspace_addref(struct vmspace *);
    736        1.91  junyoung void			uvmspace_free(struct vmspace *);
    737        1.91  junyoung void			uvmspace_share(struct proc *, struct proc *);
    738        1.91  junyoung void			uvmspace_unshare(struct lwp *);
    739         1.1       mrg 
    740       1.223   thorpej bool			uvm_voaddr_acquire(struct vm_map *, vaddr_t,
    741       1.223   thorpej 			    struct uvm_voaddr *);
    742       1.223   thorpej void			uvm_voaddr_release(struct uvm_voaddr *);
    743       1.223   thorpej int			uvm_voaddr_compare(const struct uvm_voaddr *,
    744       1.223   thorpej 			    const struct uvm_voaddr *);
    745       1.223   thorpej 
    746       1.140      yamt void			uvm_whatis(uintptr_t, void (*)(const char *, ...));
    747         1.1       mrg 
    748         1.1       mrg /* uvm_meter.c */
    749        1.91  junyoung int			uvm_sysctl(int *, u_int, void *, size_t *,
    750        1.91  junyoung 			    void *, size_t, struct proc *);
    751       1.118      yamt int			uvm_pctparam_check(struct uvm_pctparam *, int);
    752       1.108      yamt void			uvm_pctparam_set(struct uvm_pctparam *, int);
    753       1.118      yamt int			uvm_pctparam_get(struct uvm_pctparam *);
    754       1.118      yamt void			uvm_pctparam_init(struct uvm_pctparam *, int,
    755       1.118      yamt 			    int (*)(struct uvm_pctparam *, int));
    756       1.118      yamt int			uvm_pctparam_createsysctlnode(struct uvm_pctparam *,
    757       1.118      yamt 			    const char *, const char *);
    758       1.214        ad void			uvm_update_uvmexp(void);
    759         1.1       mrg 
    760         1.1       mrg /* uvm_mmap.c */
    761       1.192       chs int			uvm_mmap_dev(struct proc *, void **, size_t, dev_t,
    762       1.192       chs 			    off_t);
    763       1.192       chs int			uvm_mmap_anon(struct proc *, void **, size_t);
    764       1.195    martin vaddr_t			uvm_default_mapaddr(struct proc *, vaddr_t, vsize_t,
    765       1.195    martin 			    int);
    766         1.1       mrg 
    767       1.109      yamt /* uvm_mremap.c */
    768       1.109      yamt int			uvm_mremap(struct vm_map *, vaddr_t, vsize_t,
    769       1.109      yamt 			    struct vm_map *, vaddr_t *, vsize_t,
    770       1.109      yamt 			    struct proc *, int);
    771       1.109      yamt 
    772       1.120      yamt /* uvm_object.c */
    773       1.173     rmind void			uvm_obj_init(struct uvm_object *,
    774       1.173     rmind 			    const struct uvm_pagerops *, bool, u_int);
    775       1.221        ad void			uvm_obj_setlock(struct uvm_object *, krwlock_t *);
    776       1.173     rmind void			uvm_obj_destroy(struct uvm_object *, bool);
    777       1.175  christos int			uvm_obj_wirepages(struct uvm_object *, off_t, off_t,
    778       1.175  christos 			    struct pglist *);
    779       1.173     rmind void			uvm_obj_unwirepages(struct uvm_object *, off_t, off_t);
    780       1.231       chs bool			uvm_obj_clean_p(struct uvm_object *);
    781       1.231       chs bool			uvm_obj_nowriteback_p(struct uvm_object *);
    782       1.231       chs bool			uvm_obj_page_dirty_p(struct vm_page *);
    783       1.231       chs void			uvm_obj_page_set_dirty(struct vm_page *);
    784       1.231       chs void			uvm_obj_page_clear_dirty(struct vm_page *);
    785       1.231       chs bool			uvm_obj_page_writeback_p(struct vm_page *);
    786       1.231       chs void			uvm_obj_page_set_writeback(struct vm_page *);
    787       1.231       chs void			uvm_obj_page_clear_writeback(struct vm_page *);
    788       1.120      yamt 
    789         1.1       mrg /* uvm_page.c */
    790       1.228        ad int			uvm_availmem(bool);
    791       1.216        ad void			uvm_page_numa_load(paddr_t, paddr_t, u_int);
    792        1.91  junyoung struct vm_page		*uvm_pagealloc_strat(struct uvm_object *,
    793        1.91  junyoung 			    voff_t, struct vm_anon *, int, int, int);
    794        1.24       chs #define	uvm_pagealloc(obj, off, anon, flags) \
    795        1.24       chs 	    uvm_pagealloc_strat((obj), (off), (anon), (flags), \
    796        1.24       chs 				UVM_PGA_STRAT_NORMAL, 0)
    797        1.91  junyoung void			uvm_pagereplace(struct vm_page *,
    798        1.91  junyoung 			    struct vm_page *);
    799       1.229        ad int			uvm_pagerealloc(struct vm_page *,
    800        1.91  junyoung 			    struct uvm_object *, voff_t);
    801        1.91  junyoung void			uvm_setpagesize(void);
    802         1.1       mrg 
    803        1.53       chs /* uvm_pager.c */
    804        1.91  junyoung void			uvm_aio_aiodone(struct buf *);
    805       1.145      yamt void			uvm_aio_aiodone_pages(struct vm_page **, int, bool,
    806       1.145      yamt 			    int);
    807        1.53       chs 
    808         1.1       mrg /* uvm_pdaemon.c */
    809        1.91  junyoung void			uvm_pageout(void *);
    810       1.124      yamt struct work;
    811       1.124      yamt void			uvm_aiodone_worker(struct work *, void *);
    812       1.143        ad void			uvm_pageout_start(int);
    813       1.143        ad void			uvm_pageout_done(int);
    814       1.118      yamt void			uvm_estimatepageable(int *, int *);
    815         1.1       mrg 
    816         1.1       mrg /* uvm_pglist.c */
    817        1.91  junyoung int			uvm_pglistalloc(psize_t, paddr_t, paddr_t,
    818        1.91  junyoung 			    paddr_t, paddr_t, struct pglist *, int, int);
    819        1.91  junyoung void			uvm_pglistfree(struct pglist *);
    820         1.1       mrg 
    821         1.1       mrg /* uvm_swap.c */
    822        1.91  junyoung void			uvm_swap_init(void);
    823         1.1       mrg 
    824         1.1       mrg /* uvm_unix.c */
    825        1.91  junyoung int			uvm_grow(struct proc *, vaddr_t);
    826         1.1       mrg 
    827         1.1       mrg /* uvm_user.c */
    828        1.91  junyoung void			uvm_deallocate(struct vm_map *, vaddr_t, vsize_t);
    829         1.1       mrg 
    830         1.1       mrg /* uvm_vnode.c */
    831       1.219        ad struct uvm_page_array;
    832        1.91  junyoung void			uvm_vnp_setsize(struct vnode *, voff_t);
    833       1.130      yamt void			uvm_vnp_setwritesize(struct vnode *, voff_t);
    834        1.91  junyoung int			uvn_findpages(struct uvm_object *, voff_t,
    835       1.219        ad 			    unsigned int *, struct vm_page **,
    836       1.219        ad 			    struct uvm_page_array *, unsigned int);
    837       1.126   thorpej bool			uvn_text_p(struct uvm_object *);
    838       1.126   thorpej bool			uvn_needs_writefault_p(struct uvm_object *);
    839        1.37   thorpej 
    840        1.37   thorpej /* kern_malloc.c */
    841       1.181      para void			kmeminit_nkmempages(void);
    842       1.181      para extern int		nkmempages;
    843         1.1       mrg 
    844        1.31   thorpej #endif /* _KERNEL */
    845        1.31   thorpej 
    846         1.8     perry #endif /* _UVM_UVM_EXTERN_H_ */
    847