1/* $NetBSD: vfs.h,v 1.5 2018/05/28 21:05:10 chs Exp $ */ 2 3/*- 4 * Copyright (c) 2007 Pawel Jakub Dawidek <pjd@FreeBSD.org> 5 * All rights reserved. 6 * 7 * Redistribution and use in source and binary forms, with or without 8 * modification, are permitted provided that the following conditions 9 * are met: 10 * 1. Redistributions of source code must retain the above copyright 11 * notice, this list of conditions and the following disclaimer. 12 * 2. Redistributions in binary form must reproduce the above copyright 13 * notice, this list of conditions and the following disclaimer in the 14 * documentation and/or other materials provided with the distribution. 15 * 16 * THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND 17 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 19 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE 20 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 21 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 22 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 23 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 24 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 25 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 26 * SUCH DAMAGE. 27 * 28 * $FreeBSD: head/sys/cddl/compat/opensolaris/sys/vfs.h 297513 2016-04-02 16:25:46Z avg $ 29 */ 30 31#ifndef _OPENSOLARIS_SYS_VFS_H_ 32#define _OPENSOLARIS_SYS_VFS_H_ 33 34#include <sys/param.h> 35 36#ifdef _KERNEL 37 38#include <sys/mount.h> 39#include <sys/vnode.h> 40 41#define rootdir rootvnode 42 43typedef struct mount vfs_t; 44 45#define vfs_flag mnt_flag 46#define vfs_data mnt_data 47#define vfs_count mnt_refcnt 48#define vfs_bsize mnt_stat.f_bsize 49#define vfs_resource mnt_stat.f_mntfromname 50 51#define v_flag v_vflag 52#define v_vfsp v_mount 53 54#define VFS_RDONLY MNT_RDONLY 55#define VFS_NOSETUID MNT_NOSUID 56#define VFS_NOEXEC MNT_NOEXEC 57 58#define fs_vscan(vp, cr, async) (0) 59 60#define VROOT VV_ROOT 61 62/* 63 * Structure defining a mount option for a filesystem. 64 * option names are found in mntent.h 65 */ 66typedef struct mntopt { 67 char *mo_name; /* option name */ 68 char **mo_cancel; /* list of options cancelled by this one */ 69 char *mo_arg; /* argument string for this option */ 70 int mo_flags; /* flags for this mount option */ 71 void *mo_data; /* filesystem specific data */ 72} mntopt_t; 73 74/* 75 * Flags that apply to mount options 76 */ 77 78#define MO_SET 0x01 /* option is set */ 79#define MO_NODISPLAY 0x02 /* option not listed in mnttab */ 80#define MO_HASVALUE 0x04 /* option takes a value */ 81#define MO_IGNORE 0x08 /* option ignored by parser */ 82#define MO_DEFAULT MO_SET /* option is on by default */ 83#define MO_TAG 0x10 /* flags a tag set by user program */ 84#define MO_EMPTY 0x20 /* empty space in option table */ 85 86#define VFS_NOFORCEOPT 0x01 /* honor MO_IGNORE (don't set option) */ 87#define VFS_DISPLAY 0x02 /* Turn off MO_NODISPLAY bit for opt */ 88#define VFS_NODISPLAY 0x04 /* Turn on MO_NODISPLAY bit for opt */ 89#define VFS_CREATEOPT 0x08 /* Create the opt if it's not there */ 90#define VFS_UNMOUNTED 0x100 /* file system has been unmounted */ 91 92/* 93 * Structure holding mount option strings for the mounted file system. 94 */ 95typedef struct mntopts { 96 uint_t mo_count; /* number of entries in table */ 97 mntopt_t *mo_list; /* list of mount options */ 98} mntopts_t; 99 100 /* 101 * Argument structure for mount(2). 102 * 103 * Flags are defined in <sys/mount.h>. 104 * 105 * Note that if the MS_SYSSPACE bit is set in flags, the pointer fields in 106 * this structure are to be interpreted as kernel addresses. File systems 107 * should be prepared for this possibility. 108 */ 109struct mounta { 110 char fspec[MAXNAMELEN - 1]; 111 char dataptr[MAXPATHLEN]; 112 char optptr[MAXPATHLEN]; 113 char *fstype; /* Unused */ 114 int mflag; 115 int datalen; 116 int optlen; 117 int flags; /* Unused */ 118}; 119 120#define vfs_devismounted(dev) 0 121 122void vfs_setmntopt(vfs_t *vfsp, const char *name, const char *arg, 123 int flags __unused); 124void vfs_clearmntopt(vfs_t *vfsp, const char *name); 125int vfs_optionisset(const vfs_t *vfsp, const char *opt, char **argp); 126int mount_snapshot(kthread_t *td, vnode_t **vpp, const char *fstype, 127 char *fspath, char *fspec, int fsflags); 128 129typedef uint64_t vfs_feature_t; 130 131#define VFSFT_XVATTR 0x100000001 /* Supports xvattr for attrs */ 132#define VFSFT_CASEINSENSITIVE 0x100000002 /* Supports case-insensitive */ 133#define VFSFT_NOCASESENSITIVE 0x100000004 /* NOT case-sensitive */ 134#define VFSFT_DIRENTFLAGS 0x100000008 /* Supports dirent flags */ 135#define VFSFT_ACLONCREATE 0x100000010 /* Supports ACL on create */ 136#define VFSFT_ACEMASKONACCESS 0x100000020 /* Can use ACEMASK for access */ 137#define VFSFT_SYSATTR_VIEWS 0x100000040 /* Supports sysattr view i/f */ 138#define VFSFT_ACCESS_FILTER 0x100000080 /* dirents filtered by access */ 139#define VFSFT_REPARSE 0x100000100 /* Supports reparse point */ 140#define VFSFT_ZEROCOPY_SUPPORTED 0x100000200 141 /* Support loaning /returning cache buffer */ 142 143#define vfs_set_feature(vfsp, feature) do { } while (0) 144#define vfs_clear_feature(vfsp, feature) do { } while (0) 145#define vfs_has_feature(vfsp, feature) (0) 146 147#define VFS_HOLD(vfsp) do { \ 148 /* XXXNETBSD nothing */ \ 149} while (0) 150#define VFS_RELE(vfsp) do { \ 151 /* XXXNETBSD nothing */ \ 152} while (0) 153 154#endif /* _KERNEL */ 155 156#endif /* _OPENSOLARIS_SYS_VFS_H_ */ 157