1*f41cc18eSchristos /* $NetBSD: vnode.h,v 1.6 2021/09/17 22:41:48 christos Exp $ */ 2ba10361aSperseant /*- 3ba10361aSperseant * Copyright (c) 2003 The NetBSD Foundation, Inc. 4ba10361aSperseant * All rights reserved. 5ba10361aSperseant * 6ba10361aSperseant * This code is derived from software contributed to The NetBSD Foundation 7ba10361aSperseant * by Konrad E. Schroder <perseant@hhhh.org>. 8ba10361aSperseant * 9ba10361aSperseant * Redistribution and use in source and binary forms, with or without 10ba10361aSperseant * modification, are permitted provided that the following conditions 11ba10361aSperseant * are met: 12ba10361aSperseant * 1. Redistributions of source code must retain the above copyright 13ba10361aSperseant * notice, this list of conditions and the following disclaimer. 14ba10361aSperseant * 2. Redistributions in binary form must reproduce the above copyright 15ba10361aSperseant * notice, this list of conditions and the following disclaimer in the 16ba10361aSperseant * documentation and/or other materials provided with the distribution. 17ba10361aSperseant * 18ba10361aSperseant * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 19ba10361aSperseant * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 20ba10361aSperseant * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 21ba10361aSperseant * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 22ba10361aSperseant * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 23ba10361aSperseant * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 24ba10361aSperseant * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 25ba10361aSperseant * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 26ba10361aSperseant * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 27ba10361aSperseant * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 28ba10361aSperseant * POSSIBILITY OF SUCH DAMAGE. 29ba10361aSperseant */ 301d4cc6a1Sperseant 318903716bSchs #include <sys/queue.h> 328903716bSchs 331d4cc6a1Sperseant #define VNODE_HASH_MAX 1024 /* Must be a PO2 */ 341d4cc6a1Sperseant #define VNODE_CACHE_SIZE 1024 /* Need not be a PO2 */ 35ba10361aSperseant 36ba10361aSperseant LIST_HEAD(ubuflists, ubuf); 37ba10361aSperseant LIST_HEAD(uvnodelst, uvnode); 38ba10361aSperseant LIST_HEAD(vgrlst, vget_reg); 39ba10361aSperseant 40ba10361aSperseant struct uvnode { 41ba10361aSperseant int v_fd; 42ba10361aSperseant int (*v_strategy_op) (struct ubuf *); 43ba10361aSperseant int (*v_bwrite_op) (struct ubuf *); 44ba10361aSperseant int (*v_bmap_op) (struct uvnode *, daddr_t, daddr_t *); 457dad9f73Sad u_int32_t v_uflag; 46ba10361aSperseant void *v_fs; 47ba10361aSperseant void *v_data; 48ba10361aSperseant #undef v_usecount 49ba10361aSperseant int v_usecount; 50ba10361aSperseant struct ubuflists v_cleanblkhd; /* clean blocklist head */ 51ba10361aSperseant struct ubuflists v_dirtyblkhd; /* dirty blocklist head */ 52ba10361aSperseant LIST_ENTRY(uvnode) v_mntvnodes; 53ba10361aSperseant LIST_ENTRY(uvnode) v_getvnodes; 54ba10361aSperseant }; 55ba10361aSperseant 56ba10361aSperseant struct vget_reg { 57ba10361aSperseant void *vgr_fs; 58ba10361aSperseant struct uvnode *(*vgr_func) (void *, ino_t); 59ba10361aSperseant LIST_ENTRY(vget_reg) vgr_list; 60ba10361aSperseant }; 61ba10361aSperseant 62ba10361aSperseant #define VOP_STRATEGY(bp) ((bp)->b_vp->v_strategy_op(bp)) 63ba10361aSperseant #define VOP_BWRITE(bp) ((bp)->b_vp->v_bwrite_op(bp)) 64ba10361aSperseant #define VOP_BMAP(vp, lbn, daddrp) ((vp)->v_bmap_op((vp), (lbn), (daddrp))) 65ba10361aSperseant 66ba10361aSperseant extern int fsdirty; 67ba10361aSperseant extern struct uvnodelst vnodelist; 68ba10361aSperseant 69ba10361aSperseant int raw_vop_strategy(struct ubuf *); 70ba10361aSperseant int raw_vop_bwrite(struct ubuf *); 71ba10361aSperseant int raw_vop_bmap(struct uvnode *, daddr_t, daddr_t *); 72ba10361aSperseant 73ba10361aSperseant void vnode_destroy(struct uvnode *); 74ba10361aSperseant struct uvnode *vget(void *, ino_t); 75*f41cc18eSchristos void register_vget(void *, struct uvnode *(*)(void *, ino_t)); 76ba10361aSperseant void vfs_init(void); 77