mirror of
				https://git.proxmox.com/git/mirror_zfs
				synced 2025-11-04 10:50:49 +00:00 
			
		
		
		
	After addressing coverity complaints involving `nvpair_name()`, the compiler started complaining about dropping const. This lead to a rabbit hole where not only `nvpair_name()` needed to be constified, but also `nvpair_value_string()`, `fnvpair_value_string()` and a few other static functions, plus variable pointers throughout the code. The result became a fairly big change, so it has been split out into its own patch. Reviewed-by: Tino Reichardt <milky-zfs@mcmilk.de> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: Richard Yao <richard.yao@alumni.stonybrook.edu> Closes #14612
		
			
				
	
	
		
			667 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			667 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * CDDL HEADER START
 | 
						|
 *
 | 
						|
 * The contents of this file are subject to the terms of the
 | 
						|
 * Common Development and Distribution License (the "License").
 | 
						|
 * You may not use this file except in compliance with the License.
 | 
						|
 *
 | 
						|
 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
 | 
						|
 * or https://opensource.org/licenses/CDDL-1.0.
 | 
						|
 * See the License for the specific language governing permissions
 | 
						|
 * and limitations under the License.
 | 
						|
 *
 | 
						|
 * When distributing Covered Code, include this CDDL HEADER in each
 | 
						|
 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
 | 
						|
 * If applicable, add the following below this CDDL HEADER, with the
 | 
						|
 * fields enclosed by brackets "[]" replaced with your own identifying
 | 
						|
 * information: Portions Copyright [yyyy] [name of copyright owner]
 | 
						|
 *
 | 
						|
 * CDDL HEADER END
 | 
						|
 */
 | 
						|
 | 
						|
/*
 | 
						|
 * Copyright (c) 2012, 2018 by Delphix. All rights reserved.
 | 
						|
 */
 | 
						|
 | 
						|
#include <sys/nvpair.h>
 | 
						|
#include <sys/kmem.h>
 | 
						|
#include <sys/debug.h>
 | 
						|
#include <sys/param.h>
 | 
						|
#ifndef _KERNEL
 | 
						|
#include <stdlib.h>
 | 
						|
#endif
 | 
						|
 | 
						|
/*
 | 
						|
 * "Force" nvlist wrapper.
 | 
						|
 *
 | 
						|
 * These functions wrap the nvlist_* functions with assertions that assume
 | 
						|
 * the operation is successful.  This allows the caller's code to be much
 | 
						|
 * more readable, especially for the fnvlist_lookup_* and fnvpair_value_*
 | 
						|
 * functions, which can return the requested value (rather than filling in
 | 
						|
 * a pointer).
 | 
						|
 *
 | 
						|
 * These functions use NV_UNIQUE_NAME, encoding NV_ENCODE_NATIVE, and allocate
 | 
						|
 * with KM_SLEEP.
 | 
						|
 *
 | 
						|
 * More wrappers should be added as needed -- for example
 | 
						|
 * nvlist_lookup_*_array and nvpair_value_*_array.
 | 
						|
 */
 | 
						|
 | 
						|
nvlist_t *
 | 
						|
fnvlist_alloc(void)
 | 
						|
{
 | 
						|
	nvlist_t *nvl;
 | 
						|
	VERIFY0(nvlist_alloc(&nvl, NV_UNIQUE_NAME, KM_SLEEP));
 | 
						|
	return (nvl);
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_free(nvlist_t *nvl)
 | 
						|
{
 | 
						|
	nvlist_free(nvl);
 | 
						|
}
 | 
						|
 | 
						|
size_t
 | 
						|
fnvlist_size(nvlist_t *nvl)
 | 
						|
{
 | 
						|
	size_t size;
 | 
						|
	VERIFY0(nvlist_size(nvl, &size, NV_ENCODE_NATIVE));
 | 
						|
	return (size);
 | 
						|
}
 | 
						|
 | 
						|
/*
 | 
						|
 * Returns allocated buffer of size *sizep.  Caller must free the buffer with
 | 
						|
 * fnvlist_pack_free().
 | 
						|
 */
 | 
						|
char *
 | 
						|
fnvlist_pack(nvlist_t *nvl, size_t *sizep)
 | 
						|
{
 | 
						|
	char *packed = 0;
 | 
						|
	VERIFY3U(nvlist_pack(nvl, &packed, sizep, NV_ENCODE_NATIVE,
 | 
						|
	    KM_SLEEP), ==, 0);
 | 
						|
	return (packed);
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_pack_free(char *pack, size_t size)
 | 
						|
{
 | 
						|
#ifdef _KERNEL
 | 
						|
	kmem_free(pack, size);
 | 
						|
#else
 | 
						|
	(void) size;
 | 
						|
	free(pack);
 | 
						|
#endif
 | 
						|
}
 | 
						|
 | 
						|
nvlist_t *
 | 
						|
fnvlist_unpack(char *buf, size_t buflen)
 | 
						|
{
 | 
						|
	nvlist_t *rv;
 | 
						|
	VERIFY0(nvlist_unpack(buf, buflen, &rv, KM_SLEEP));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
nvlist_t *
 | 
						|
fnvlist_dup(const nvlist_t *nvl)
 | 
						|
{
 | 
						|
	nvlist_t *rv;
 | 
						|
	VERIFY0(nvlist_dup(nvl, &rv, KM_SLEEP));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_merge(nvlist_t *dst, nvlist_t *src)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_merge(dst, src, KM_SLEEP));
 | 
						|
}
 | 
						|
 | 
						|
size_t
 | 
						|
fnvlist_num_pairs(nvlist_t *nvl)
 | 
						|
{
 | 
						|
	size_t count = 0;
 | 
						|
	nvpair_t *pair;
 | 
						|
 | 
						|
	for (pair = nvlist_next_nvpair(nvl, 0); pair != NULL;
 | 
						|
	    pair = nvlist_next_nvpair(nvl, pair))
 | 
						|
		count++;
 | 
						|
	return (count);
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_boolean(nvlist_t *nvl, const char *name)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_boolean(nvl, name));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_boolean_value(nvlist_t *nvl, const char *name, boolean_t val)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_boolean_value(nvl, name, val));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_byte(nvlist_t *nvl, const char *name, uchar_t val)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_byte(nvl, name, val));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_int8(nvlist_t *nvl, const char *name, int8_t val)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_int8(nvl, name, val));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_uint8(nvlist_t *nvl, const char *name, uint8_t val)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_uint8(nvl, name, val));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_int16(nvlist_t *nvl, const char *name, int16_t val)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_int16(nvl, name, val));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_uint16(nvlist_t *nvl, const char *name, uint16_t val)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_uint16(nvl, name, val));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_int32(nvlist_t *nvl, const char *name, int32_t val)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_int32(nvl, name, val));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_uint32(nvlist_t *nvl, const char *name, uint32_t val)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_uint32(nvl, name, val));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_int64(nvlist_t *nvl, const char *name, int64_t val)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_int64(nvl, name, val));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_uint64(nvlist_t *nvl, const char *name, uint64_t val)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_uint64(nvl, name, val));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_string(nvlist_t *nvl, const char *name, const char *val)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_string(nvl, name, val));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_nvlist(nvlist_t *nvl, const char *name, nvlist_t *val)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_nvlist(nvl, name, val));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_nvpair(nvlist_t *nvl, nvpair_t *pair)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_nvpair(nvl, pair));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_boolean_array(nvlist_t *nvl, const char *name,
 | 
						|
    const boolean_t *val, uint_t n)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_boolean_array(nvl, name, val, n));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_byte_array(nvlist_t *nvl, const char *name, const uchar_t *val,
 | 
						|
    uint_t n)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_byte_array(nvl, name, val, n));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_int8_array(nvlist_t *nvl, const char *name, const int8_t *val,
 | 
						|
    uint_t n)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_int8_array(nvl, name, val, n));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_uint8_array(nvlist_t *nvl, const char *name, const uint8_t *val,
 | 
						|
    uint_t n)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_uint8_array(nvl, name, val, n));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_int16_array(nvlist_t *nvl, const char *name, const int16_t *val,
 | 
						|
    uint_t n)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_int16_array(nvl, name, val, n));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_uint16_array(nvlist_t *nvl, const char *name,
 | 
						|
    const uint16_t *val, uint_t n)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_uint16_array(nvl, name, val, n));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_int32_array(nvlist_t *nvl, const char *name, const int32_t *val,
 | 
						|
    uint_t n)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_int32_array(nvl, name, val, n));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_uint32_array(nvlist_t *nvl, const char *name,
 | 
						|
    const uint32_t *val, uint_t n)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_uint32_array(nvl, name, val, n));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_int64_array(nvlist_t *nvl, const char *name, const int64_t *val,
 | 
						|
    uint_t n)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_int64_array(nvl, name, val, n));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_uint64_array(nvlist_t *nvl, const char *name,
 | 
						|
    const uint64_t *val, uint_t n)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_uint64_array(nvl, name, val, n));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_string_array(nvlist_t *nvl, const char *name,
 | 
						|
    const char * const *val, uint_t n)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_string_array(nvl, name, val, n));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_add_nvlist_array(nvlist_t *nvl, const char *name,
 | 
						|
    const nvlist_t * const *val, uint_t n)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_add_nvlist_array(nvl, name, val, n));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_remove(nvlist_t *nvl, const char *name)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_remove_all(nvl, name));
 | 
						|
}
 | 
						|
 | 
						|
void
 | 
						|
fnvlist_remove_nvpair(nvlist_t *nvl, nvpair_t *pair)
 | 
						|
{
 | 
						|
	VERIFY0(nvlist_remove_nvpair(nvl, pair));
 | 
						|
}
 | 
						|
 | 
						|
nvpair_t *
 | 
						|
fnvlist_lookup_nvpair(nvlist_t *nvl, const char *name)
 | 
						|
{
 | 
						|
	nvpair_t *rv;
 | 
						|
	VERIFY0(nvlist_lookup_nvpair(nvl, name, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
/* returns B_TRUE if the entry exists */
 | 
						|
boolean_t
 | 
						|
fnvlist_lookup_boolean(const nvlist_t *nvl, const char *name)
 | 
						|
{
 | 
						|
	return (nvlist_lookup_boolean(nvl, name) == 0);
 | 
						|
}
 | 
						|
 | 
						|
boolean_t
 | 
						|
fnvlist_lookup_boolean_value(const nvlist_t *nvl, const char *name)
 | 
						|
{
 | 
						|
	boolean_t rv;
 | 
						|
	VERIFY0(nvlist_lookup_boolean_value(nvl, name, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
uchar_t
 | 
						|
fnvlist_lookup_byte(const nvlist_t *nvl, const char *name)
 | 
						|
{
 | 
						|
	uchar_t rv;
 | 
						|
	VERIFY0(nvlist_lookup_byte(nvl, name, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
int8_t
 | 
						|
fnvlist_lookup_int8(const nvlist_t *nvl, const char *name)
 | 
						|
{
 | 
						|
	int8_t rv;
 | 
						|
	VERIFY0(nvlist_lookup_int8(nvl, name, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
int16_t
 | 
						|
fnvlist_lookup_int16(const nvlist_t *nvl, const char *name)
 | 
						|
{
 | 
						|
	int16_t rv;
 | 
						|
	VERIFY0(nvlist_lookup_int16(nvl, name, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
int32_t
 | 
						|
fnvlist_lookup_int32(const nvlist_t *nvl, const char *name)
 | 
						|
{
 | 
						|
	int32_t rv;
 | 
						|
	VERIFY0(nvlist_lookup_int32(nvl, name, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
int64_t
 | 
						|
fnvlist_lookup_int64(const nvlist_t *nvl, const char *name)
 | 
						|
{
 | 
						|
	int64_t rv;
 | 
						|
	VERIFY0(nvlist_lookup_int64(nvl, name, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
uint8_t
 | 
						|
fnvlist_lookup_uint8(const nvlist_t *nvl, const char *name)
 | 
						|
{
 | 
						|
	uint8_t rv;
 | 
						|
	VERIFY0(nvlist_lookup_uint8(nvl, name, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
uint16_t
 | 
						|
fnvlist_lookup_uint16(const nvlist_t *nvl, const char *name)
 | 
						|
{
 | 
						|
	uint16_t rv;
 | 
						|
	VERIFY0(nvlist_lookup_uint16(nvl, name, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
uint32_t
 | 
						|
fnvlist_lookup_uint32(const nvlist_t *nvl, const char *name)
 | 
						|
{
 | 
						|
	uint32_t rv;
 | 
						|
	VERIFY0(nvlist_lookup_uint32(nvl, name, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
uint64_t
 | 
						|
fnvlist_lookup_uint64(const nvlist_t *nvl, const char *name)
 | 
						|
{
 | 
						|
	uint64_t rv;
 | 
						|
	VERIFY0(nvlist_lookup_uint64(nvl, name, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
const char *
 | 
						|
fnvlist_lookup_string(const nvlist_t *nvl, const char *name)
 | 
						|
{
 | 
						|
	const char *rv;
 | 
						|
	VERIFY0(nvlist_lookup_string(nvl, name, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
nvlist_t *
 | 
						|
fnvlist_lookup_nvlist(nvlist_t *nvl, const char *name)
 | 
						|
{
 | 
						|
	nvlist_t *rv;
 | 
						|
	VERIFY0(nvlist_lookup_nvlist(nvl, name, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
boolean_t *
 | 
						|
fnvlist_lookup_boolean_array(nvlist_t *nvl, const char *name, uint_t *n)
 | 
						|
{
 | 
						|
	boolean_t *rv;
 | 
						|
	VERIFY0(nvlist_lookup_boolean_array(nvl, name, &rv, n));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
uchar_t *
 | 
						|
fnvlist_lookup_byte_array(nvlist_t *nvl, const char *name, uint_t *n)
 | 
						|
{
 | 
						|
	uchar_t *rv;
 | 
						|
	VERIFY0(nvlist_lookup_byte_array(nvl, name, &rv, n));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
int8_t *
 | 
						|
fnvlist_lookup_int8_array(nvlist_t *nvl, const char *name, uint_t *n)
 | 
						|
{
 | 
						|
	int8_t *rv;
 | 
						|
	VERIFY0(nvlist_lookup_int8_array(nvl, name, &rv, n));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
uint8_t *
 | 
						|
fnvlist_lookup_uint8_array(nvlist_t *nvl, const char *name, uint_t *n)
 | 
						|
{
 | 
						|
	uint8_t *rv;
 | 
						|
	VERIFY0(nvlist_lookup_uint8_array(nvl, name, &rv, n));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
int16_t *
 | 
						|
fnvlist_lookup_int16_array(nvlist_t *nvl, const char *name, uint_t *n)
 | 
						|
{
 | 
						|
	int16_t *rv;
 | 
						|
	VERIFY0(nvlist_lookup_int16_array(nvl, name, &rv, n));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
uint16_t *
 | 
						|
fnvlist_lookup_uint16_array(nvlist_t *nvl, const char *name, uint_t *n)
 | 
						|
{
 | 
						|
	uint16_t *rv;
 | 
						|
	VERIFY0(nvlist_lookup_uint16_array(nvl, name, &rv, n));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
int32_t *
 | 
						|
fnvlist_lookup_int32_array(nvlist_t *nvl, const char *name, uint_t *n)
 | 
						|
{
 | 
						|
	int32_t *rv;
 | 
						|
	VERIFY0(nvlist_lookup_int32_array(nvl, name, &rv, n));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
uint32_t *
 | 
						|
fnvlist_lookup_uint32_array(nvlist_t *nvl, const char *name, uint_t *n)
 | 
						|
{
 | 
						|
	uint32_t *rv;
 | 
						|
	VERIFY0(nvlist_lookup_uint32_array(nvl, name, &rv, n));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
int64_t *
 | 
						|
fnvlist_lookup_int64_array(nvlist_t *nvl, const char *name, uint_t *n)
 | 
						|
{
 | 
						|
	int64_t *rv;
 | 
						|
	VERIFY0(nvlist_lookup_int64_array(nvl, name, &rv, n));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
uint64_t *
 | 
						|
fnvlist_lookup_uint64_array(nvlist_t *nvl, const char *name, uint_t *n)
 | 
						|
{
 | 
						|
	uint64_t *rv;
 | 
						|
	VERIFY0(nvlist_lookup_uint64_array(nvl, name, &rv, n));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
boolean_t
 | 
						|
fnvpair_value_boolean_value(const nvpair_t *nvp)
 | 
						|
{
 | 
						|
	boolean_t rv;
 | 
						|
	VERIFY0(nvpair_value_boolean_value(nvp, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
uchar_t
 | 
						|
fnvpair_value_byte(const nvpair_t *nvp)
 | 
						|
{
 | 
						|
	uchar_t rv;
 | 
						|
	VERIFY0(nvpair_value_byte(nvp, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
int8_t
 | 
						|
fnvpair_value_int8(const nvpair_t *nvp)
 | 
						|
{
 | 
						|
	int8_t rv;
 | 
						|
	VERIFY0(nvpair_value_int8(nvp, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
int16_t
 | 
						|
fnvpair_value_int16(const nvpair_t *nvp)
 | 
						|
{
 | 
						|
	int16_t rv;
 | 
						|
	VERIFY0(nvpair_value_int16(nvp, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
int32_t
 | 
						|
fnvpair_value_int32(const nvpair_t *nvp)
 | 
						|
{
 | 
						|
	int32_t rv;
 | 
						|
	VERIFY0(nvpair_value_int32(nvp, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
int64_t
 | 
						|
fnvpair_value_int64(const nvpair_t *nvp)
 | 
						|
{
 | 
						|
	int64_t rv;
 | 
						|
	VERIFY0(nvpair_value_int64(nvp, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
uint8_t
 | 
						|
fnvpair_value_uint8(const nvpair_t *nvp)
 | 
						|
{
 | 
						|
	uint8_t rv;
 | 
						|
	VERIFY0(nvpair_value_uint8(nvp, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
uint16_t
 | 
						|
fnvpair_value_uint16(const nvpair_t *nvp)
 | 
						|
{
 | 
						|
	uint16_t rv;
 | 
						|
	VERIFY0(nvpair_value_uint16(nvp, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
uint32_t
 | 
						|
fnvpair_value_uint32(const nvpair_t *nvp)
 | 
						|
{
 | 
						|
	uint32_t rv;
 | 
						|
	VERIFY0(nvpair_value_uint32(nvp, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
uint64_t
 | 
						|
fnvpair_value_uint64(const nvpair_t *nvp)
 | 
						|
{
 | 
						|
	uint64_t rv;
 | 
						|
	VERIFY0(nvpair_value_uint64(nvp, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
const char *
 | 
						|
fnvpair_value_string(const nvpair_t *nvp)
 | 
						|
{
 | 
						|
	const char *rv;
 | 
						|
	VERIFY0(nvpair_value_string(nvp, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
nvlist_t *
 | 
						|
fnvpair_value_nvlist(nvpair_t *nvp)
 | 
						|
{
 | 
						|
	nvlist_t *rv;
 | 
						|
	VERIFY0(nvpair_value_nvlist(nvp, &rv));
 | 
						|
	return (rv);
 | 
						|
}
 | 
						|
 | 
						|
#if defined(_KERNEL)
 | 
						|
 | 
						|
EXPORT_SYMBOL(fnvlist_alloc);
 | 
						|
EXPORT_SYMBOL(fnvlist_free);
 | 
						|
EXPORT_SYMBOL(fnvlist_size);
 | 
						|
EXPORT_SYMBOL(fnvlist_pack);
 | 
						|
EXPORT_SYMBOL(fnvlist_pack_free);
 | 
						|
EXPORT_SYMBOL(fnvlist_unpack);
 | 
						|
EXPORT_SYMBOL(fnvlist_dup);
 | 
						|
EXPORT_SYMBOL(fnvlist_merge);
 | 
						|
 | 
						|
EXPORT_SYMBOL(fnvlist_add_nvpair);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_boolean);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_boolean_value);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_byte);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_int8);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_uint8);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_int16);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_uint16);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_int32);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_uint32);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_int64);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_uint64);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_string);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_nvlist);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_boolean_array);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_byte_array);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_int8_array);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_uint8_array);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_int16_array);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_uint16_array);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_int32_array);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_uint32_array);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_int64_array);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_uint64_array);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_string_array);
 | 
						|
EXPORT_SYMBOL(fnvlist_add_nvlist_array);
 | 
						|
 | 
						|
EXPORT_SYMBOL(fnvlist_remove);
 | 
						|
EXPORT_SYMBOL(fnvlist_remove_nvpair);
 | 
						|
 | 
						|
EXPORT_SYMBOL(fnvlist_lookup_nvpair);
 | 
						|
EXPORT_SYMBOL(fnvlist_lookup_boolean);
 | 
						|
EXPORT_SYMBOL(fnvlist_lookup_boolean_value);
 | 
						|
EXPORT_SYMBOL(fnvlist_lookup_byte);
 | 
						|
EXPORT_SYMBOL(fnvlist_lookup_int8);
 | 
						|
EXPORT_SYMBOL(fnvlist_lookup_uint8);
 | 
						|
EXPORT_SYMBOL(fnvlist_lookup_int16);
 | 
						|
EXPORT_SYMBOL(fnvlist_lookup_uint16);
 | 
						|
EXPORT_SYMBOL(fnvlist_lookup_int32);
 | 
						|
EXPORT_SYMBOL(fnvlist_lookup_uint32);
 | 
						|
EXPORT_SYMBOL(fnvlist_lookup_int64);
 | 
						|
EXPORT_SYMBOL(fnvlist_lookup_uint64);
 | 
						|
EXPORT_SYMBOL(fnvlist_lookup_string);
 | 
						|
EXPORT_SYMBOL(fnvlist_lookup_nvlist);
 | 
						|
 | 
						|
EXPORT_SYMBOL(fnvpair_value_boolean_value);
 | 
						|
EXPORT_SYMBOL(fnvpair_value_byte);
 | 
						|
EXPORT_SYMBOL(fnvpair_value_int8);
 | 
						|
EXPORT_SYMBOL(fnvpair_value_uint8);
 | 
						|
EXPORT_SYMBOL(fnvpair_value_int16);
 | 
						|
EXPORT_SYMBOL(fnvpair_value_uint16);
 | 
						|
EXPORT_SYMBOL(fnvpair_value_int32);
 | 
						|
EXPORT_SYMBOL(fnvpair_value_uint32);
 | 
						|
EXPORT_SYMBOL(fnvpair_value_int64);
 | 
						|
EXPORT_SYMBOL(fnvpair_value_uint64);
 | 
						|
EXPORT_SYMBOL(fnvpair_value_string);
 | 
						|
EXPORT_SYMBOL(fnvpair_value_nvlist);
 | 
						|
EXPORT_SYMBOL(fnvlist_num_pairs);
 | 
						|
 | 
						|
#endif
 |