swap_pager.c (130585) | swap_pager.c (130640) |
---|---|
1/* 2 * Copyright (c) 1998 Matthew Dillon, 3 * Copyright (c) 1994 John S. Dyson 4 * Copyright (c) 1990 University of Utah. 5 * Copyright (c) 1982, 1986, 1989, 1993 6 * The Regents of the University of California. All rights reserved. 7 * 8 * This code is derived from software contributed to Berkeley by --- 53 unchanged lines hidden (view full) --- 62 * 63 * from: Utah $Hdr: swap_pager.c 1.4 91/04/30$ 64 * 65 * @(#)swap_pager.c 8.9 (Berkeley) 3/21/94 66 * @(#)vm_swap.c 8.5 (Berkeley) 2/17/94 67 */ 68 69#include <sys/cdefs.h> | 1/* 2 * Copyright (c) 1998 Matthew Dillon, 3 * Copyright (c) 1994 John S. Dyson 4 * Copyright (c) 1990 University of Utah. 5 * Copyright (c) 1982, 1986, 1989, 1993 6 * The Regents of the University of California. All rights reserved. 7 * 8 * This code is derived from software contributed to Berkeley by --- 53 unchanged lines hidden (view full) --- 62 * 63 * from: Utah $Hdr: swap_pager.c 1.4 91/04/30$ 64 * 65 * @(#)swap_pager.c 8.9 (Berkeley) 3/21/94 66 * @(#)vm_swap.c 8.5 (Berkeley) 2/17/94 67 */ 68 69#include <sys/cdefs.h> |
70__FBSDID("$FreeBSD: head/sys/vm/swap_pager.c 130585 2004-06-16 09:47:26Z phk $"); | 70__FBSDID("$FreeBSD: head/sys/vm/swap_pager.c 130640 2004-06-17 17:16:53Z phk $"); |
71 72#include "opt_mac.h" 73#include "opt_swap.h" 74#include "opt_vm.h" 75 76#include <sys/param.h> 77#include <sys/systm.h> 78#include <sys/conf.h> --- 70 unchanged lines hidden (view full) --- 149 150/* 151 * Swap device table 152 */ 153struct swdevt { 154 int sw_flags; 155 int sw_nblks; 156 int sw_used; | 71 72#include "opt_mac.h" 73#include "opt_swap.h" 74#include "opt_vm.h" 75 76#include <sys/param.h> 77#include <sys/systm.h> 78#include <sys/conf.h> --- 70 unchanged lines hidden (view full) --- 149 150/* 151 * Swap device table 152 */ 153struct swdevt { 154 int sw_flags; 155 int sw_nblks; 156 int sw_used; |
157 udev_t sw_udev; | 157 dev_t sw_dev; |
158 struct vnode *sw_vp; 159 void *sw_id; 160 swblk_t sw_first; 161 swblk_t sw_end; 162 struct blist *sw_blist; 163 TAILQ_ENTRY(swdevt) sw_list; 164 sw_strategy_t *sw_strategy; 165 sw_close_t *sw_close; --- 1908 unchanged lines hidden (view full) --- 2074 swdev_syscall_active = 0; 2075 wakeup_one(&swdev_syscall_active); 2076done2: 2077 mtx_unlock(&Giant); 2078 return (error); 2079} 2080 2081static void | 158 struct vnode *sw_vp; 159 void *sw_id; 160 swblk_t sw_first; 161 swblk_t sw_end; 162 struct blist *sw_blist; 163 TAILQ_ENTRY(swdevt) sw_list; 164 sw_strategy_t *sw_strategy; 165 sw_close_t *sw_close; --- 1908 unchanged lines hidden (view full) --- 2074 swdev_syscall_active = 0; 2075 wakeup_one(&swdev_syscall_active); 2076done2: 2077 mtx_unlock(&Giant); 2078 return (error); 2079} 2080 2081static void |
2082swaponsomething(struct vnode *vp, void *id, u_long nblks, sw_strategy_t *strategy, sw_close_t *close, udev_t udev) | 2082swaponsomething(struct vnode *vp, void *id, u_long nblks, sw_strategy_t *strategy, sw_close_t *close, dev_t dev) |
2083{ 2084 struct swdevt *sp, *tsp; 2085 swblk_t dvbase; 2086 u_long mblocks; 2087 2088 /* 2089 * If we go beyond this, we get overflows in the radix 2090 * tree bitmap code. --- 11 unchanged lines hidden (view full) --- 2102 * sw->sw_nblks is in page-sized chunks now too. 2103 */ 2104 nblks &= ~(ctodb(1) - 1); 2105 nblks = dbtoc(nblks); 2106 2107 sp = malloc(sizeof *sp, M_VMPGDATA, M_WAITOK | M_ZERO); 2108 sp->sw_vp = vp; 2109 sp->sw_id = id; | 2083{ 2084 struct swdevt *sp, *tsp; 2085 swblk_t dvbase; 2086 u_long mblocks; 2087 2088 /* 2089 * If we go beyond this, we get overflows in the radix 2090 * tree bitmap code. --- 11 unchanged lines hidden (view full) --- 2102 * sw->sw_nblks is in page-sized chunks now too. 2103 */ 2104 nblks &= ~(ctodb(1) - 1); 2105 nblks = dbtoc(nblks); 2106 2107 sp = malloc(sizeof *sp, M_VMPGDATA, M_WAITOK | M_ZERO); 2108 sp->sw_vp = vp; 2109 sp->sw_id = id; |
2110 sp->sw_udev = udev; | 2110 sp->sw_dev = dev; |
2111 sp->sw_flags = 0; 2112 sp->sw_nblks = nblks; 2113 sp->sw_used = 0; 2114 sp->sw_strategy = strategy; 2115 sp->sw_close = close; 2116 2117 sp->sw_blist = blist_create(nblks); 2118 /* --- 169 unchanged lines hidden (view full) --- 2288 return (EINVAL); 2289 2290 n = 0; 2291 mtx_lock(&sw_dev_mtx); 2292 TAILQ_FOREACH(sp, &swtailq, sw_list) { 2293 if (n == *name) { 2294 mtx_unlock(&sw_dev_mtx); 2295 xs.xsw_version = XSWDEV_VERSION; | 2111 sp->sw_flags = 0; 2112 sp->sw_nblks = nblks; 2113 sp->sw_used = 0; 2114 sp->sw_strategy = strategy; 2115 sp->sw_close = close; 2116 2117 sp->sw_blist = blist_create(nblks); 2118 /* --- 169 unchanged lines hidden (view full) --- 2288 return (EINVAL); 2289 2290 n = 0; 2291 mtx_lock(&sw_dev_mtx); 2292 TAILQ_FOREACH(sp, &swtailq, sw_list) { 2293 if (n == *name) { 2294 mtx_unlock(&sw_dev_mtx); 2295 xs.xsw_version = XSWDEV_VERSION; |
2296 xs.xsw_dev = sp->sw_udev; | 2296 xs.xsw_dev = sp->sw_dev; |
2297 xs.xsw_flags = sp->sw_flags; 2298 xs.xsw_nblks = sp->sw_nblks; 2299 xs.xsw_used = sp->sw_used; 2300 2301 error = SYSCTL_OUT(req, &xs, sizeof(xs)); 2302 return (error); 2303 } 2304 n++; --- 223 unchanged lines hidden (view full) --- 2528 */ 2529 2530static void 2531swapdev_strategy(struct buf *bp, struct swdevt *sp) 2532{ 2533 int s; 2534 struct vnode *vp, *vp2; 2535 | 2297 xs.xsw_flags = sp->sw_flags; 2298 xs.xsw_nblks = sp->sw_nblks; 2299 xs.xsw_used = sp->sw_used; 2300 2301 error = SYSCTL_OUT(req, &xs, sizeof(xs)); 2302 return (error); 2303 } 2304 n++; --- 223 unchanged lines hidden (view full) --- 2528 */ 2529 2530static void 2531swapdev_strategy(struct buf *bp, struct swdevt *sp) 2532{ 2533 int s; 2534 struct vnode *vp, *vp2; 2535 |
2536 bp->b_dev = NODEV; | 2536 bp->b_dev = NULL; |
2537 bp->b_blkno = ctodb(bp->b_blkno - sp->sw_first); 2538 2539 vp2 = sp->sw_id; 2540 vhold(vp2); 2541 s = splvm(); 2542 if (bp->b_iocmd == BIO_WRITE) { 2543 vp = bp->b_vp; 2544 if (vp) { --- 48 unchanged lines hidden (view full) --- 2593 if (error == 0) 2594#endif 2595 error = VOP_OPEN(vp, FREAD | FWRITE, td->td_ucred, td, -1); 2596 (void) VOP_UNLOCK(vp, 0, td); 2597 if (error) 2598 return (error); 2599 2600 swaponsomething(vp, vp, nblks, swapdev_strategy, swapdev_close, | 2537 bp->b_blkno = ctodb(bp->b_blkno - sp->sw_first); 2538 2539 vp2 = sp->sw_id; 2540 vhold(vp2); 2541 s = splvm(); 2542 if (bp->b_iocmd == BIO_WRITE) { 2543 vp = bp->b_vp; 2544 if (vp) { --- 48 unchanged lines hidden (view full) --- 2593 if (error == 0) 2594#endif 2595 error = VOP_OPEN(vp, FREAD | FWRITE, td->td_ucred, td, -1); 2596 (void) VOP_UNLOCK(vp, 0, td); 2597 if (error) 2598 return (error); 2599 2600 swaponsomething(vp, vp, nblks, swapdev_strategy, swapdev_close, |
2601 NOUDEV); | 2601 NODEV); |
2602 return (0); 2603} | 2602 return (0); 2603} |