5 * The contents of this file are subject to the terms of the
6 * Common Development and Distribution License (the "License").
7 * You may not use this file except in compliance with the License.
9 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 * or http://www.opensolaris.org/os/licensing.
11 * See the License for the specific language governing permissions
12 * and limitations under the License.
14 * When distributing Covered Code, include this CDDL HEADER in each
15 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 * If applicable, add the following below this CDDL HEADER, with the
17 * fields enclosed by brackets "[]" replaced with your own identifying
18 * information: Portions Copyright [yyyy] [name of copyright owner]
24 * Copyright (c) 2012 by Delphix. All rights reserved.
27 #include <sys/nvpair.h>
29 #include <sys/zfs_context.h>
31 #include <sys/debug.h>
36 * "Force" nvlist wrapper.
38 * These functions wrap the nvlist_* functions with assertions that assume
39 * the operation is successful. This allows the caller's code to be much
40 * more readable, especially for the fnvlist_lookup_* and fnvpair_value_*
41 * functions, which can return the requested value (rather than filling in
44 * These functions use NV_UNIQUE_NAME, encoding NV_ENCODE_NATIVE, and allocate
47 * More wrappers should be added as needed -- for example
48 * nvlist_lookup_*_array and nvpair_value_*_array.
55 VERIFY0(nvlist_alloc(&nvl, NV_UNIQUE_NAME, KM_SLEEP));
60 fnvlist_free(nvlist_t *nvl)
66 fnvlist_size(nvlist_t *nvl)
69 VERIFY0(nvlist_size(nvl, &size, NV_ENCODE_NATIVE));
74 * Returns allocated buffer of size *sizep. Caller must free the buffer with
75 * fnvlist_pack_free().
78 fnvlist_pack(nvlist_t *nvl, size_t *sizep)
81 VERIFY3U(nvlist_pack(nvl, &packed, sizep, NV_ENCODE_NATIVE,
88 fnvlist_pack_free(char *pack, size_t size)
91 kmem_free(pack, size);
98 fnvlist_unpack(char *buf, size_t buflen)
101 VERIFY0(nvlist_unpack(buf, buflen, &rv, KM_SLEEP));
106 fnvlist_dup(nvlist_t *nvl)
109 VERIFY0(nvlist_dup(nvl, &rv, KM_SLEEP));
114 fnvlist_merge(nvlist_t *dst, nvlist_t *src)
116 VERIFY0(nvlist_merge(dst, src, KM_SLEEP));
120 fnvlist_add_boolean(nvlist_t *nvl, const char *name)
122 VERIFY0(nvlist_add_boolean(nvl, name));
126 fnvlist_add_boolean_value(nvlist_t *nvl, const char *name, boolean_t val)
128 VERIFY0(nvlist_add_boolean_value(nvl, name, val));
132 fnvlist_add_byte(nvlist_t *nvl, const char *name, uchar_t val)
134 VERIFY0(nvlist_add_byte(nvl, name, val));
138 fnvlist_add_int8(nvlist_t *nvl, const char *name, int8_t val)
140 VERIFY0(nvlist_add_int8(nvl, name, val));
144 fnvlist_add_uint8(nvlist_t *nvl, const char *name, uint8_t val)
146 VERIFY0(nvlist_add_uint8(nvl, name, val));
150 fnvlist_add_int16(nvlist_t *nvl, const char *name, int16_t val)
152 VERIFY0(nvlist_add_int16(nvl, name, val));
156 fnvlist_add_uint16(nvlist_t *nvl, const char *name, uint16_t val)
158 VERIFY0(nvlist_add_uint16(nvl, name, val));
162 fnvlist_add_int32(nvlist_t *nvl, const char *name, int32_t val)
164 VERIFY0(nvlist_add_int32(nvl, name, val));
168 fnvlist_add_uint32(nvlist_t *nvl, const char *name, uint32_t val)
170 VERIFY0(nvlist_add_uint32(nvl, name, val));
174 fnvlist_add_int64(nvlist_t *nvl, const char *name, int64_t val)
176 VERIFY0(nvlist_add_int64(nvl, name, val));
180 fnvlist_add_uint64(nvlist_t *nvl, const char *name, uint64_t val)
182 VERIFY0(nvlist_add_uint64(nvl, name, val));
186 fnvlist_add_string(nvlist_t *nvl, const char *name, const char *val)
188 VERIFY0(nvlist_add_string(nvl, name, val));
192 fnvlist_add_nvlist(nvlist_t *nvl, const char *name, nvlist_t *val)
194 VERIFY0(nvlist_add_nvlist(nvl, name, val));
198 fnvlist_add_nvpair(nvlist_t *nvl, nvpair_t *pair)
200 VERIFY0(nvlist_add_nvpair(nvl, pair));
204 fnvlist_add_boolean_array(nvlist_t *nvl, const char *name,
205 boolean_t *val, uint_t n)
207 VERIFY0(nvlist_add_boolean_array(nvl, name, val, n));
211 fnvlist_add_byte_array(nvlist_t *nvl, const char *name, uchar_t *val, uint_t n)
213 VERIFY0(nvlist_add_byte_array(nvl, name, val, n));
217 fnvlist_add_int8_array(nvlist_t *nvl, const char *name, int8_t *val, uint_t n)
219 VERIFY0(nvlist_add_int8_array(nvl, name, val, n));
223 fnvlist_add_uint8_array(nvlist_t *nvl, const char *name, uint8_t *val, uint_t n)
225 VERIFY0(nvlist_add_uint8_array(nvl, name, val, n));
229 fnvlist_add_int16_array(nvlist_t *nvl, const char *name, int16_t *val, uint_t n)
231 VERIFY0(nvlist_add_int16_array(nvl, name, val, n));
235 fnvlist_add_uint16_array(nvlist_t *nvl, const char *name,
236 uint16_t *val, uint_t n)
238 VERIFY0(nvlist_add_uint16_array(nvl, name, val, n));
242 fnvlist_add_int32_array(nvlist_t *nvl, const char *name, int32_t *val, uint_t n)
244 VERIFY0(nvlist_add_int32_array(nvl, name, val, n));
248 fnvlist_add_uint32_array(nvlist_t *nvl, const char *name,
249 uint32_t *val, uint_t n)
251 VERIFY0(nvlist_add_uint32_array(nvl, name, val, n));
255 fnvlist_add_int64_array(nvlist_t *nvl, const char *name, int64_t *val, uint_t n)
257 VERIFY0(nvlist_add_int64_array(nvl, name, val, n));
261 fnvlist_add_uint64_array(nvlist_t *nvl, const char *name,
262 uint64_t *val, uint_t n)
264 VERIFY0(nvlist_add_uint64_array(nvl, name, val, n));
268 fnvlist_add_string_array(nvlist_t *nvl, const char *name,
269 char * const *val, uint_t n)
271 VERIFY0(nvlist_add_string_array(nvl, name, val, n));
275 fnvlist_add_nvlist_array(nvlist_t *nvl, const char *name,
276 nvlist_t **val, uint_t n)
278 VERIFY0(nvlist_add_nvlist_array(nvl, name, val, n));
282 fnvlist_remove(nvlist_t *nvl, const char *name)
284 VERIFY0(nvlist_remove_all(nvl, name));
288 fnvlist_remove_nvpair(nvlist_t *nvl, nvpair_t *pair)
290 VERIFY0(nvlist_remove_nvpair(nvl, pair));
294 fnvlist_lookup_nvpair(nvlist_t *nvl, const char *name)
297 VERIFY0(nvlist_lookup_nvpair(nvl, name, &rv));
301 /* returns B_TRUE if the entry exists */
303 fnvlist_lookup_boolean(nvlist_t *nvl, const char *name)
305 return (nvlist_lookup_boolean(nvl, name) == 0);
309 fnvlist_lookup_boolean_value(nvlist_t *nvl, const char *name)
312 VERIFY0(nvlist_lookup_boolean_value(nvl, name, &rv));
317 fnvlist_lookup_byte(nvlist_t *nvl, const char *name)
320 VERIFY0(nvlist_lookup_byte(nvl, name, &rv));
325 fnvlist_lookup_int8(nvlist_t *nvl, const char *name)
328 VERIFY0(nvlist_lookup_int8(nvl, name, &rv));
333 fnvlist_lookup_int16(nvlist_t *nvl, const char *name)
336 VERIFY0(nvlist_lookup_int16(nvl, name, &rv));
341 fnvlist_lookup_int32(nvlist_t *nvl, const char *name)
344 VERIFY0(nvlist_lookup_int32(nvl, name, &rv));
349 fnvlist_lookup_int64(nvlist_t *nvl, const char *name)
352 VERIFY0(nvlist_lookup_int64(nvl, name, &rv));
357 fnvlist_lookup_uint8_t(nvlist_t *nvl, const char *name)
360 VERIFY0(nvlist_lookup_uint8(nvl, name, &rv));
365 fnvlist_lookup_uint16(nvlist_t *nvl, const char *name)
368 VERIFY0(nvlist_lookup_uint16(nvl, name, &rv));
373 fnvlist_lookup_uint32(nvlist_t *nvl, const char *name)
376 VERIFY0(nvlist_lookup_uint32(nvl, name, &rv));
381 fnvlist_lookup_uint64(nvlist_t *nvl, const char *name)
384 VERIFY0(nvlist_lookup_uint64(nvl, name, &rv));
389 fnvlist_lookup_string(nvlist_t *nvl, const char *name)
392 VERIFY0(nvlist_lookup_string(nvl, name, &rv));
397 fnvlist_lookup_nvlist(nvlist_t *nvl, const char *name)
400 VERIFY0(nvlist_lookup_nvlist(nvl, name, &rv));
405 fnvpair_value_boolean_value(nvpair_t *nvp)
408 VERIFY0(nvpair_value_boolean_value(nvp, &rv));
413 fnvpair_value_byte(nvpair_t *nvp)
416 VERIFY0(nvpair_value_byte(nvp, &rv));
421 fnvpair_value_int8(nvpair_t *nvp)
424 VERIFY0(nvpair_value_int8(nvp, &rv));
429 fnvpair_value_int16(nvpair_t *nvp)
432 VERIFY0(nvpair_value_int16(nvp, &rv));
437 fnvpair_value_int32(nvpair_t *nvp)
440 VERIFY0(nvpair_value_int32(nvp, &rv));
445 fnvpair_value_int64(nvpair_t *nvp)
448 VERIFY0(nvpair_value_int64(nvp, &rv));
453 fnvpair_value_uint8_t(nvpair_t *nvp)
456 VERIFY0(nvpair_value_uint8(nvp, &rv));
461 fnvpair_value_uint16(nvpair_t *nvp)
464 VERIFY0(nvpair_value_uint16(nvp, &rv));
469 fnvpair_value_uint32(nvpair_t *nvp)
472 VERIFY0(nvpair_value_uint32(nvp, &rv));
477 fnvpair_value_uint64(nvpair_t *nvp)
480 VERIFY0(nvpair_value_uint64(nvp, &rv));
485 fnvpair_value_string(nvpair_t *nvp)
488 VERIFY0(nvpair_value_string(nvp, &rv));
493 fnvpair_value_nvlist(nvpair_t *nvp)
496 VERIFY0(nvpair_value_nvlist(nvp, &rv));