Module Name: src Committed By: thorpej Date: Wed Jul 8 15:07:13 UTC 2020
Modified Files: src/sys/dev/dm: device-mapper.c dm_dev.c dm_ioctl.c dm_target.c Log Message: Adapt to proplib API chanages. To generate a diff of this commit: cvs rdiff -u -r1.60 -r1.61 src/sys/dev/dm/device-mapper.c cvs rdiff -u -r1.17 -r1.18 src/sys/dev/dm/dm_dev.c cvs rdiff -u -r1.49 -r1.50 src/sys/dev/dm/dm_ioctl.c cvs rdiff -u -r1.40 -r1.41 src/sys/dev/dm/dm_target.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/device-mapper.c diff -u src/sys/dev/dm/device-mapper.c:1.60 src/sys/dev/dm/device-mapper.c:1.61 --- src/sys/dev/dm/device-mapper.c:1.60 Thu Jan 16 07:18:08 2020 +++ src/sys/dev/dm/device-mapper.c Wed Jul 8 15:07:13 2020 @@ -1,4 +1,4 @@ -/* $NetBSD: device-mapper.c,v 1.60 2020/01/16 07:18:08 maya Exp $ */ +/* $NetBSD: device-mapper.c,v 1.61 2020/07/08 15:07:13 thorpej Exp $ */ /* * Copyright (c) 2010 The NetBSD Foundation, Inc. @@ -402,7 +402,7 @@ dm_cmd_to_fun(prop_dictionary_t dm_dict) return EINVAL; for (i = 0; cmd_fn[i].cmd != NULL; i++) - if (prop_string_equals_cstring(command, cmd_fn[i].cmd)) + if (prop_string_equals_string(command, cmd_fn[i].cmd)) break; if (!cmd_fn[i].allowed && Index: src/sys/dev/dm/dm_dev.c diff -u src/sys/dev/dm/dm_dev.c:1.17 src/sys/dev/dm/dm_dev.c:1.18 --- src/sys/dev/dm/dm_dev.c:1.17 Tue Dec 31 10:30:30 2019 +++ src/sys/dev/dm/dm_dev.c Wed Jul 8 15:07:13 2020 @@ -1,4 +1,4 @@ -/* $NetBSD: dm_dev.c,v 1.17 2019/12/31 10:30:30 tkusumi Exp $ */ +/* $NetBSD: dm_dev.c,v 1.18 2020/07/08 15:07:13 thorpej 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_dev.c,v 1.17 2019/12/31 10:30:30 tkusumi Exp $"); +__KERNEL_RCSID(0, "$NetBSD: dm_dev.c,v 1.18 2020/07/08 15:07:13 thorpej Exp $"); #include <sys/types.h> #include <sys/param.h> @@ -381,7 +381,7 @@ dm_dev_prop_list(void) TAILQ_FOREACH(dmv, &dm_dev_list, next_devlist) { dev_dict = prop_dictionary_create(); - prop_dictionary_set_cstring(dev_dict, DM_DEV_NAME, dmv->name); + prop_dictionary_set_string(dev_dict, DM_DEV_NAME, dmv->name); prop_dictionary_set_uint32(dev_dict, DM_DEV_DEV, dmv->minor); prop_array_add(dev_array, dev_dict); Index: src/sys/dev/dm/dm_ioctl.c diff -u src/sys/dev/dm/dm_ioctl.c:1.49 src/sys/dev/dm/dm_ioctl.c:1.50 --- src/sys/dev/dm/dm_ioctl.c:1.49 Mon Dec 23 16:17:35 2019 +++ src/sys/dev/dm/dm_ioctl.c Wed Jul 8 15:07:13 2020 @@ -1,4 +1,4 @@ -/* $NetBSD: dm_ioctl.c,v 1.49 2019/12/23 16:17:35 tkusumi Exp $ */ +/* $NetBSD: dm_ioctl.c,v 1.50 2020/07/08 15:07:13 thorpej 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.49 2019/12/23 16:17:35 tkusumi Exp $"); +__KERNEL_RCSID(0, "$NetBSD: dm_ioctl.c,v 1.50 2020/07/08 15:07:13 thorpej Exp $"); /* * Locking is used to synchronise between ioctl calls and between dm_table's @@ -202,8 +202,8 @@ dm_dev_create_ioctl(prop_dictionary_t dm uuid = NULL; /* Get needed values from dictionary. */ - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_NAME, &name); - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_UUID, &uuid); + prop_dictionary_get_string(dm_dict, DM_IOCTL_NAME, &name); + prop_dictionary_get_string(dm_dict, DM_IOCTL_UUID, &uuid); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_FLAGS, &flags); dm_dbg_print_flags(flags); @@ -323,8 +323,8 @@ dm_dev_rename_ioctl(prop_dictionary_t dm minor = 0; /* Get needed values from dictionary. */ - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_NAME, &name); - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_UUID, &uuid); + prop_dictionary_get_string(dm_dict, DM_IOCTL_NAME, &name); + prop_dictionary_get_string(dm_dict, DM_IOCTL_UUID, &uuid); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_FLAGS, &flags); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_MINOR, &minor); @@ -332,7 +332,7 @@ dm_dev_rename_ioctl(prop_dictionary_t dm cmd_array = prop_dictionary_get(dm_dict, DM_IOCTL_CMD_DATA); - prop_array_get_cstring_nocopy(cmd_array, 0, &n_name); + prop_array_get_string(cmd_array, 0, &n_name); if (strlen(n_name) + 1 > DM_NAME_LEN) return EINVAL; @@ -351,7 +351,7 @@ dm_dev_rename_ioctl(prop_dictionary_t dm prop_dictionary_set_uint32(dm_dict, DM_IOCTL_OPEN, dmv->table_head.io_cnt); prop_dictionary_set_uint32(dm_dict, DM_IOCTL_MINOR, dmv->minor); - prop_dictionary_set_cstring(dm_dict, DM_IOCTL_UUID, dmv->uuid); + prop_dictionary_set_string(dm_dict, DM_IOCTL_UUID, dmv->uuid); dm_dev_insert(dmv); @@ -375,8 +375,8 @@ dm_dev_remove_ioctl(prop_dictionary_t dm uuid = NULL; /* Get needed values from dictionary. */ - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_NAME, &name); - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_UUID, &uuid); + prop_dictionary_get_string(dm_dict, DM_IOCTL_NAME, &name); + prop_dictionary_get_string(dm_dict, DM_IOCTL_UUID, &uuid); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_FLAGS, &flags); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_MINOR, &minor); @@ -415,8 +415,8 @@ dm_dev_status_ioctl(prop_dictionary_t dm uuid = NULL; flags = 0; - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_NAME, &name); - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_UUID, &uuid); + prop_dictionary_get_string(dm_dict, DM_IOCTL_NAME, &name); + prop_dictionary_get_string(dm_dict, DM_IOCTL_UUID, &uuid); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_FLAGS, &flags); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_MINOR, &minor); @@ -428,7 +428,7 @@ dm_dev_status_ioctl(prop_dictionary_t dm prop_dictionary_set_uint32(dm_dict, DM_IOCTL_OPEN, dmv->table_head.io_cnt); prop_dictionary_set_uint32(dm_dict, DM_IOCTL_MINOR, dmv->minor); - prop_dictionary_set_cstring(dm_dict, DM_IOCTL_UUID, dmv->uuid); + prop_dictionary_set_string(dm_dict, DM_IOCTL_UUID, dmv->uuid); if (dmv->flags & DM_SUSPEND_FLAG) DM_ADD_FLAG(flags, DM_SUSPEND_FLAG); @@ -469,8 +469,8 @@ dm_dev_suspend_ioctl(prop_dictionary_t d uuid = NULL; flags = 0; - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_NAME, &name); - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_UUID, &uuid); + prop_dictionary_get_string(dm_dict, DM_IOCTL_NAME, &name); + prop_dictionary_get_string(dm_dict, DM_IOCTL_UUID, &uuid); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_FLAGS, &flags); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_MINOR, &minor); @@ -514,8 +514,8 @@ dm_dev_resume_ioctl(prop_dictionary_t dm * printf("%s\n",xml); */ - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_NAME, &name); - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_UUID, &uuid); + prop_dictionary_get_string(dm_dict, DM_IOCTL_NAME, &name); + prop_dictionary_get_string(dm_dict, DM_IOCTL_UUID, &uuid); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_FLAGS, &flags); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_MINOR, &minor); @@ -570,8 +570,8 @@ dm_table_clear_ioctl(prop_dictionary_t d flags = 0; minor = 0; - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_NAME, &name); - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_UUID, &uuid); + prop_dictionary_get_string(dm_dict, DM_IOCTL_NAME, &name); + prop_dictionary_get_string(dm_dict, DM_IOCTL_UUID, &uuid); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_FLAGS, &flags); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_MINOR, &minor); @@ -615,8 +615,8 @@ dm_table_deps_ioctl(prop_dictionary_t dm uuid = NULL; flags = 0; - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_NAME, &name); - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_UUID, &uuid); + prop_dictionary_get_string(dm_dict, DM_IOCTL_NAME, &name); + prop_dictionary_get_string(dm_dict, DM_IOCTL_UUID, &uuid); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_FLAGS, &flags); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_MINOR, &minor); @@ -628,8 +628,8 @@ dm_table_deps_ioctl(prop_dictionary_t dm return ENOENT; } prop_dictionary_set_uint32(dm_dict, DM_IOCTL_MINOR, dmv->minor); - prop_dictionary_set_cstring(dm_dict, DM_IOCTL_NAME, dmv->name); - prop_dictionary_set_cstring(dm_dict, DM_IOCTL_UUID, dmv->uuid); + prop_dictionary_set_string(dm_dict, DM_IOCTL_NAME, dmv->name); + prop_dictionary_set_string(dm_dict, DM_IOCTL_UUID, dmv->uuid); aprint_debug("Getting table deps for device: %s\n", dmv->name); @@ -720,8 +720,8 @@ dm_table_load_ioctl(prop_dictionary_t dm * printf("%s\n",xml); */ - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_NAME, &name); - prop_dictionary_get_cstring_nocopy(dm_dict, DM_IOCTL_UUID, &uuid); + prop_dictionary_get_string(dm_dict, DM_IOCTL_NAME, &name); + prop_dictionary_get_string(dm_dict, DM_IOCTL_UUID, &uuid); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_FLAGS, &flags); prop_dictionary_get_uint32(dm_dict, DM_IOCTL_MINOR, &minor); @@ -753,9 +753,11 @@ dm_table_load_ioctl(prop_dictionary_t dm while ((target_dict = prop_object_iterator_next(iter)) != NULL) { int ret; - char *str = NULL; + const char *cp; + char *str; + size_t strsz; - prop_dictionary_get_cstring_nocopy(target_dict, + prop_dictionary_get_string(target_dict, DM_TABLE_TYPE, &type); /* * If we want to deny table with 2 or more different @@ -786,8 +788,13 @@ dm_table_load_ioctl(prop_dictionary_t dm * null and therefore it should be checked before we try to * use it. */ - prop_dictionary_get_cstring(target_dict, - DM_TABLE_PARAMS, (char **) &str); + cp = NULL; + prop_dictionary_get_string(target_dict, + DM_TABLE_PARAMS, &cp); + if (cp == NULL) + str = NULL; + else + str = kmem_strdupsize(cp, &strsz, KM_SLEEP); if (SLIST_EMPTY(tbl) || last_table == NULL) /* insert this table to head */ @@ -798,14 +805,17 @@ dm_table_load_ioctl(prop_dictionary_t dm if ((ret = dm_table_init(target, table_en, str)) != 0) { dm_table_release(&dmv->table_head, DM_TABLE_INACTIVE); dm_table_destroy(&dmv->table_head, DM_TABLE_INACTIVE); - free(str, M_TEMP); + + if (str != NULL) + kmem_free(str, strsz); dm_dev_unbusy(dmv); prop_object_iterator_release(iter); return ret; } last_table = table_en; - free(str, M_TEMP); + if (str != NULL) + kmem_free(str, strsz); } prop_object_iterator_release(iter); @@ -948,7 +958,7 @@ dm_table_status_ioctl(prop_dictionary_t prop_dictionary_set_uint64(target_dict, DM_TABLE_LENGTH, table_en->length); - prop_dictionary_set_cstring(target_dict, DM_TABLE_TYPE, + prop_dictionary_set_string(target_dict, DM_TABLE_TYPE, table_en->target->name); /* dm_table_get_cur_actv.table ?? */ @@ -959,7 +969,7 @@ dm_table_status_ioctl(prop_dictionary_t * Explicitly clear DM_TABLE_PARAMS to prevent dmsetup(8) from * printing junk when DM_TABLE_PARAMS was never initialized. */ - prop_dictionary_set_cstring(target_dict, DM_TABLE_PARAMS, ""); + prop_dictionary_set_string(target_dict, DM_TABLE_PARAMS, ""); is_table = (flags & DM_STATUS_TABLE_FLAG) ? 1 : 0; if (is_table && table_en->target->table) @@ -972,7 +982,7 @@ dm_table_status_ioctl(prop_dictionary_t params = NULL; if (params != NULL) { - prop_dictionary_set_cstring(target_dict, + prop_dictionary_set_string(target_dict, DM_TABLE_PARAMS, params); kmem_free(params, DM_MAX_PARAMS_SIZE); } Index: src/sys/dev/dm/dm_target.c diff -u src/sys/dev/dm/dm_target.c:1.40 src/sys/dev/dm/dm_target.c:1.41 --- src/sys/dev/dm/dm_target.c:1.40 Tue Jan 21 16:27:53 2020 +++ src/sys/dev/dm/dm_target.c Wed Jul 8 15:07:13 2020 @@ -1,4 +1,4 @@ -/* $NetBSD: dm_target.c,v 1.40 2020/01/21 16:27:53 tkusumi Exp $ */ +/* $NetBSD: dm_target.c,v 1.41 2020/07/08 15:07:13 thorpej 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.40 2020/01/21 16:27:53 tkusumi Exp $"); +__KERNEL_RCSID(0, "$NetBSD: dm_target.c,v 1.41 2020/07/08 15:07:13 thorpej Exp $"); #include <sys/types.h> #include <sys/param.h> @@ -285,7 +285,7 @@ dm_target_prop_list(void) target_dict = prop_dictionary_create(); ver = prop_array_create(); - prop_dictionary_set_cstring(target_dict, DM_TARGETS_NAME, + prop_dictionary_set_string(target_dict, DM_TARGETS_NAME, dm_target->name); for (i = 0; i < 3; i++)