mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-27 18:34:22 +03:00
Remove zfs_major/zfs_minor/zfsfstype
Under Linux we don't need to reserve a major or minor number for the filesystem. We can rely on the VFS to handle colisions without this being handled by the lower ZFS layers. Additionally, there is no need to keep a zfsfstype around. We are not limited on Linux by the OpenSolaris infrastructure which needed this. The upper zpl layer can specify the filesystem type.
This commit is contained in:
parent
4b3f12ecd5
commit
c0b3dc7d07
@ -66,11 +66,6 @@
|
|||||||
#include "zfs_comutil.h"
|
#include "zfs_comutil.h"
|
||||||
|
|
||||||
#ifdef HAVE_ZPL
|
#ifdef HAVE_ZPL
|
||||||
int zfsfstype;
|
|
||||||
static major_t zfs_major;
|
|
||||||
static minor_t zfs_minor;
|
|
||||||
static kmutex_t zfs_dev_mtx;
|
|
||||||
|
|
||||||
extern int sys_shutdown;
|
extern int sys_shutdown;
|
||||||
|
|
||||||
static int zfs_mount(vfs_t *vfsp, vnode_t *mvp, struct mounta *uap, cred_t *cr);
|
static int zfs_mount(vfs_t *vfsp, vnode_t *mvp, struct mounta *uap, cred_t *cr);
|
||||||
@ -161,58 +156,6 @@ zfs_sync(vfs_t *vfsp, short flag, cred_t *cr)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL(zfs_sync);
|
EXPORT_SYMBOL(zfs_sync);
|
||||||
|
|
||||||
static int
|
|
||||||
zfs_create_unique_device(dev_t *dev)
|
|
||||||
{
|
|
||||||
major_t new_major;
|
|
||||||
|
|
||||||
do {
|
|
||||||
ASSERT3U(zfs_minor, <=, MAXMIN32);
|
|
||||||
minor_t start = zfs_minor;
|
|
||||||
do {
|
|
||||||
mutex_enter(&zfs_dev_mtx);
|
|
||||||
if (zfs_minor >= MAXMIN32) {
|
|
||||||
/*
|
|
||||||
* If we're still using the real major
|
|
||||||
* keep out of /dev/zfs and /dev/zvol minor
|
|
||||||
* number space. If we're using a getudev()'ed
|
|
||||||
* major number, we can use all of its minors.
|
|
||||||
*/
|
|
||||||
if (zfs_major == ddi_name_to_major(ZFS_DRIVER))
|
|
||||||
zfs_minor = ZFS_MIN_MINOR;
|
|
||||||
else
|
|
||||||
zfs_minor = 0;
|
|
||||||
} else {
|
|
||||||
zfs_minor++;
|
|
||||||
}
|
|
||||||
*dev = makedevice(zfs_major, zfs_minor);
|
|
||||||
mutex_exit(&zfs_dev_mtx);
|
|
||||||
} while (vfs_devismounted(*dev) && zfs_minor != start);
|
|
||||||
if (zfs_minor == start) {
|
|
||||||
/*
|
|
||||||
* We are using all ~262,000 minor numbers for the
|
|
||||||
* current major number. Create a new major number.
|
|
||||||
*/
|
|
||||||
if ((new_major = getudev()) == (major_t)-1) {
|
|
||||||
cmn_err(CE_WARN,
|
|
||||||
"zfs_mount: Can't get unique major "
|
|
||||||
"device number.");
|
|
||||||
return (-1);
|
|
||||||
}
|
|
||||||
mutex_enter(&zfs_dev_mtx);
|
|
||||||
zfs_major = new_major;
|
|
||||||
zfs_minor = 0;
|
|
||||||
|
|
||||||
mutex_exit(&zfs_dev_mtx);
|
|
||||||
} else {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
/* CONSTANTCONDITION */
|
|
||||||
} while (1);
|
|
||||||
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
atime_changed_cb(void *arg, uint64_t newval)
|
atime_changed_cb(void *arg, uint64_t newval)
|
||||||
{
|
{
|
||||||
@ -1090,7 +1033,6 @@ zfs_set_fuid_feature(zfsvfs_t *zfsvfs)
|
|||||||
int
|
int
|
||||||
zfs_domount(vfs_t *vfsp, char *osname)
|
zfs_domount(vfs_t *vfsp, char *osname)
|
||||||
{
|
{
|
||||||
dev_t mount_dev;
|
|
||||||
uint64_t recordsize, fsid_guid;
|
uint64_t recordsize, fsid_guid;
|
||||||
int error = 0;
|
int error = 0;
|
||||||
zfsvfs_t *zfsvfs;
|
zfsvfs_t *zfsvfs;
|
||||||
@ -1107,18 +1049,10 @@ zfs_domount(vfs_t *vfsp, char *osname)
|
|||||||
vfsp->vfs_bcount = 0;
|
vfsp->vfs_bcount = 0;
|
||||||
vfsp->vfs_data = NULL;
|
vfsp->vfs_data = NULL;
|
||||||
|
|
||||||
if (zfs_create_unique_device(&mount_dev) == -1) {
|
|
||||||
error = ENODEV;
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
ASSERT(vfs_devismounted(mount_dev) == 0);
|
|
||||||
|
|
||||||
if ((error = dsl_prop_get_integer(osname, "recordsize",
|
if ((error = dsl_prop_get_integer(osname, "recordsize",
|
||||||
&recordsize, NULL)))
|
&recordsize, NULL)))
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
vfsp->vfs_dev = mount_dev;
|
|
||||||
vfsp->vfs_fstype = zfsfstype;
|
|
||||||
vfsp->vfs_bsize = recordsize;
|
vfsp->vfs_bsize = recordsize;
|
||||||
vfsp->vfs_flag |= VFS_NOTRUNC;
|
vfsp->vfs_flag |= VFS_NOTRUNC;
|
||||||
vfsp->vfs_data = zfsvfs;
|
vfsp->vfs_data = zfsvfs;
|
||||||
@ -1134,8 +1068,7 @@ zfs_domount(vfs_t *vfsp, char *osname)
|
|||||||
fsid_guid = dmu_objset_fsid_guid(zfsvfs->z_os);
|
fsid_guid = dmu_objset_fsid_guid(zfsvfs->z_os);
|
||||||
ASSERT((fsid_guid & ~((1ULL<<56)-1)) == 0);
|
ASSERT((fsid_guid & ~((1ULL<<56)-1)) == 0);
|
||||||
vfsp->vfs_fsid.val[0] = fsid_guid;
|
vfsp->vfs_fsid.val[0] = fsid_guid;
|
||||||
vfsp->vfs_fsid.val[1] = ((fsid_guid>>32) << 8) |
|
vfsp->vfs_fsid.val[1] = ((fsid_guid>>32) << 8);
|
||||||
zfsfstype & 0xFF;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Set features for file system.
|
* Set features for file system.
|
||||||
@ -1625,7 +1558,7 @@ zfs_statvfs(vfs_t *vfsp, struct statvfs64 *statp)
|
|||||||
/*
|
/*
|
||||||
* We're a zfs filesystem.
|
* We're a zfs filesystem.
|
||||||
*/
|
*/
|
||||||
(void) strcpy(statp->f_basetype, vfssw[vfsp->vfs_fstype].vsw_name);
|
(void) strcpy(statp->f_basetype, MNTTYPE_ZFS);
|
||||||
|
|
||||||
statp->f_flag = vf_to_stf(vfsp->vfs_flag);
|
statp->f_flag = vf_to_stf(vfsp->vfs_flag);
|
||||||
|
|
||||||
@ -2033,47 +1966,13 @@ zfs_freevfs(vfs_t *vfsp)
|
|||||||
|
|
||||||
atomic_add_32(&zfs_active_fs_count, -1);
|
atomic_add_32(&zfs_active_fs_count, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* VFS_INIT() initialization. Note that there is no VFS_FINI(),
|
|
||||||
* so we can't safely do any non-idempotent initialization here.
|
|
||||||
* Leave that to zfs_init() and zfs_fini(), which are called
|
|
||||||
* from the module's _init() and _fini() entry points.
|
|
||||||
*/
|
|
||||||
/*ARGSUSED*/
|
|
||||||
static int
|
|
||||||
zfs_vfsinit(int fstype, char *name)
|
|
||||||
{
|
|
||||||
int error;
|
|
||||||
|
|
||||||
zfsfstype = fstype;
|
|
||||||
mutex_init(&zfs_dev_mtx, NULL, MUTEX_DEFAULT, NULL);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Unique major number for all zfs mounts.
|
|
||||||
* If we run out of 32-bit minors, we'll getudev() another major.
|
|
||||||
*/
|
|
||||||
zfs_major = ddi_name_to_major(ZFS_DRIVER);
|
|
||||||
zfs_minor = ZFS_MIN_MINOR;
|
|
||||||
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
#endif /* HAVE_ZPL */
|
#endif /* HAVE_ZPL */
|
||||||
|
|
||||||
void
|
void
|
||||||
zfs_init(void)
|
zfs_init(void)
|
||||||
{
|
{
|
||||||
#ifdef HAVE_ZPL
|
|
||||||
/*
|
|
||||||
* Initialize .zfs directory structures
|
|
||||||
*/
|
|
||||||
zfsctl_init();
|
zfsctl_init();
|
||||||
|
|
||||||
/*
|
|
||||||
* Initialize znode cache, vnode ops, etc...
|
|
||||||
*/
|
|
||||||
zfs_znode_init();
|
zfs_znode_init();
|
||||||
#endif /* HAVE_ZPL */
|
|
||||||
|
|
||||||
dmu_objset_register_type(DMU_OST_ZFS, zfs_space_delta_cb);
|
dmu_objset_register_type(DMU_OST_ZFS, zfs_space_delta_cb);
|
||||||
}
|
}
|
||||||
@ -2081,10 +1980,8 @@ zfs_init(void)
|
|||||||
void
|
void
|
||||||
zfs_fini(void)
|
zfs_fini(void)
|
||||||
{
|
{
|
||||||
#ifdef HAVE_ZPL
|
|
||||||
zfsctl_fini();
|
zfsctl_fini();
|
||||||
zfs_znode_fini();
|
zfs_znode_fini();
|
||||||
#endif /* HAVE_ZPL */
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef HAVE_ZPL
|
#ifdef HAVE_ZPL
|
||||||
|
Loading…
Reference in New Issue
Block a user