The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/contrib/openzfs/include/sys/zfs_ioctl_impl.h

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 /*
    2  * CDDL HEADER START
    3  *
    4  * The contents of this file are subject to the terms of the
    5  * Common Development and Distribution License (the "License").
    6  * You may not use this file except in compliance with the License.
    7  *
    8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
    9  * or https://opensource.org/licenses/CDDL-1.0.
   10  * See the License for the specific language governing permissions
   11  * and limitations under the License.
   12  *
   13  * When distributing Covered Code, include this CDDL HEADER in each
   14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
   15  * If applicable, add the following below this CDDL HEADER, with the
   16  * fields enclosed by brackets "[]" replaced with your own identifying
   17  * information: Portions Copyright [yyyy] [name of copyright owner]
   18  *
   19  * CDDL HEADER END
   20  */
   21 
   22 
   23 #ifndef _ZFS_IOCTL_IMPL_H_
   24 #define _ZFS_IOCTL_IMPL_H_
   25 
   26 extern kmutex_t zfsdev_state_lock;
   27 extern uint64_t zfs_max_nvlist_src_size;
   28 
   29 typedef int zfs_ioc_legacy_func_t(zfs_cmd_t *);
   30 typedef int zfs_ioc_func_t(const char *, nvlist_t *, nvlist_t *);
   31 typedef int zfs_secpolicy_func_t(zfs_cmd_t *, nvlist_t *, cred_t *);
   32 
   33 typedef enum {
   34         POOL_CHECK_NONE         = 1 << 0,
   35         POOL_CHECK_SUSPENDED    = 1 << 1,
   36         POOL_CHECK_READONLY     = 1 << 2,
   37 } zfs_ioc_poolcheck_t;
   38 
   39 typedef enum {
   40         NO_NAME,
   41         POOL_NAME,
   42         DATASET_NAME,
   43         ENTITY_NAME
   44 } zfs_ioc_namecheck_t;
   45 
   46 /*
   47  * IOC Keys are used to document and validate user->kernel interface inputs.
   48  * See zfs_keys_recv_new for an example declaration. Any key name that is not
   49  * listed will be rejected as input.
   50  *
   51  * The keyname 'optional' is always allowed, and must be an nvlist if present.
   52  * Arguments which older kernels can safely ignore can be placed under the
   53  * "optional" key.
   54  *
   55  * When adding new keys to an existing ioc for new functionality, consider:
   56  *      - adding an entry into zfs_sysfs.c zfs_features[] list
   57  *      - updating the libzfs_input_check.c test utility
   58  *
   59  * Note: in the ZK_WILDCARDLIST case, the name serves as documentation
   60  * for the expected name (bookmark, snapshot, property, etc) but there
   61  * is no validation in the preflight zfs_check_input_nvpairs() check.
   62  */
   63 typedef enum {
   64         ZK_OPTIONAL = 1 << 0,           /* pair is optional */
   65         ZK_WILDCARDLIST = 1 << 1,       /* one or more unspecified key names */
   66 } ioc_key_flag_t;
   67 
   68 typedef struct zfs_ioc_key {
   69         const char      *zkey_name;
   70         data_type_t     zkey_type;
   71         ioc_key_flag_t  zkey_flags;
   72 } zfs_ioc_key_t;
   73 
   74 int zfs_secpolicy_config(zfs_cmd_t *, nvlist_t *, cred_t *);
   75 
   76 void zfs_ioctl_register_dataset_nolog(zfs_ioc_t, zfs_ioc_legacy_func_t *,
   77     zfs_secpolicy_func_t *, zfs_ioc_poolcheck_t);
   78 
   79 void zfs_ioctl_register(const char *, zfs_ioc_t, zfs_ioc_func_t *,
   80     zfs_secpolicy_func_t *, zfs_ioc_namecheck_t, zfs_ioc_poolcheck_t,
   81     boolean_t, boolean_t, const zfs_ioc_key_t *, size_t);
   82 
   83 uint64_t zfs_max_nvlist_src_size_os(void);
   84 void zfs_ioctl_update_mount_cache(const char *dsname);
   85 void zfs_ioctl_init_os(void);
   86 
   87 boolean_t zfs_vfs_held(zfsvfs_t *);
   88 int zfs_vfs_ref(zfsvfs_t **);
   89 void zfs_vfs_rele(zfsvfs_t *);
   90 
   91 long zfsdev_ioctl_common(uint_t, zfs_cmd_t *, int);
   92 int zfsdev_attach(void);
   93 void zfsdev_detach(void);
   94 void zfsdev_private_set_state(void *, zfsdev_state_t *);
   95 zfsdev_state_t *zfsdev_private_get_state(void *);
   96 int zfsdev_state_init(void *);
   97 void zfsdev_state_destroy(void *);
   98 int zfs_kmod_init(void);
   99 void zfs_kmod_fini(void);
  100 
  101 #endif

Cache object: f586a2337dad2c400984b5ecfa6b04fe


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.