Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/external/cddl/osnet/dist/uts/common/fs/zfs Enable the zvol m...
details: https://anonhg.NetBSD.org/src/rev/1ba4cc1e4fe7
branches: trunk
changeset: 999157:1ba4cc1e4fe7
user: hannken <hannken%NetBSD.org@localhost>
date: Wed May 22 08:45:32 2019 +0000
description:
Enable the zvol minor management to create and remove device nodes.
diffstat:
external/cddl/osnet/dist/uts/common/fs/zfs/dsl_dataset.c | 12 ++--
external/cddl/osnet/dist/uts/common/fs/zfs/dsl_dir.c | 2 +-
external/cddl/osnet/dist/uts/common/fs/zfs/spa.c | 4 +-
external/cddl/osnet/dist/uts/common/fs/zfs/sys/zvol.h | 2 +-
external/cddl/osnet/dist/uts/common/fs/zfs/zfs_ioctl.c | 12 +---
external/cddl/osnet/dist/uts/common/fs/zfs/zfs_vfsops.c | 12 +++-
external/cddl/osnet/dist/uts/common/fs/zfs/zvol.c | 47 ++++++++++++---
7 files changed, 61 insertions(+), 30 deletions(-)
diffs (truncated from 315 to 300 lines):
diff -r 807fd8ea02f6 -r 1ba4cc1e4fe7 external/cddl/osnet/dist/uts/common/fs/zfs/dsl_dataset.c
--- a/external/cddl/osnet/dist/uts/common/fs/zfs/dsl_dataset.c Wed May 22 08:44:48 2019 +0000
+++ b/external/cddl/osnet/dist/uts/common/fs/zfs/dsl_dataset.c Wed May 22 08:45:32 2019 +0000
@@ -1612,7 +1612,7 @@
fnvlist_free(suspended);
}
-#ifdef __FreeBSD__
+#if defined(__FreeBSD__) || defined(__NetBSD__)
#ifdef _KERNEL
if (error == 0) {
for (pair = nvlist_next_nvpair(snaps, NULL); pair != NULL;
@@ -2164,7 +2164,7 @@
dsl_dataset_rename_snapshot_sync_impl(dsl_pool_t *dp,
dsl_dataset_t *hds, void *arg)
{
-#ifdef __FreeBSD__
+#if defined(__FreeBSD__) || defined(__NetBSD__)
#ifdef _KERNEL
char *oldname, *newname;
#endif
@@ -2197,7 +2197,7 @@
dsl_dataset_phys(hds)->ds_snapnames_zapobj,
ds->ds_snapname, 8, 1, &ds->ds_object, tx));
-#ifdef __FreeBSD__
+#if defined(__FreeBSD__) || defined(__NetBSD__)
#ifdef _KERNEL
oldname = kmem_alloc(MAXPATHLEN, KM_SLEEP);
newname = kmem_alloc(MAXPATHLEN, KM_SLEEP);
@@ -2640,7 +2640,7 @@
dsl_dir_t *odd = NULL;
uint64_t oldnext_obj;
int64_t delta;
-#if defined(__FreeBSD__) && defined(_KERNEL)
+#if (defined(__FreeBSD__) || defined(__NetBSD__)) && defined(_KERNEL)
char *oldname, *newname;
#endif
@@ -2710,7 +2710,7 @@
dsl_dir_phys(dd)->dd_clones, origin_head->ds_object, tx));
}
-#if defined(__FreeBSD__) && defined(_KERNEL)
+#if (defined(__FreeBSD__) || defined(__NetBSD__)) && defined(_KERNEL)
/* Take the spa_namespace_lock early so zvol renames don't deadlock. */
mutex_enter(&spa_namespace_lock);
@@ -2752,7 +2752,7 @@
VERIFY0(dsl_dir_hold_obj(dp, dd->dd_object,
NULL, ds, &ds->ds_dir));
-#if defined(__FreeBSD__) && defined(_KERNEL)
+#if (defined(__FreeBSD__) || defined(__NetBSD__)) && defined(_KERNEL)
dsl_dataset_name(ds, newname);
zfsvfs_update_fromname(oldname, newname);
zvol_rename_minors(oldname, newname);
diff -r 807fd8ea02f6 -r 1ba4cc1e4fe7 external/cddl/osnet/dist/uts/common/fs/zfs/dsl_dir.c
--- a/external/cddl/osnet/dist/uts/common/fs/zfs/dsl_dir.c Wed May 22 08:44:48 2019 +0000
+++ b/external/cddl/osnet/dist/uts/common/fs/zfs/dsl_dir.c Wed May 22 08:45:32 2019 +0000
@@ -1912,7 +1912,7 @@
VERIFY0(zap_add(mos, dsl_dir_phys(newparent)->dd_child_dir_zapobj,
dd->dd_myname, 8, 1, &dd->dd_object, tx));
-#ifdef __FreeBSD__
+#if defined(__FreeBSD__) || defined(__NetBSD__)
#ifdef _KERNEL
zfsvfs_update_fromname(ddra->ddra_oldname, ddra->ddra_newname);
zvol_rename_minors(ddra->ddra_oldname, ddra->ddra_newname);
diff -r 807fd8ea02f6 -r 1ba4cc1e4fe7 external/cddl/osnet/dist/uts/common/fs/zfs/spa.c
--- a/external/cddl/osnet/dist/uts/common/fs/zfs/spa.c Wed May 22 08:44:48 2019 +0000
+++ b/external/cddl/osnet/dist/uts/common/fs/zfs/spa.c Wed May 22 08:45:32 2019 +0000
@@ -3226,7 +3226,7 @@
spa->spa_last_ubsync_txg = 0;
spa->spa_load_txg = 0;
mutex_exit(&spa_namespace_lock);
-#ifdef __FreeBSD__
+#if defined(__FreeBSD__) || defined(__NetBSD__)
#ifdef _KERNEL
if (firstopen)
zvol_create_minors(spa->spa_name);
@@ -4508,7 +4508,7 @@
mutex_exit(&spa_namespace_lock);
-#ifdef __FreeBSD__
+#if defined(__FreeBSD__) || defined(__NetBSD__)
#ifdef _KERNEL
zvol_create_minors(pool);
#endif
diff -r 807fd8ea02f6 -r 1ba4cc1e4fe7 external/cddl/osnet/dist/uts/common/fs/zfs/sys/zvol.h
--- a/external/cddl/osnet/dist/uts/common/fs/zfs/sys/zvol.h Wed May 22 08:44:48 2019 +0000
+++ b/external/cddl/osnet/dist/uts/common/fs/zfs/sys/zvol.h Wed May 22 08:45:32 2019 +0000
@@ -75,7 +75,7 @@
ssize_t resid, boolean_t sync);
#endif /* illumos */
-#if defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
+#if defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__NetBSD__)
extern int zvol_create_minors(const char *name);
extern void zvol_rename_minors(const char *oldname, const char *newname);
#endif
diff -r 807fd8ea02f6 -r 1ba4cc1e4fe7 external/cddl/osnet/dist/uts/common/fs/zfs/zfs_ioctl.c
--- a/external/cddl/osnet/dist/uts/common/fs/zfs/zfs_ioctl.c Wed May 22 08:44:48 2019 +0000
+++ b/external/cddl/osnet/dist/uts/common/fs/zfs/zfs_ioctl.c Wed May 22 08:45:32 2019 +0000
@@ -3360,10 +3360,8 @@
if (error != 0)
(void) dsl_destroy_head(fsname);
}
-#ifdef __FreeBSD__
if (error == 0 && type == DMU_OST_ZVOL)
zvol_create_minors(fsname);
-#endif
return (error);
}
@@ -3405,10 +3403,8 @@
if (error != 0)
(void) dsl_destroy_head(fsname);
}
-#ifdef __FreeBSD__
if (error == 0)
zvol_create_minors(fsname);
-#endif
return (error);
}
@@ -3681,9 +3677,7 @@
error = zfs_unmount_snap(name);
if (error != 0)
return (error);
-#if defined(__FreeBSD__)
zvol_remove_minors(name);
-#endif
}
return (dsl_destroy_snapshots_nvl(snaps, defer, outnvl));
@@ -3807,7 +3801,7 @@
else
err = dsl_destroy_head(zc->zc_name);
if (zc->zc_objset_type == DMU_OST_ZVOL && err == 0)
-#ifdef __FreeBSD__
+#if defined(__FreeBSD__) || defined(__NetBSD__)
zvol_remove_minors(zc->zc_name);
#else
(void) zvol_remove_minor(zc->zc_name);
@@ -4550,10 +4544,8 @@
}
#endif
-#ifdef __FreeBSD__
if (error == 0)
zvol_create_minors(tofs);
-#endif
/*
* On error, restore the original props.
@@ -6166,7 +6158,9 @@
static minor_t last_minor;
minor_t m;
+#ifndef __NetBSD__
ASSERT(MUTEX_HELD(&spa_namespace_lock));
+#endif
for (m = last_minor + 1; m != last_minor; m++) {
if (m > ZFSDEV_MAX_MINOR)
diff -r 807fd8ea02f6 -r 1ba4cc1e4fe7 external/cddl/osnet/dist/uts/common/fs/zfs/zfs_vfsops.c
--- a/external/cddl/osnet/dist/uts/common/fs/zfs/zfs_vfsops.c Wed May 22 08:44:48 2019 +0000
+++ b/external/cddl/osnet/dist/uts/common/fs/zfs/zfs_vfsops.c Wed May 22 08:45:32 2019 +0000
@@ -2956,7 +2956,7 @@
return (error);
}
-#ifdef __FreeBSD_kernel__
+#if defined(__FreeBSD_kernel__) || defined(__NetBSD__)
#ifdef _KERNEL
void
zfsvfs_update_fromname(const char *oldname, const char *newname)
@@ -2968,8 +2968,14 @@
oldlen = strlen(oldname);
+#ifdef __NetBSD__
+ mount_iterator_t *iter;
+ mountlist_iterator_init(&iter);
+ while ((mp = mountlist_iterator_next(iter)) != NULL) {
+#else
mtx_lock(&mountlist_mtx);
TAILQ_FOREACH(mp, &mountlist, mnt_list) {
+#endif
fromname = mp->mnt_stat.f_mntfromname;
if (strcmp(fromname, oldname) == 0) {
(void)strlcpy(fromname, newname,
@@ -2985,7 +2991,11 @@
continue;
}
}
+#ifdef __NetBSD__
+ mountlist_iterator_destroy(iter);
+#else
mtx_unlock(&mountlist_mtx);
+#endif
}
#endif
#endif
diff -r 807fd8ea02f6 -r 1ba4cc1e4fe7 external/cddl/osnet/dist/uts/common/fs/zfs/zvol.c
--- a/external/cddl/osnet/dist/uts/common/fs/zfs/zvol.c Wed May 22 08:44:48 2019 +0000
+++ b/external/cddl/osnet/dist/uts/common/fs/zfs/zvol.c Wed May 22 08:45:32 2019 +0000
@@ -870,7 +870,7 @@
(void) strlcpy(zv->zv_name, name, MAXPATHLEN);
zv->zv_min_bs = DEV_BSHIFT;
-#ifdef illumos
+#if defined(illumos) || defined(__NetBSD__)
zv->zv_minor = minor;
#endif
zv->zv_objset = os;
@@ -950,12 +950,17 @@
char nmbuf[20];
minor_t minor = zv->zv_minor;
- /* XXXNETBSD needs changes here */
- (void) snprintf(nmbuf, sizeof (nmbuf), "%u,raw", zv->zv_minor);
+ LIST_REMOVE(zv, zv_links);
+
+ (void) snprintf(nmbuf, sizeof (nmbuf), "%s", zv->zv_name);
ddi_remove_minor_node(zfs_dip, nmbuf);
- (void) snprintf(nmbuf, sizeof (nmbuf), "%u", zv->zv_minor);
+ (void) snprintf(nmbuf, sizeof (nmbuf), "%s", zv->zv_name);
ddi_remove_minor_node(zfs_dip, nmbuf);
+
+ disk_detach(&zv->zv_dk);
+ disk_destroy(&zv->zv_dk);
+ mutex_destroy(&zv->zv_dklock);
#endif
avl_destroy(&zv->zv_znode.z_range_avl);
@@ -983,6 +988,11 @@
mutex_exit(&zfsdev_state_lock);
return (SET_ERROR(ENXIO));
}
+#ifdef __NetBSD__
+ disk_detach(&zv->zv_dk);
+ disk_destroy(&zv->zv_dk);
+ mutex_destroy(&zv->zv_dklock);
+#endif
rc = zvol_remove_zv(zv);
mutex_exit(&zfsdev_state_lock);
return (rc);
@@ -1058,12 +1068,6 @@
dmu_objset_disown(zv->zv_objset, zvol_tag);
zv->zv_objset = NULL;
-#ifdef __NetBSD__xxx
- /* the old code has this here, but it's in the wrong place. */
- disk_detach(&zv->zv_dk);
- disk_destroy(&zv->zv_dk);
- mutex_destroy(&zv->zv_dklock);
-#endif
}
#ifdef illumos
@@ -3125,6 +3129,7 @@
}
}
}
+#endif
extern boolean_t dataset_name_hidden(const char *name);
@@ -3243,6 +3248,26 @@
return (0);
}
+#ifdef __NetBSD__
+void
+zvol_rename_minor(zvol_state_t *zv, const char *newname)
+{
+ char *nm;
+ minor_t minor = zv->zv_minor;
+
+ nm = PNBUF_GET();
+ strlcpy(nm, newname, MAXPATHLEN);
+ ddi_remove_minor_node(zfs_dip, zv->zv_name);
+ (void)ddi_create_minor_node(zfs_dip, nm, S_IFCHR, minor, DDI_PSEUDO, 0);
+ (void)ddi_create_minor_node(zfs_dip, nm, S_IFBLK, minor, DDI_PSEUDO, 0);
+ PNBUF_PUT(nm);
+
+ strlcpy(zv->zv_name, newname, sizeof(zv->zv_name));
+ /* XXX Update dk_name? */
+}
+#endif
+
+#ifdef __FreeBSD__
static void
zvol_rename_minor(zvol_state_t *zv, const char *newname)
{
@@ -3297,6 +3322,7 @@
Home |
Main Index |
Thread Index |
Old Index