1df8bae1dSRodney W. Grimes /* 2df8bae1dSRodney W. Grimes * Copyright (c) 1990 University of Utah. 326f9a767SRodney W. Grimes * Copyright (c) 1991 The Regents of the University of California. 426f9a767SRodney W. Grimes * All rights reserved. 5df8bae1dSRodney W. Grimes * 6df8bae1dSRodney W. Grimes * This code is derived from software contributed to Berkeley by 7df8bae1dSRodney W. Grimes * the Systems Programming Group of the University of Utah Computer 8df8bae1dSRodney W. Grimes * Science Department. 9df8bae1dSRodney W. Grimes * 10df8bae1dSRodney W. Grimes * Redistribution and use in source and binary forms, with or without 11df8bae1dSRodney W. Grimes * modification, are permitted provided that the following conditions 12df8bae1dSRodney W. Grimes * are met: 13df8bae1dSRodney W. Grimes * 1. Redistributions of source code must retain the above copyright 14df8bae1dSRodney W. Grimes * notice, this list of conditions and the following disclaimer. 15df8bae1dSRodney W. Grimes * 2. Redistributions in binary form must reproduce the above copyright 16df8bae1dSRodney W. Grimes * notice, this list of conditions and the following disclaimer in the 17df8bae1dSRodney W. Grimes * documentation and/or other materials provided with the distribution. 18df8bae1dSRodney W. Grimes * 3. All advertising materials mentioning features or use of this software 19df8bae1dSRodney W. Grimes * must display the following acknowledgement: 20df8bae1dSRodney W. Grimes * This product includes software developed by the University of 21df8bae1dSRodney W. Grimes * California, Berkeley and its contributors. 22df8bae1dSRodney W. Grimes * 4. Neither the name of the University nor the names of its contributors 23df8bae1dSRodney W. Grimes * may be used to endorse or promote products derived from this software 24df8bae1dSRodney W. Grimes * without specific prior written permission. 25df8bae1dSRodney W. Grimes * 26df8bae1dSRodney W. Grimes * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 27df8bae1dSRodney W. Grimes * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 28df8bae1dSRodney W. Grimes * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 29df8bae1dSRodney W. Grimes * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 30df8bae1dSRodney W. Grimes * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 31df8bae1dSRodney W. Grimes * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 32df8bae1dSRodney W. Grimes * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 33df8bae1dSRodney W. Grimes * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 34df8bae1dSRodney W. Grimes * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 35df8bae1dSRodney W. Grimes * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 36df8bae1dSRodney W. Grimes * SUCH DAMAGE. 37df8bae1dSRodney W. Grimes * 3826f9a767SRodney W. Grimes * from: @(#)swap_pager.h 7.1 (Berkeley) 12/5/90 3926f9a767SRodney W. Grimes * $Id: swap_pager.h,v 1.9 1994/03/14 21:54:23 davidg Exp $ 4026f9a767SRodney W. Grimes */ 4126f9a767SRodney W. Grimes 4226f9a767SRodney W. Grimes /* 4326f9a767SRodney W. Grimes * Modifications to the block allocation data structure by John S. Dyson 4426f9a767SRodney W. Grimes * 18 Dec 93. 45df8bae1dSRodney W. Grimes */ 46df8bae1dSRodney W. Grimes 47df8bae1dSRodney W. Grimes #ifndef _SWAP_PAGER_ 48df8bae1dSRodney W. Grimes #define _SWAP_PAGER_ 1 49df8bae1dSRodney W. Grimes 50df8bae1dSRodney W. Grimes /* 5126f9a767SRodney W. Grimes * SWB_NPAGES can be set to any value from 1 to 16 pages per allocation, 5226f9a767SRodney W. Grimes * however, due to the allocation spilling into non-swap pager backed memory, 5326f9a767SRodney W. Grimes * suggest keeping SWB_NPAGES small (1-4). If high performance is manditory 5426f9a767SRodney W. Grimes * perhaps up to 8 pages might be in order???? 5526f9a767SRodney W. Grimes * Above problem has been fixed, now we support 16 pages per block. Unused 5626f9a767SRodney W. Grimes * space is recovered by the swap pager now... 57df8bae1dSRodney W. Grimes */ 5826f9a767SRodney W. Grimes #define SWB_NPAGES 8 59df8bae1dSRodney W. Grimes struct swblock { 6026f9a767SRodney W. Grimes unsigned short swb_valid; /* bitmask for valid pages */ 6126f9a767SRodney W. Grimes unsigned short swb_locked; /* block locked */ 6226f9a767SRodney W. Grimes int swb_block[SWB_NPAGES]; /* unfortunately int instead of daddr_t */ 63df8bae1dSRodney W. Grimes }; 64df8bae1dSRodney W. Grimes typedef struct swblock *sw_blk_t; 65df8bae1dSRodney W. Grimes 66df8bae1dSRodney W. Grimes /* 67df8bae1dSRodney W. Grimes * Swap pager private data. 68df8bae1dSRodney W. Grimes */ 69df8bae1dSRodney W. Grimes struct swpager { 70df8bae1dSRodney W. Grimes vm_size_t sw_osize; /* size of object we are backing (bytes) */ 71df8bae1dSRodney W. Grimes int sw_nblocks;/* number of blocks in list (sw_blk_t units) */ 72df8bae1dSRodney W. Grimes sw_blk_t sw_blocks; /* pointer to list of swap blocks */ 73df8bae1dSRodney W. Grimes short sw_flags; /* flags */ 74df8bae1dSRodney W. Grimes short sw_poip; /* pageouts in progress */ 7526f9a767SRodney W. Grimes short sw_piip; /* pageins in progress */ 76df8bae1dSRodney W. Grimes }; 77df8bae1dSRodney W. Grimes typedef struct swpager *sw_pager_t; 78df8bae1dSRodney W. Grimes 79df8bae1dSRodney W. Grimes #define SW_WANTED 0x01 80df8bae1dSRodney W. Grimes #define SW_NAMED 0x02 81df8bae1dSRodney W. Grimes 8226f9a767SRodney W. Grimes #ifdef KERNEL 8326f9a767SRodney W. Grimes 8426f9a767SRodney W. Grimes void swap_pager_init(void); 8526f9a767SRodney W. Grimes vm_pager_t swap_pager_alloc(caddr_t, vm_size_t, vm_prot_t, vm_offset_t); 8626f9a767SRodney W. Grimes void swap_pager_dealloc(vm_pager_t); 8726f9a767SRodney W. Grimes boolean_t swap_pager_getpage(vm_pager_t, vm_page_t, boolean_t); 8826f9a767SRodney W. Grimes boolean_t swap_pager_putpage(vm_pager_t, vm_page_t, boolean_t); 8926f9a767SRodney W. Grimes boolean_t swap_pager_getmulti(vm_pager_t, vm_page_t *, int, int, boolean_t); 9026f9a767SRodney W. Grimes boolean_t swap_pager_haspage(vm_pager_t, vm_offset_t); 9126f9a767SRodney W. Grimes int swap_pager_io(sw_pager_t, vm_page_t *, int, int, int); 9226f9a767SRodney W. Grimes void swap_pager_iodone(struct buf *); 9326f9a767SRodney W. Grimes boolean_t swap_pager_clean(); 9426f9a767SRodney W. Grimes 9526f9a767SRodney W. Grimes extern struct pagerops swappagerops; 9626f9a767SRodney W. Grimes 9726f9a767SRodney W. Grimes #endif 9826f9a767SRodney W. Grimes 99df8bae1dSRodney W. Grimes #endif /* _SWAP_PAGER_ */ 100