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.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
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]
23 * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
24 * Portions Copyright 2011 Martin Matuska
25 * Copyright 2015, OmniTI Computer Consulting, Inc. All rights reserved.
26 * Portions Copyright 2012 Pawel Jakub Dawidek <pawel@dawidek.net>
27 * Copyright (c) 2014, 2016 Joyent, Inc. All rights reserved.
28 * Copyright 2016 Nexenta Systems, Inc. All rights reserved.
29 * Copyright (c) 2014, Joyent, Inc. All rights reserved.
30 * Copyright (c) 2011, 2018 by Delphix. All rights reserved.
31 * Copyright (c) 2013 by Saso Kiselkov. All rights reserved.
32 * Copyright (c) 2013 Steven Hartland. All rights reserved.
33 * Copyright (c) 2014 Integros [integros.com]
34 * Copyright 2016 Toomas Soome <tsoome@me.com>
35 * Copyright (c) 2016 Actifio, Inc. All rights reserved.
36 * Copyright (c) 2018, loli10K <ezomori.nozomu@gmail.com>. All rights reserved.
37 * Copyright 2017 RackTop Systems.
38 * Copyright (c) 2017 Open-E, Inc. All Rights Reserved.
39 * Copyright (c) 2019 Datto Inc.
42 #include <sys/types.h>
43 #include <sys/param.h>
44 #include <sys/errno.h>
49 #include <sys/zfs_ioctl.h>
50 #include <sys/zfs_vfsops.h>
53 #include <sys/nvpair.h>
54 #include <sys/fs/zfs.h>
55 #include <sys/zfs_ctldir.h>
56 #include <sys/zfs_dir.h>
57 #include <sys/zfs_onexit.h>
59 #include <sys/fm/util.h>
60 #include <sys/dsl_crypt.h>
62 #include <sys/zfs_ioctl_impl.h>
64 #include <sys/zfs_sysfs.h>
65 #include <linux/miscdevice.h>
66 #include <linux/slab.h>
69 zfs_vfs_held(zfsvfs_t *zfsvfs)
71 return (zfsvfs->z_sb != NULL);
75 zfs_vfs_ref(zfsvfs_t **zfvp)
77 if (*zfvp == NULL || (*zfvp)->z_sb == NULL ||
78 !atomic_inc_not_zero(&((*zfvp)->z_sb->s_active))) {
79 return (SET_ERROR(ESRCH));
85 zfs_vfs_rele(zfsvfs_t *zfsvfs)
87 deactivate_super(zfsvfs->z_sb);
91 zfsdev_state_init(struct file *filp)
93 zfsdev_state_t *zs, *zsprev = NULL;
95 boolean_t newzs = B_FALSE;
97 ASSERT(MUTEX_HELD(&zfsdev_state_lock));
99 minor = zfsdev_minor_alloc();
101 return (SET_ERROR(ENXIO));
103 for (zs = zfsdev_state_list; zs != NULL; zs = zs->zs_next) {
104 if (zs->zs_minor == -1)
110 zs = kmem_zalloc(sizeof (zfsdev_state_t), KM_SLEEP);
114 filp->private_data = zs;
116 zfs_onexit_init((zfs_onexit_t **)&zs->zs_onexit);
117 zfs_zevent_init((zfs_zevent_t **)&zs->zs_zevent);
120 * In order to provide for lock-free concurrent read access
121 * to the minor list in zfsdev_get_state_impl(), new entries
122 * must be completely written before linking them into the
123 * list whereas existing entries are already linked; the last
124 * operation must be updating zs_minor (from -1 to the new
128 zs->zs_minor = minor;
130 zsprev->zs_next = zs;
133 zs->zs_minor = minor;
140 zfsdev_state_destroy(struct file *filp)
144 ASSERT(MUTEX_HELD(&zfsdev_state_lock));
145 ASSERT(filp->private_data != NULL);
147 zs = filp->private_data;
149 zfs_onexit_destroy(zs->zs_onexit);
150 zfs_zevent_destroy(zs->zs_zevent);
151 zs->zs_onexit = NULL;
152 zs->zs_zevent = NULL;
158 zfsdev_open(struct inode *ino, struct file *filp)
162 mutex_enter(&zfsdev_state_lock);
163 error = zfsdev_state_init(filp);
164 mutex_exit(&zfsdev_state_lock);
170 zfsdev_release(struct inode *ino, struct file *filp)
174 mutex_enter(&zfsdev_state_lock);
175 error = zfsdev_state_destroy(filp);
176 mutex_exit(&zfsdev_state_lock);
182 zfsdev_ioctl(struct file *filp, unsigned cmd, unsigned long arg)
188 vecnum = cmd - ZFS_IOC_FIRST;
190 zc = kmem_zalloc(sizeof (zfs_cmd_t), KM_SLEEP);
192 if (ddi_copyin((void *)(uintptr_t)arg, zc, sizeof (zfs_cmd_t), 0)) {
193 error = -SET_ERROR(EFAULT);
196 error = -zfsdev_ioctl_common(vecnum, zc, 0);
197 rc = ddi_copyout(zc, (void *)(uintptr_t)arg, sizeof (zfs_cmd_t), 0);
198 if (error == 0 && rc != 0)
199 error = -SET_ERROR(EFAULT);
201 kmem_free(zc, sizeof (zfs_cmd_t));
207 zfs_max_nvlist_src_size_os(void)
209 if (zfs_max_nvlist_src_size != 0)
210 return (zfs_max_nvlist_src_size);
212 return (KMALLOC_MAX_SIZE);
216 zfs_ioctl_init_os(void)
222 zfsdev_compat_ioctl(struct file *filp, unsigned cmd, unsigned long arg)
224 return (zfsdev_ioctl(filp, cmd, arg));
227 #define zfsdev_compat_ioctl NULL
230 static const struct file_operations zfsdev_fops = {
232 .release = zfsdev_release,
233 .unlocked_ioctl = zfsdev_ioctl,
234 .compat_ioctl = zfsdev_compat_ioctl,
235 .owner = THIS_MODULE,
238 static struct miscdevice zfs_misc = {
239 .minor = ZFS_DEVICE_MINOR,
241 .fops = &zfsdev_fops,
244 MODULE_ALIAS_MISCDEV(ZFS_DEVICE_MINOR);
245 MODULE_ALIAS("devname:zfs");
252 error = misc_register(&zfs_misc);
253 if (error == -EBUSY) {
255 * Fallback to dynamic minor allocation in the event of a
256 * collision with a reserved minor in linux/miscdevice.h.
257 * In this case the kernel modules must be manually loaded.
259 printk(KERN_INFO "ZFS: misc_register() with static minor %d "
260 "failed %d, retrying with MISC_DYNAMIC_MINOR\n",
261 ZFS_DEVICE_MINOR, error);
263 zfs_misc.minor = MISC_DYNAMIC_MINOR;
264 error = misc_register(&zfs_misc);
268 printk(KERN_INFO "ZFS: misc_register() failed %d\n", error);
276 misc_deregister(&zfs_misc);
280 #define ZFS_DEBUG_STR " (DEBUG mode)"
282 #define ZFS_DEBUG_STR ""
290 if ((error = zfs_kmod_init()) != 0) {
291 printk(KERN_NOTICE "ZFS: Failed to Load ZFS Filesystem v%s-%s%s"
292 ", rc = %d\n", ZFS_META_VERSION, ZFS_META_RELEASE,
293 ZFS_DEBUG_STR, error);
300 printk(KERN_NOTICE "ZFS: Loaded module v%s-%s%s, "
301 "ZFS pool version %s, ZFS filesystem version %s\n",
302 ZFS_META_VERSION, ZFS_META_RELEASE, ZFS_DEBUG_STR,
303 SPA_VERSION_STRING, ZPL_VERSION_STRING);
304 #ifndef CONFIG_FS_POSIX_ACL
305 printk(KERN_NOTICE "ZFS: Posix ACLs disabled by kernel\n");
306 #endif /* CONFIG_FS_POSIX_ACL */
317 printk(KERN_NOTICE "ZFS: Unloaded module v%s-%s%s\n",
318 ZFS_META_VERSION, ZFS_META_RELEASE, ZFS_DEBUG_STR);
326 ZFS_MODULE_DESCRIPTION("ZFS");
327 ZFS_MODULE_AUTHOR(ZFS_META_AUTHOR);
328 ZFS_MODULE_LICENSE(ZFS_META_LICENSE);
329 ZFS_MODULE_VERSION(ZFS_META_VERSION "-" ZFS_META_RELEASE);