Module Name: src Committed By: tkusumi Date: Sat Dec 21 11:59:03 UTC 2019
Modified Files: src/sys/dev/dm: dm.h dm_ioctl.c dm_table.c dm_target.c dm_target_error.c dm_target_linear.c dm_target_mirror.c dm_target_snapshot.c dm_target_stripe.c dm_target_zero.c Log Message: dm: Remove target's ->deps() by implementing deps in dm core Retrieving device dependencies doesn't need to be target specific. The reason it currently needs ->deps() is because dm core doesn't have data structure that allows table to walk through target's underlying devices. Add struct dm_mapping to be able to do this, and remove ->deps()'s from targets which basically do the same thing. =====(A) before this commit table | [dm core] ------------------------------------------------------- | pdev pdev pdev [dm targets] v ^ ^ ^ target----/---------/---------/ (void*) =====(B) this commit table---->mapping-->mapping-->mapping-->... | | | | | v v v [dm core] ------------------------------------------------------- | pdev pdev pdev [dm targets] v ^ ^ ^ target----/---------/---------/ (void*) taken-from: DragonFlyBSD To generate a diff of this commit: cvs rdiff -u -r1.49 -r1.50 src/sys/dev/dm/dm.h cvs rdiff -u -r1.47 -r1.48 src/sys/dev/dm/dm_ioctl.c cvs rdiff -u -r1.16 -r1.17 src/sys/dev/dm/dm_table.c cvs rdiff -u -r1.34 -r1.35 src/sys/dev/dm/dm_target.c \ src/sys/dev/dm/dm_target_linear.c cvs rdiff -u -r1.26 -r1.27 src/sys/dev/dm/dm_target_error.c cvs rdiff -u -r1.22 -r1.23 src/sys/dev/dm/dm_target_mirror.c cvs rdiff -u -r1.36 -r1.37 src/sys/dev/dm/dm_target_snapshot.c cvs rdiff -u -r1.41 -r1.42 src/sys/dev/dm/dm_target_stripe.c cvs rdiff -u -r1.28 -r1.29 src/sys/dev/dm/dm_target_zero.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/dev/dm/dm.h diff -u src/sys/dev/dm/dm.h:1.49 src/sys/dev/dm/dm.h:1.50 --- src/sys/dev/dm/dm.h:1.49 Fri Dec 20 16:16:36 2019 +++ src/sys/dev/dm/dm.h Sat Dec 21 11:59:03 2019 @@ -1,4 +1,4 @@ -/* $NetBSD: dm.h,v 1.49 2019/12/20 16:16:36 tkusumi Exp $ */ +/* $NetBSD: dm.h,v 1.50 2019/12/21 11:59:03 tkusumi Exp $ */ /* * Copyright (c) 2008 The NetBSD Foundation, Inc. @@ -65,6 +65,13 @@ extern const struct dkdriver dmdkdriver; extern uint32_t dm_dev_counter; +typedef struct dm_mapping { + union { + struct dm_pdev *pdev; + } data; + TAILQ_ENTRY(dm_mapping) next; +} dm_mapping_t; + /* * A device mapper table is a list of physical ranges plus the mapping target * applied to them. @@ -77,6 +84,8 @@ typedef struct dm_table_entry { struct dm_target *target; /* Link to table target. */ void *target_config; /* Target specific data. */ SLIST_ENTRY(dm_table_entry) next; + + TAILQ_HEAD(, dm_mapping) pdev_maps; } dm_table_entry_t; SLIST_HEAD(dm_table, dm_table_entry); @@ -172,7 +181,6 @@ typedef struct dm_target { /* Destroy target_config area */ int (*destroy)(dm_table_entry_t *); - int (*deps)(dm_table_entry_t *, prop_array_t); /* * Info/table routine are called to get params string, which is target * specific. When dm_table_status_ioctl is called with flag @@ -237,7 +245,6 @@ int dm_target_linear_init(dm_table_entry char *dm_target_linear_table(void *); int dm_target_linear_strategy(dm_table_entry_t *, struct buf *); int dm_target_linear_sync(dm_table_entry_t *); -int dm_target_linear_deps(dm_table_entry_t *, prop_array_t); int dm_target_linear_destroy(dm_table_entry_t *); int dm_target_linear_upcall(dm_table_entry_t *, struct buf *); int dm_target_linear_secsize(dm_table_entry_t *, unsigned int *); @@ -247,7 +254,6 @@ int dm_target_stripe_init(dm_table_entry char *dm_target_stripe_table(void *); int dm_target_stripe_strategy(dm_table_entry_t *, struct buf *); int dm_target_stripe_sync(dm_table_entry_t *); -int dm_target_stripe_deps(dm_table_entry_t *, prop_array_t); int dm_target_stripe_destroy(dm_table_entry_t *); int dm_target_stripe_upcall(dm_table_entry_t *, struct buf *); int dm_target_stripe_secsize(dm_table_entry_t *, unsigned int *); @@ -256,7 +262,6 @@ int dm_target_stripe_secsize(dm_table_en int dm_target_error_init(dm_table_entry_t*, int, char **); char *dm_target_error_table(void *); int dm_target_error_strategy(dm_table_entry_t *, struct buf *); -int dm_target_error_deps(dm_table_entry_t *, prop_array_t); int dm_target_error_destroy(dm_table_entry_t *); int dm_target_error_upcall(dm_table_entry_t *, struct buf *); @@ -265,7 +270,6 @@ int dm_target_zero_init(dm_table_entry_t char *dm_target_zero_table(void *); int dm_target_zero_strategy(dm_table_entry_t *, struct buf *); int dm_target_zero_destroy(dm_table_entry_t *); -int dm_target_zero_deps(dm_table_entry_t *, prop_array_t); int dm_target_zero_upcall(dm_table_entry_t *, struct buf *); /* dm_table.c */ @@ -282,6 +286,7 @@ void dm_table_release(dm_table_head_t *, void dm_table_switch_tables(dm_table_head_t *); void dm_table_head_init(dm_table_head_t *); void dm_table_head_destroy(dm_table_head_t *); +int dm_table_add_deps(dm_table_entry_t *, dm_pdev_t *); /* dm_dev.c */ dm_dev_t* dm_dev_alloc(void); Index: src/sys/dev/dm/dm_ioctl.c diff -u src/sys/dev/dm/dm_ioctl.c:1.47 src/sys/dev/dm/dm_ioctl.c:1.48 --- src/sys/dev/dm/dm_ioctl.c:1.47 Thu Dec 19 16:27:39 2019 +++ src/sys/dev/dm/dm_ioctl.c Sat Dec 21 11:59:03 2019 @@ -1,4 +1,4 @@ -/* $NetBSD: dm_ioctl.c,v 1.47 2019/12/19 16:27:39 tkusumi Exp $ */ +/* $NetBSD: dm_ioctl.c,v 1.48 2019/12/21 11:59:03 tkusumi Exp $ */ /* * Copyright (c) 2008 The NetBSD Foundation, Inc. @@ -29,7 +29,7 @@ * POSSIBILITY OF SUCH DAMAGE. */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: dm_ioctl.c,v 1.47 2019/12/19 16:27:39 tkusumi Exp $"); +__KERNEL_RCSID(0, "$NetBSD: dm_ioctl.c,v 1.48 2019/12/21 11:59:03 tkusumi Exp $"); /* * Locking is used to synchronise between ioctl calls and between dm_table's @@ -116,6 +116,7 @@ static struct cfdata dm_cfdata = { prop_dictionary_set_uint32(dm_dict,DM_IOCTL_FLAGS,flag); \ } while (/*CONSTCOND*/0) +static int dm_table_deps(dm_table_entry_t *, prop_array_t); static int dm_table_init(dm_target_t *, dm_table_entry_t *, char *); /* @@ -644,7 +645,7 @@ dm_table_deps_ioctl(prop_dictionary_t dm tbl = dm_table_get_entry(&dmv->table_head, table_type); SLIST_FOREACH(table_en, tbl, next) - table_en->target->deps(table_en, cmd_array); + dm_table_deps(table_en, cmd_array); dm_table_release(&dmv->table_head, table_type); dm_dev_unbusy(dmv); @@ -655,6 +656,36 @@ dm_table_deps_ioctl(prop_dictionary_t dm return 0; } +static int +dm_table_deps(dm_table_entry_t *table_en, prop_array_t array) +{ + dm_mapping_t *map; + int i, size; + uint64_t rdev, tmp; + + size = prop_array_count(array); + + TAILQ_FOREACH(map, &table_en->pdev_maps, next) { + rdev = map->data.pdev->pdev_vnode->v_rdev; + for (i = 0; i < size; i++) { + if (prop_array_get_uint64(array, i, &tmp) == true) + if (rdev == tmp) + break; /* exists */ + } + /* + * Ignore if the device has already been added by + * other tables. + */ + if (i == size) { + prop_array_add_uint64(array, rdev); + aprint_debug("%s: %d:%d\n", __func__, major(rdev), + minor(rdev)); + } + } + + return 0; +} + /* * Load new table/tables to device. * Call apropriate target init routine open all physical pdev's and @@ -746,6 +777,7 @@ dm_table_load_ioctl(prop_dictionary_t dm table_en->target = target; table_en->dm_dev = dmv; table_en->target_config = NULL; + TAILQ_INIT(&table_en->pdev_maps); /* * There is a parameter string after dm_target_spec Index: src/sys/dev/dm/dm_table.c diff -u src/sys/dev/dm/dm_table.c:1.16 src/sys/dev/dm/dm_table.c:1.17 --- src/sys/dev/dm/dm_table.c:1.16 Sun Dec 15 14:39:42 2019 +++ src/sys/dev/dm/dm_table.c Sat Dec 21 11:59:03 2019 @@ -1,4 +1,4 @@ -/* $NetBSD: dm_table.c,v 1.16 2019/12/15 14:39:42 tkusumi Exp $ */ +/* $NetBSD: dm_table.c,v 1.17 2019/12/21 11:59:03 tkusumi Exp $ */ /* * Copyright (c) 2008 The NetBSD Foundation, Inc. @@ -29,7 +29,7 @@ * POSSIBILITY OF SUCH DAMAGE. */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: dm_table.c,v 1.16 2019/12/15 14:39:42 tkusumi Exp $"); +__KERNEL_RCSID(0, "$NetBSD: dm_table.c,v 1.17 2019/12/21 11:59:03 tkusumi Exp $"); #include <sys/types.h> #include <sys/param.h> @@ -54,6 +54,8 @@ __KERNEL_RCSID(0, "$NetBSD: dm_table.c,v static int dm_table_busy(dm_table_head_t *, uint8_t); static void dm_table_unbusy(dm_table_head_t *); +static void dm_table_free_deps(dm_table_entry_t *); + /* * Function to increment table user reference counter. Return id @@ -166,6 +168,7 @@ dm_table_destroy(dm_table_head_t *head, SLIST_REMOVE(tbl, table_en, dm_table_entry, next); if (table_en->target->destroy(table_en) == 0) table_en->target_config = NULL; + dm_table_free_deps(table_en); kmem_free(table_en, sizeof(*table_en)); } KASSERT(SLIST_EMPTY(tbl)); @@ -327,3 +330,47 @@ dm_table_head_destroy(dm_table_head_t *h cv_destroy(&head->table_cv); mutex_destroy(&head->table_mtx); } + +int +dm_table_add_deps(dm_table_entry_t *table_en, dm_pdev_t *pdev) +{ + dm_table_head_t *head; + dm_mapping_t *map; + + if (!pdev) + return -1; + + head = &table_en->dm_dev->table_head; + mutex_enter(&head->table_mtx); + + TAILQ_FOREACH(map, &table_en->pdev_maps, next) { + if (map->data.pdev->pdev_vnode->v_rdev == + pdev->pdev_vnode->v_rdev) { + mutex_exit(&head->table_mtx); + return -1; + } + } + + map = kmem_alloc(sizeof(*map), KM_SLEEP); + map->data.pdev = pdev; + aprint_debug("%s: %s\n", __func__, pdev->name); + TAILQ_INSERT_TAIL(&table_en->pdev_maps, map, next); + + mutex_exit(&head->table_mtx); + + return 0; +} + +/* caller must hold ->table_mtx */ +static void +dm_table_free_deps(dm_table_entry_t *table_en) +{ + dm_mapping_t *map; + + while ((map = TAILQ_FIRST(&table_en->pdev_maps)) != NULL) { + TAILQ_REMOVE(&table_en->pdev_maps, map, next); + aprint_debug("%s: %s\n", __func__, map->data.pdev->name); + kmem_free(map, sizeof(*map)); + } + KASSERT(TAILQ_EMPTY(&table_en->pdev_maps)); +} Index: src/sys/dev/dm/dm_target.c diff -u src/sys/dev/dm/dm_target.c:1.34 src/sys/dev/dm/dm_target.c:1.35 --- src/sys/dev/dm/dm_target.c:1.34 Thu Dec 19 15:34:54 2019 +++ src/sys/dev/dm/dm_target.c Sat Dec 21 11:59:03 2019 @@ -1,4 +1,4 @@ -/* $NetBSD: dm_target.c,v 1.34 2019/12/19 15:34:54 tkusumi Exp $ */ +/* $NetBSD: dm_target.c,v 1.35 2019/12/21 11:59:03 tkusumi Exp $ */ /* * Copyright (c) 2008 The NetBSD Foundation, Inc. @@ -29,7 +29,7 @@ * POSSIBILITY OF SUCH DAMAGE. */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: dm_target.c,v 1.34 2019/12/19 15:34:54 tkusumi Exp $"); +__KERNEL_RCSID(0, "$NetBSD: dm_target.c,v 1.35 2019/12/21 11:59:03 tkusumi Exp $"); #include <sys/types.h> #include <sys/param.h> @@ -168,10 +168,6 @@ dm_target_insert(dm_target_t *dm_target) printf("%s missing strategy\n", dm_target->name); return EINVAL; } - if (dm_target->deps == NULL) { - printf("%s missing deps\n", dm_target->name); - return EINVAL; - } if (dm_target->destroy == NULL) { printf("%s missing destroy\n", dm_target->name); return EINVAL; @@ -324,7 +320,6 @@ dm_target_init(void) dmt->table = &dm_target_linear_table; dmt->strategy = &dm_target_linear_strategy; dmt->sync = &dm_target_linear_sync; - dmt->deps = &dm_target_linear_deps; dmt->destroy = &dm_target_linear_destroy; dmt->upcall = &dm_target_linear_upcall; dmt->secsize = &dm_target_linear_secsize; @@ -339,7 +334,6 @@ dm_target_init(void) dmt->table = &dm_target_stripe_table; dmt->strategy = &dm_target_stripe_strategy; dmt->sync = &dm_target_stripe_sync; - dmt->deps = &dm_target_stripe_deps; dmt->destroy = &dm_target_stripe_destroy; dmt->upcall = &dm_target_stripe_upcall; dmt->secsize = &dm_target_stripe_secsize; @@ -353,7 +347,6 @@ dm_target_init(void) dmt->init = &dm_target_error_init; dmt->table = &dm_target_error_table; dmt->strategy = &dm_target_error_strategy; - dmt->deps = &dm_target_error_deps; dmt->destroy = &dm_target_error_destroy; dmt->upcall = &dm_target_error_upcall; if (dm_target_insert(dmt)) @@ -366,7 +359,6 @@ dm_target_init(void) dmt->init = &dm_target_zero_init; dmt->table = &dm_target_zero_table; dmt->strategy = &dm_target_zero_strategy; - dmt->deps = &dm_target_zero_deps; dmt->destroy = &dm_target_zero_destroy; dmt->upcall = &dm_target_zero_upcall; if (dm_target_insert(dmt)) Index: src/sys/dev/dm/dm_target_linear.c diff -u src/sys/dev/dm/dm_target_linear.c:1.34 src/sys/dev/dm/dm_target_linear.c:1.35 --- src/sys/dev/dm/dm_target_linear.c:1.34 Fri Dec 20 16:16:36 2019 +++ src/sys/dev/dm/dm_target_linear.c Sat Dec 21 11:59:03 2019 @@ -1,4 +1,4 @@ -/* $NetBSD: dm_target_linear.c,v 1.34 2019/12/20 16:16:36 tkusumi Exp $ */ +/* $NetBSD: dm_target_linear.c,v 1.35 2019/12/21 11:59:03 tkusumi Exp $ */ /* * Copyright (c) 2008 The NetBSD Foundation, Inc. @@ -29,7 +29,7 @@ * POSSIBILITY OF SUCH DAMAGE. */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: dm_target_linear.c,v 1.34 2019/12/20 16:16:36 tkusumi Exp $"); +__KERNEL_RCSID(0, "$NetBSD: dm_target_linear.c,v 1.35 2019/12/21 11:59:03 tkusumi Exp $"); /* * This file implements initial version of device-mapper dklinear target. @@ -75,6 +75,7 @@ dm_target_linear_init(dm_table_entry_t * tlc->pdev = dmp; tlc->offset = atoi64(argv[1]); + dm_table_add_deps(table_en, dmp); table_en->target_config = tlc; return 0; @@ -162,23 +163,6 @@ out: return 0; } -/* Add this target pdev dependencies to prop_array_t */ -int -dm_target_linear_deps(dm_table_entry_t *table_en, prop_array_t prop_array) -{ - dm_target_linear_config_t *tlc; - - if (table_en->target_config == NULL) - return ENOENT; - - tlc = table_en->target_config; - - prop_array_add_uint64(prop_array, - (uint64_t) tlc->pdev->pdev_vnode->v_rdev); - - return 0; -} - /* * Register upcall device. * Linear target doesn't need any upcall devices but other targets like Index: src/sys/dev/dm/dm_target_error.c diff -u src/sys/dev/dm/dm_target_error.c:1.26 src/sys/dev/dm/dm_target_error.c:1.27 --- src/sys/dev/dm/dm_target_error.c:1.26 Wed Dec 18 14:31:35 2019 +++ src/sys/dev/dm/dm_target_error.c Sat Dec 21 11:59:03 2019 @@ -1,4 +1,4 @@ -/* $NetBSD: dm_target_error.c,v 1.26 2019/12/18 14:31:35 tkusumi Exp $ */ +/* $NetBSD: dm_target_error.c,v 1.27 2019/12/21 11:59:03 tkusumi Exp $ */ /* * Copyright (c) 2008 The NetBSD Foundation, Inc. @@ -29,7 +29,7 @@ * POSSIBILITY OF SUCH DAMAGE. */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: dm_target_error.c,v 1.26 2019/12/18 14:31:35 tkusumi Exp $"); +__KERNEL_RCSID(0, "$NetBSD: dm_target_error.c,v 1.27 2019/12/21 11:59:03 tkusumi Exp $"); /* * This file implements initial version of device-mapper error target. @@ -73,7 +73,6 @@ dm_target_error_modcmd(modcmd_t cmd, voi dmt->init = &dm_target_error_init; dmt->table = &dm_target_error_table; dmt->strategy = &dm_target_error_strategy; - dmt->deps = &dm_target_error_deps; dmt->destroy = &dm_target_error_destroy; dmt->upcall = &dm_target_error_upcall; @@ -145,14 +144,6 @@ dm_target_error_destroy(dm_table_entry_t return 0; } -/* Doesn't not need to do anything here. */ -int -dm_target_error_deps(dm_table_entry_t *table_en, prop_array_t prop_array) -{ - - return 0; -} - /* Unsupported for this target. */ int dm_target_error_upcall(dm_table_entry_t *table_en, struct buf *bp) Index: src/sys/dev/dm/dm_target_mirror.c diff -u src/sys/dev/dm/dm_target_mirror.c:1.22 src/sys/dev/dm/dm_target_mirror.c:1.23 --- src/sys/dev/dm/dm_target_mirror.c:1.22 Sun Dec 15 14:39:42 2019 +++ src/sys/dev/dm/dm_target_mirror.c Sat Dec 21 11:59:03 2019 @@ -1,4 +1,4 @@ -/*$NetBSD: dm_target_mirror.c,v 1.22 2019/12/15 14:39:42 tkusumi Exp $*/ +/*$NetBSD: dm_target_mirror.c,v 1.23 2019/12/21 11:59:03 tkusumi Exp $*/ /* * Copyright (c) 2009 The NetBSD Foundation, Inc. @@ -29,7 +29,7 @@ * POSSIBILITY OF SUCH DAMAGE. */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: dm_target_mirror.c,v 1.22 2019/12/15 14:39:42 tkusumi Exp $"); +__KERNEL_RCSID(0, "$NetBSD: dm_target_mirror.c,v 1.23 2019/12/21 11:59:03 tkusumi Exp $"); /* * This file implements initial version of device-mapper mirror target. @@ -45,7 +45,6 @@ int dm_target_mirror_init(dm_table_entry char *dm_target_mirror_table(void *); int dm_target_mirror_strategy(dm_table_entry_t *, struct buf *); int dm_target_mirror_sync(dm_table_entry_t *); -int dm_target_mirror_deps(dm_table_entry_t *, prop_array_t); int dm_target_mirror_destroy(dm_table_entry_t *); int dm_target_mirror_upcall(dm_table_entry_t *, struct buf *); @@ -95,7 +94,6 @@ dm_target_mirror_modcmd(modcmd_t cmd, vo dmt->table = &dm_target_mirror_table; dmt->strategy = &dm_target_mirror_strategy; dmt->sync = &dm_target_mirror_sync; - dmt->deps = &dm_target_mirror_deps; dmt->destroy = &dm_target_mirror_destroy; dmt->upcall = &dm_target_mirror_upcall; @@ -174,14 +172,6 @@ dm_target_mirror_destroy(dm_table_entry_ return 0; } -/* Doesn't not need to do anything here. */ -int -dm_target_mirror_deps(dm_table_entry_t *table_en, prop_array_t prop_array) -{ - - return 0; -} - /* Unsupported for this target. */ int dm_target_mirror_upcall(dm_table_entry_t *table_en, struct buf *bp) Index: src/sys/dev/dm/dm_target_snapshot.c diff -u src/sys/dev/dm/dm_target_snapshot.c:1.36 src/sys/dev/dm/dm_target_snapshot.c:1.37 --- src/sys/dev/dm/dm_target_snapshot.c:1.36 Sun Dec 15 16:14:27 2019 +++ src/sys/dev/dm/dm_target_snapshot.c Sat Dec 21 11:59:03 2019 @@ -1,4 +1,4 @@ -/* $NetBSD: dm_target_snapshot.c,v 1.36 2019/12/15 16:14:27 tkusumi Exp $ */ +/* $NetBSD: dm_target_snapshot.c,v 1.37 2019/12/21 11:59:03 tkusumi Exp $ */ /* * Copyright (c) 2008 The NetBSD Foundation, Inc. @@ -29,7 +29,7 @@ * POSSIBILITY OF SUCH DAMAGE. */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: dm_target_snapshot.c,v 1.36 2019/12/15 16:14:27 tkusumi Exp $"); +__KERNEL_RCSID(0, "$NetBSD: dm_target_snapshot.c,v 1.37 2019/12/21 11:59:03 tkusumi Exp $"); /* * 1. Suspend my_data to temporarily stop any I/O while the snapshot is being @@ -90,7 +90,6 @@ int dm_target_snapshot_init(dm_table_ent char *dm_target_snapshot_table(void *); int dm_target_snapshot_strategy(dm_table_entry_t *, struct buf *); int dm_target_snapshot_sync(dm_table_entry_t *); -int dm_target_snapshot_deps(dm_table_entry_t *, prop_array_t); int dm_target_snapshot_destroy(dm_table_entry_t *); int dm_target_snapshot_upcall(dm_table_entry_t *, struct buf *); @@ -99,7 +98,6 @@ int dm_target_snapshot_orig_init(dm_tabl char *dm_target_snapshot_orig_table(void *); int dm_target_snapshot_orig_strategy(dm_table_entry_t *, struct buf *); int dm_target_snapshot_orig_sync(dm_table_entry_t *); -int dm_target_snapshot_orig_deps(dm_table_entry_t *, prop_array_t); int dm_target_snapshot_orig_destroy(dm_table_entry_t *); int dm_target_snapshot_orig_upcall(dm_table_entry_t *, struct buf *); @@ -156,7 +154,6 @@ dm_target_snapshot_modcmd(modcmd_t cmd, dmt->table = &dm_target_snapshot_table; dmt->strategy = &dm_target_snapshot_strategy; dmt->sync = &dm_target_snapshot_sync; - dmt->deps = &dm_target_snapshot_deps; dmt->destroy = &dm_target_snapshot_destroy; dmt->upcall = &dm_target_snapshot_upcall; @@ -169,7 +166,6 @@ dm_target_snapshot_modcmd(modcmd_t cmd, dmt1->table = &dm_target_snapshot_orig_table; dmt1->strategy = &dm_target_snapshot_orig_strategy; dmt1->sync = &dm_target_snapshot_orig_sync; - dmt1->deps = &dm_target_snapshot_orig_deps; dmt1->destroy = &dm_target_snapshot_orig_destroy; dmt1->upcall = &dm_target_snapshot_orig_upcall; @@ -237,6 +233,8 @@ dm_target_snapshot_init(dm_table_entry_t tsc->tsc_snap_dev = dmp_snap; tsc->tsc_cow_dev = dmp_cow; + dm_table_add_deps(table_en, dmp_snap); + dm_table_add_deps(table_en, dmp_cow); table_en->target_config = tsc; return 0; @@ -338,28 +336,6 @@ out: return 0; } -/* Add this target dependencies to prop_array_t */ -int -dm_target_snapshot_deps(dm_table_entry_t *table_en, prop_array_t prop_array) -{ - dm_target_snapshot_config_t *tsc; - - if (table_en->target_config == NULL) - return 0; - - tsc = table_en->target_config; - - prop_array_add_uint64(prop_array, - (uint64_t) tsc->tsc_snap_dev->pdev_vnode->v_rdev); - - if (tsc->tsc_persistent_dev) { - prop_array_add_uint64(prop_array, - (uint64_t) tsc->tsc_cow_dev->pdev_vnode->v_rdev); - - } - return 0; -} - /* Upcall is used to inform other depended devices about IO. */ int dm_target_snapshot_upcall(dm_table_entry_t *table_en, struct buf *bp) @@ -404,6 +380,7 @@ dm_target_snapshot_orig_init(dm_table_en tsoc = kmem_alloc(sizeof(dm_target_snapshot_origin_config_t), KM_SLEEP); tsoc->tsoc_real_dev = dmp_real; + dm_table_add_deps(table_en, dmp_real); table_en->target_config = tsoc; return 0; @@ -498,35 +475,6 @@ out: return 0; } -/* - * Get target deps and add them to prop_array_t. - */ -int -dm_target_snapshot_orig_deps(dm_table_entry_t *table_en, - prop_array_t prop_array) -{ - dm_target_snapshot_origin_config_t *tsoc; - struct vattr va; - - int error; - - if (table_en->target_config == NULL) - return 0; - - tsoc = table_en->target_config; - - vn_lock(tsoc->tsoc_real_dev->pdev_vnode, LK_SHARED | LK_RETRY); - error = VOP_GETATTR(tsoc->tsoc_real_dev->pdev_vnode, &va, - curlwp->l_cred); - VOP_UNLOCK(tsoc->tsoc_real_dev->pdev_vnode); - if (error != 0) - return error; - - prop_array_add_uint64(prop_array, (uint64_t) va.va_rdev); - - return 0; -} - /* Unsupported for this target. */ int dm_target_snapshot_orig_upcall(dm_table_entry_t *table_en, struct buf *bp) Index: src/sys/dev/dm/dm_target_stripe.c diff -u src/sys/dev/dm/dm_target_stripe.c:1.41 src/sys/dev/dm/dm_target_stripe.c:1.42 --- src/sys/dev/dm/dm_target_stripe.c:1.41 Fri Dec 20 16:16:36 2019 +++ src/sys/dev/dm/dm_target_stripe.c Sat Dec 21 11:59:03 2019 @@ -1,4 +1,4 @@ -/*$NetBSD: dm_target_stripe.c,v 1.41 2019/12/20 16:16:36 tkusumi Exp $*/ +/*$NetBSD: dm_target_stripe.c,v 1.42 2019/12/21 11:59:03 tkusumi Exp $*/ /* * Copyright (c) 2009 The NetBSD Foundation, Inc. @@ -29,7 +29,7 @@ * POSSIBILITY OF SUCH DAMAGE. */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: dm_target_stripe.c,v 1.41 2019/12/20 16:16:36 tkusumi Exp $"); +__KERNEL_RCSID(0, "$NetBSD: dm_target_stripe.c,v 1.42 2019/12/21 11:59:03 tkusumi Exp $"); /* * This file implements initial version of device-mapper stripe target. @@ -83,7 +83,6 @@ dm_target_stripe_modcmd(modcmd_t cmd, vo dmt->table = &dm_target_stripe_table; dmt->strategy = &dm_target_stripe_strategy; dmt->sync = &dm_target_stripe_sync; - dmt->deps = &dm_target_stripe_deps; dmt->destroy = &dm_target_stripe_destroy; dmt->upcall = &dm_target_stripe_upcall; dmt->secsize = &dm_target_stripe_secsize; @@ -169,6 +168,7 @@ dm_target_stripe_init(dm_table_entry_t * return ENOENT; } tlc->offset = atoi64(argv[strpi+1]); + dm_table_add_deps(table_en, tlc->pdev); /* Insert striping device to linked list. */ TAILQ_INSERT_TAIL(&tsc->stripe_devs, tlc, entries); @@ -305,26 +305,6 @@ dm_target_stripe_destroy(dm_table_entry_ return 0; } -/* Doesn't not need to do anything here. */ -int -dm_target_stripe_deps(dm_table_entry_t *table_en, prop_array_t prop_array) -{ - dm_target_stripe_config_t *tsc; - dm_target_linear_config_t *tlc; - - if (table_en->target_config == NULL) - return ENOENT; - - tsc = table_en->target_config; - - TAILQ_FOREACH(tlc, &tsc->stripe_devs, entries) { - prop_array_add_uint64(prop_array, - (uint64_t) tlc->pdev->pdev_vnode->v_rdev); - } - - return 0; -} - /* Unsupported for this target. */ int dm_target_stripe_upcall(dm_table_entry_t *table_en, struct buf *bp) Index: src/sys/dev/dm/dm_target_zero.c diff -u src/sys/dev/dm/dm_target_zero.c:1.28 src/sys/dev/dm/dm_target_zero.c:1.29 --- src/sys/dev/dm/dm_target_zero.c:1.28 Wed Dec 18 14:31:35 2019 +++ src/sys/dev/dm/dm_target_zero.c Sat Dec 21 11:59:03 2019 @@ -1,4 +1,4 @@ -/* $NetBSD: dm_target_zero.c,v 1.28 2019/12/18 14:31:35 tkusumi Exp $ */ +/* $NetBSD: dm_target_zero.c,v 1.29 2019/12/21 11:59:03 tkusumi Exp $ */ /* * Copyright (c) 2008 The NetBSD Foundation, Inc. @@ -29,7 +29,7 @@ * POSSIBILITY OF SUCH DAMAGE. */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: dm_target_zero.c,v 1.28 2019/12/18 14:31:35 tkusumi Exp $"); +__KERNEL_RCSID(0, "$NetBSD: dm_target_zero.c,v 1.29 2019/12/21 11:59:03 tkusumi Exp $"); /* * This file implements initial version of device-mapper zero target. @@ -73,7 +73,6 @@ dm_target_zero_modcmd(modcmd_t cmd, void dmt->init = &dm_target_zero_init; dmt->table = &dm_target_zero_table; dmt->strategy = &dm_target_zero_strategy; - dmt->deps = &dm_target_zero_deps; dmt->destroy = &dm_target_zero_destroy; dmt->upcall = &dm_target_zero_upcall; @@ -150,14 +149,6 @@ dm_target_zero_destroy(dm_table_entry_t return 0; } -/* Does not need to do anything here. */ -int -dm_target_zero_deps(dm_table_entry_t *table_en, prop_array_t prop_array) -{ - - return 0; -} - /* Unsuported for this target. */ int dm_target_zero_upcall(dm_table_entry_t *table_en, struct buf *bp)