1d167cf6fSWarner Losh /*- 251369649SPedro F. Giffuni * SPDX-License-Identifier: BSD-3-Clause 351369649SPedro F. Giffuni * 4df8bae1dSRodney W. Grimes * Copyright (c) 1992, 1993 5df8bae1dSRodney W. Grimes * The Regents of the University of California. All rights reserved. 6df8bae1dSRodney W. Grimes * 7df8bae1dSRodney W. Grimes * This code is derived from software donated to Berkeley by 8df8bae1dSRodney W. Grimes * Jan-Simon Pendry. 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. 18fbbd9655SWarner Losh * 3. Neither the name of the University nor the names of its contributors 19df8bae1dSRodney W. Grimes * may be used to endorse or promote products derived from this software 20df8bae1dSRodney W. Grimes * without specific prior written permission. 21df8bae1dSRodney W. Grimes * 22df8bae1dSRodney W. Grimes * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 23df8bae1dSRodney W. Grimes * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 24df8bae1dSRodney W. Grimes * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 25df8bae1dSRodney W. Grimes * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 26df8bae1dSRodney W. Grimes * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 27df8bae1dSRodney W. Grimes * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 28df8bae1dSRodney W. Grimes * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 29df8bae1dSRodney W. Grimes * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 30df8bae1dSRodney W. Grimes * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 31df8bae1dSRodney W. Grimes * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 32df8bae1dSRodney W. Grimes * SUCH DAMAGE. 33df8bae1dSRodney W. Grimes */ 34df8bae1dSRodney W. Grimes 359cf4c952SKonstantin Belousov #ifndef FS_NULL_H 369cf4c952SKonstantin Belousov #define FS_NULL_H 379cf4c952SKonstantin Belousov 389cf4c952SKonstantin Belousov #define NULLM_CACHE 0x0001 399cf4c952SKonstantin Belousov 40df8bae1dSRodney W. Grimes struct null_mount { 41df8bae1dSRodney W. Grimes struct mount *nullm_vfs; 425fc9e11cSKonstantin Belousov struct vnode *nullm_lowerrootvp; /* Ref to lower root vnode */ 439cf4c952SKonstantin Belousov uint64_t nullm_flags; 44*c746ed72SJason A. Harmening struct mount_upper_node upper_node; 45*c746ed72SJason A. Harmening struct mount_upper_node notify_node; 46df8bae1dSRodney W. Grimes }; 47df8bae1dSRodney W. Grimes 48c4473420SPeter Wemm #ifdef _KERNEL 49df8bae1dSRodney W. Grimes /* 50df8bae1dSRodney W. Grimes * A cache of vnode references 51df8bae1dSRodney W. Grimes */ 52df8bae1dSRodney W. Grimes struct null_node { 53e3975643SJake Burkholder LIST_ENTRY(null_node) null_hash; /* Hash list */ 54df8bae1dSRodney W. Grimes struct vnode *null_lowervp; /* VREFed once */ 55df8bae1dSRodney W. Grimes struct vnode *null_vnode; /* Back pointer */ 560fc6daa7SKonstantin Belousov u_int null_flags; 57df8bae1dSRodney W. Grimes }; 58df8bae1dSRodney W. Grimes 590fc6daa7SKonstantin Belousov #define NULLV_NOUNLOCK 0x0001 600fc6daa7SKonstantin Belousov #define NULLV_DROP 0x0002 610fc6daa7SKonstantin Belousov 62df8bae1dSRodney W. Grimes #define MOUNTTONULLMOUNT(mp) ((struct null_mount *)((mp)->mnt_data)) 63df8bae1dSRodney W. Grimes #define VTONULL(vp) ((struct null_node *)(vp)->v_data) 64df8bae1dSRodney W. Grimes #define NULLTOV(xp) ((xp)->null_vnode) 657da1e3f0SBoris Popov 667da1e3f0SBoris Popov int nullfs_init(struct vfsconf *vfsp); 678da80660SBoris Popov int nullfs_uninit(struct vfsconf *vfsp); 681cfdefbbSSemen Ustimenko int null_nodeget(struct mount *mp, struct vnode *target, struct vnode **vpp); 69d9e9650aSKonstantin Belousov struct vnode *null_hashget(struct mount *mp, struct vnode *lowervp); 7008720e34SSemen Ustimenko void null_hashrem(struct null_node *xp); 717da1e3f0SBoris Popov int null_bypass(struct vop_generic_args *ap); 727da1e3f0SBoris Popov 73a0f40f54SBruce Evans #ifdef DIAGNOSTIC 747da1e3f0SBoris Popov struct vnode *null_checkvp(struct vnode *vp, char *fil, int lno); 75df8bae1dSRodney W. Grimes #define NULLVPTOLOWERVP(vp) null_checkvp((vp), __FILE__, __LINE__) 76df8bae1dSRodney W. Grimes #else 77df8bae1dSRodney W. Grimes #define NULLVPTOLOWERVP(vp) (VTONULL(vp)->null_lowervp) 78df8bae1dSRodney W. Grimes #endif 79df8bae1dSRodney W. Grimes 80aec0fb7bSPoul-Henning Kamp extern struct vop_vector null_vnodeops; 818da80660SBoris Popov 828da80660SBoris Popov #ifdef MALLOC_DECLARE 838da80660SBoris Popov MALLOC_DECLARE(M_NULLFSNODE); 848da80660SBoris Popov #endif 858da80660SBoris Popov 868da80660SBoris Popov #ifdef NULLFS_DEBUG 878da80660SBoris Popov #define NULLFSDEBUG(format, args...) printf(format ,## args) 888da80660SBoris Popov #else 898da80660SBoris Popov #define NULLFSDEBUG(format, args...) 908da80660SBoris Popov #endif /* NULLFS_DEBUG */ 917da1e3f0SBoris Popov 92c4473420SPeter Wemm #endif /* _KERNEL */ 939cf4c952SKonstantin Belousov 949cf4c952SKonstantin Belousov #endif 95