2 * Copyright (c) 2009-2013 The FreeBSD Foundation
5 * This software was developed by Pawel Jakub Dawidek under sponsorship from
6 * the FreeBSD Foundation.
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions
11 * 1. Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
18 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE
21 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30 #include <sys/cdefs.h>
31 __FBSDID("$FreeBSD$");
33 #include <sys/param.h>
34 #include <sys/endian.h>
35 #include <sys/queue.h>
50 #include "common_impl.h"
53 #include "nvlist_impl.h"
54 #include "nvpair_impl.h"
58 #define PJDLOG_ASSERT(...) assert(__VA_ARGS__)
59 #define PJDLOG_RASSERT(expr, ...) assert(expr)
60 #define PJDLOG_ABORT(...) abort()
63 #define NVPAIR_MAGIC 0x6e7670 /* "nvp" */
71 TAILQ_ENTRY(nvpair) nvp_next;
74 #define NVPAIR_ASSERT(nvp) do { \
75 PJDLOG_ASSERT((nvp) != NULL); \
76 PJDLOG_ASSERT((nvp)->nvp_magic == NVPAIR_MAGIC); \
79 struct nvpair_header {
81 uint16_t nvph_namesize;
82 uint64_t nvph_datasize;
87 nvpair_assert(const nvpair_t *nvp)
94 nvpair_nvlist(const nvpair_t *nvp)
99 return (nvp->nvp_list);
103 nvpair_next(const nvpair_t *nvp)
107 PJDLOG_ASSERT(nvp->nvp_list != NULL);
109 return (TAILQ_NEXT(nvp, nvp_next));
113 nvpair_prev(const nvpair_t *nvp)
117 PJDLOG_ASSERT(nvp->nvp_list != NULL);
119 return (TAILQ_PREV(nvp, nvl_head, nvp_next));
123 nvpair_insert(struct nvl_head *head, nvpair_t *nvp, nvlist_t *nvl)
127 PJDLOG_ASSERT(nvp->nvp_list == NULL);
128 PJDLOG_ASSERT(!nvlist_exists(nvl, nvpair_name(nvp)));
130 TAILQ_INSERT_TAIL(head, nvp, nvp_next);
135 nvpair_remove_nvlist(nvpair_t *nvp)
139 /* XXX: DECONST is bad, mkay? */
140 nvl = __DECONST(nvlist_t *, nvpair_get_nvlist(nvp));
141 PJDLOG_ASSERT(nvl != NULL);
142 nvlist_set_parent(nvl, NULL);
146 nvpair_remove(struct nvl_head *head, nvpair_t *nvp, const nvlist_t *nvl)
150 PJDLOG_ASSERT(nvp->nvp_list == nvl);
152 if (nvpair_type(nvp) == NV_TYPE_NVLIST)
153 nvpair_remove_nvlist(nvp);
155 TAILQ_REMOVE(head, nvp, nvp_next);
156 nvp->nvp_list = NULL;
160 nvpair_clone(const nvpair_t *nvp)
169 name = nvpair_name(nvp);
171 switch (nvpair_type(nvp)) {
173 newnvp = nvpair_create_null(name);
176 newnvp = nvpair_create_bool(name, nvpair_get_bool(nvp));
179 newnvp = nvpair_create_number(name, nvpair_get_number(nvp));
182 newnvp = nvpair_create_string(name, nvpair_get_string(nvp));
185 newnvp = nvpair_create_nvlist(name, nvpair_get_nvlist(nvp));
187 case NV_TYPE_DESCRIPTOR:
188 newnvp = nvpair_create_descriptor(name,
189 nvpair_get_descriptor(nvp));
192 data = nvpair_get_binary(nvp, &datasize);
193 newnvp = nvpair_create_binary(name, data, datasize);
196 PJDLOG_ABORT("Unknown type: %d.", nvpair_type(nvp));
203 nvpair_header_size(void)
206 return (sizeof(struct nvpair_header));
210 nvpair_size(const nvpair_t *nvp)
215 return (nvp->nvp_datasize);
219 nvpair_pack_header(const nvpair_t *nvp, unsigned char *ptr, size_t *leftp)
221 struct nvpair_header nvphdr;
226 nvphdr.nvph_type = nvp->nvp_type;
227 namesize = strlen(nvp->nvp_name) + 1;
228 PJDLOG_ASSERT(namesize > 0 && namesize <= UINT16_MAX);
229 nvphdr.nvph_namesize = namesize;
230 nvphdr.nvph_datasize = nvp->nvp_datasize;
231 PJDLOG_ASSERT(*leftp >= sizeof(nvphdr));
232 memcpy(ptr, &nvphdr, sizeof(nvphdr));
233 ptr += sizeof(nvphdr);
234 *leftp -= sizeof(nvphdr);
236 PJDLOG_ASSERT(*leftp >= namesize);
237 memcpy(ptr, nvp->nvp_name, namesize);
245 nvpair_pack_null(const nvpair_t *nvp, unsigned char *ptr,
246 size_t *leftp __unused)
250 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_NULL);
256 nvpair_pack_bool(const nvpair_t *nvp, unsigned char *ptr, size_t *leftp)
261 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_BOOL);
263 value = (uint8_t)nvp->nvp_data;
265 PJDLOG_ASSERT(*leftp >= sizeof(value));
266 memcpy(ptr, &value, sizeof(value));
267 ptr += sizeof(value);
268 *leftp -= sizeof(value);
274 nvpair_pack_number(const nvpair_t *nvp, unsigned char *ptr, size_t *leftp)
279 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_NUMBER);
281 value = (uint64_t)nvp->nvp_data;
283 PJDLOG_ASSERT(*leftp >= sizeof(value));
284 memcpy(ptr, &value, sizeof(value));
285 ptr += sizeof(value);
286 *leftp -= sizeof(value);
292 nvpair_pack_string(const nvpair_t *nvp, unsigned char *ptr, size_t *leftp)
296 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_STRING);
298 PJDLOG_ASSERT(*leftp >= nvp->nvp_datasize);
299 memcpy(ptr, (const void *)(intptr_t)nvp->nvp_data, nvp->nvp_datasize);
300 ptr += nvp->nvp_datasize;
301 *leftp -= nvp->nvp_datasize;
307 nvpair_pack_nvlist_up(unsigned char *ptr, size_t *leftp)
309 struct nvpair_header nvphdr;
311 const char *name = "";
314 nvphdr.nvph_type = NV_TYPE_NVLIST_UP;
315 nvphdr.nvph_namesize = namesize;
316 nvphdr.nvph_datasize = 0;
317 PJDLOG_ASSERT(*leftp >= sizeof(nvphdr));
318 memcpy(ptr, &nvphdr, sizeof(nvphdr));
319 ptr += sizeof(nvphdr);
320 *leftp -= sizeof(nvphdr);
322 PJDLOG_ASSERT(*leftp >= namesize);
323 memcpy(ptr, name, namesize);
331 nvpair_pack_descriptor(const nvpair_t *nvp, unsigned char *ptr, int64_t *fdidxp,
337 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_DESCRIPTOR);
339 value = (int64_t)nvp->nvp_data;
342 * If there is a real descriptor here, we change its number
343 * to position in the array of descriptors send via control
346 PJDLOG_ASSERT(fdidxp != NULL);
352 PJDLOG_ASSERT(*leftp >= sizeof(value));
353 memcpy(ptr, &value, sizeof(value));
354 ptr += sizeof(value);
355 *leftp -= sizeof(value);
361 nvpair_pack_binary(const nvpair_t *nvp, unsigned char *ptr, size_t *leftp)
365 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_BINARY);
367 PJDLOG_ASSERT(*leftp >= nvp->nvp_datasize);
368 memcpy(ptr, (const void *)(intptr_t)nvp->nvp_data, nvp->nvp_datasize);
369 ptr += nvp->nvp_datasize;
370 *leftp -= nvp->nvp_datasize;
376 nvpair_init_datasize(nvpair_t *nvp)
381 if (nvp->nvp_type == NV_TYPE_NVLIST) {
382 if (nvp->nvp_data == 0) {
383 nvp->nvp_datasize = 0;
386 nvlist_size((const nvlist_t *)(intptr_t)nvp->nvp_data);
391 const unsigned char *
392 nvpair_unpack_header(int flags, nvpair_t *nvp, const unsigned char *ptr,
395 struct nvpair_header nvphdr;
397 if (*leftp < sizeof(nvphdr))
400 memcpy(&nvphdr, ptr, sizeof(nvphdr));
401 ptr += sizeof(nvphdr);
402 *leftp -= sizeof(nvphdr);
404 #if NV_TYPE_FIRST > 0
405 if (nvphdr.nvph_type < NV_TYPE_FIRST)
408 if (nvphdr.nvph_type > NV_TYPE_LAST &&
409 nvphdr.nvph_type != NV_TYPE_NVLIST_UP) {
413 #if BYTE_ORDER == BIG_ENDIAN
414 if ((flags & NV_FLAG_BIG_ENDIAN) == 0) {
415 nvphdr.nvph_namesize = le16toh(nvphdr.nvph_namesize);
416 nvphdr.nvph_datasize = le64toh(nvphdr.nvph_datasize);
419 if ((flags & NV_FLAG_BIG_ENDIAN) != 0) {
420 nvphdr.nvph_namesize = be16toh(nvphdr.nvph_namesize);
421 nvphdr.nvph_datasize = be64toh(nvphdr.nvph_datasize);
425 if (nvphdr.nvph_namesize > NV_NAME_MAX)
427 if (*leftp < nvphdr.nvph_namesize)
429 if (nvphdr.nvph_namesize < 1)
431 if (strnlen((const char *)ptr, nvphdr.nvph_namesize) !=
432 (size_t)(nvphdr.nvph_namesize - 1)) {
436 memcpy(nvp->nvp_name, ptr, nvphdr.nvph_namesize);
437 ptr += nvphdr.nvph_namesize;
438 *leftp -= nvphdr.nvph_namesize;
440 if (*leftp < nvphdr.nvph_datasize)
443 nvp->nvp_type = nvphdr.nvph_type;
445 nvp->nvp_datasize = nvphdr.nvph_datasize;
453 const unsigned char *
454 nvpair_unpack_null(int flags __unused, nvpair_t *nvp, const unsigned char *ptr,
455 size_t *leftp __unused)
458 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_NULL);
460 if (nvp->nvp_datasize != 0) {
468 const unsigned char *
469 nvpair_unpack_bool(int flags __unused, nvpair_t *nvp, const unsigned char *ptr,
474 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_BOOL);
476 if (nvp->nvp_datasize != sizeof(value)) {
480 if (*leftp < sizeof(value)) {
485 memcpy(&value, ptr, sizeof(value));
486 ptr += sizeof(value);
487 *leftp -= sizeof(value);
489 if (value != 0 && value != 1) {
494 nvp->nvp_data = (uint64_t)value;
499 const unsigned char *
500 nvpair_unpack_number(int flags, nvpair_t *nvp, const unsigned char *ptr,
504 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_NUMBER);
506 if (nvp->nvp_datasize != sizeof(uint64_t)) {
510 if (*leftp < sizeof(uint64_t)) {
515 if ((flags & NV_FLAG_BIG_ENDIAN) != 0)
516 nvp->nvp_data = be64dec(ptr);
518 nvp->nvp_data = le64dec(ptr);
519 ptr += sizeof(uint64_t);
520 *leftp -= sizeof(uint64_t);
525 const unsigned char *
526 nvpair_unpack_string(int flags __unused, nvpair_t *nvp,
527 const unsigned char *ptr, size_t *leftp)
530 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_STRING);
532 if (*leftp < nvp->nvp_datasize || nvp->nvp_datasize == 0) {
537 if (strnlen((const char *)ptr, nvp->nvp_datasize) !=
538 nvp->nvp_datasize - 1) {
543 nvp->nvp_data = (uint64_t)(uintptr_t)strdup((const char *)ptr);
544 if (nvp->nvp_data == 0)
547 ptr += nvp->nvp_datasize;
548 *leftp -= nvp->nvp_datasize;
553 const unsigned char *
554 nvpair_unpack_nvlist(int *flagsp, nvpair_t *nvp, const unsigned char *ptr,
555 size_t *leftp, size_t nfds, nvlist_t **child)
559 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_NVLIST);
561 if (*leftp < nvp->nvp_datasize || nvp->nvp_datasize == 0) {
566 value = nvlist_create(0);
570 ptr = nvlist_unpack_header(value, ptr, nfds, flagsp, leftp);
574 nvp->nvp_data = (uint64_t)(uintptr_t)value;
580 const unsigned char *
581 nvpair_unpack_descriptor(int flags, nvpair_t *nvp, const unsigned char *ptr,
582 size_t *leftp, const int *fds, size_t nfds)
586 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_DESCRIPTOR);
588 if (nvp->nvp_datasize != sizeof(idx)) {
592 if (*leftp < sizeof(idx)) {
597 if ((flags & NV_FLAG_BIG_ENDIAN) != 0)
607 if ((size_t)idx >= nfds) {
612 nvp->nvp_data = (uint64_t)fds[idx];
615 *leftp -= sizeof(idx);
620 const unsigned char *
621 nvpair_unpack_binary(int flags __unused, nvpair_t *nvp,
622 const unsigned char *ptr, size_t *leftp)
626 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_BINARY);
628 if (*leftp < nvp->nvp_datasize || nvp->nvp_datasize == 0) {
633 value = malloc(nvp->nvp_datasize);
637 memcpy(value, ptr, nvp->nvp_datasize);
638 ptr += nvp->nvp_datasize;
639 *leftp -= nvp->nvp_datasize;
641 nvp->nvp_data = (uint64_t)(uintptr_t)value;
646 const unsigned char *
647 nvpair_unpack(int flags, const unsigned char *ptr, size_t *leftp,
652 nvp = calloc(1, sizeof(*nvp) + NV_NAME_MAX);
655 nvp->nvp_name = (char *)(nvp + 1);
657 ptr = nvpair_unpack_header(flags, nvp, ptr, leftp);
660 tmp = realloc(nvp, sizeof(*nvp) + strlen(nvp->nvp_name) + 1);
665 /* Update nvp_name after realloc(). */
666 nvp->nvp_name = (char *)(nvp + 1);
667 nvp->nvp_data = 0x00;
668 nvp->nvp_magic = NVPAIR_MAGIC;
677 nvpair_type(const nvpair_t *nvp)
682 return (nvp->nvp_type);
686 nvpair_name(const nvpair_t *nvp)
691 return (nvp->nvp_name);
695 nvpair_allocv(int type, uint64_t data, size_t datasize, const char *namefmt,
702 PJDLOG_ASSERT(type >= NV_TYPE_FIRST && type <= NV_TYPE_LAST);
704 namelen = vasprintf(&name, namefmt, nameap);
708 PJDLOG_ASSERT(namelen > 0);
709 if (namelen >= NV_NAME_MAX) {
711 errno = ENAMETOOLONG;
715 nvp = calloc(1, sizeof(*nvp) + namelen + 1);
717 nvp->nvp_name = (char *)(nvp + 1);
718 memcpy(nvp->nvp_name, name, namelen + 1);
719 nvp->nvp_type = type;
720 nvp->nvp_data = data;
721 nvp->nvp_datasize = datasize;
722 nvp->nvp_magic = NVPAIR_MAGIC;
730 nvpair_create_null(const char *name)
733 return (nvpair_createf_null("%s", name));
737 nvpair_create_bool(const char *name, bool value)
740 return (nvpair_createf_bool(value, "%s", name));
744 nvpair_create_number(const char *name, uint64_t value)
747 return (nvpair_createf_number(value, "%s", name));
751 nvpair_create_string(const char *name, const char *value)
754 return (nvpair_createf_string(value, "%s", name));
758 nvpair_create_stringf(const char *name, const char *valuefmt, ...)
763 va_start(valueap, valuefmt);
764 nvp = nvpair_create_stringv(name, valuefmt, valueap);
771 nvpair_create_stringv(const char *name, const char *valuefmt, va_list valueap)
777 len = vasprintf(&str, valuefmt, valueap);
780 nvp = nvpair_create_string(name, str);
787 nvpair_create_nvlist(const char *name, const nvlist_t *value)
790 return (nvpair_createf_nvlist(value, "%s", name));
794 nvpair_create_descriptor(const char *name, int value)
797 return (nvpair_createf_descriptor(value, "%s", name));
801 nvpair_create_binary(const char *name, const void *value, size_t size)
804 return (nvpair_createf_binary(value, size, "%s", name));
808 nvpair_createf_null(const char *namefmt, ...)
813 va_start(nameap, namefmt);
814 nvp = nvpair_createv_null(namefmt, nameap);
821 nvpair_createf_bool(bool value, const char *namefmt, ...)
826 va_start(nameap, namefmt);
827 nvp = nvpair_createv_bool(value, namefmt, nameap);
834 nvpair_createf_number(uint64_t value, const char *namefmt, ...)
839 va_start(nameap, namefmt);
840 nvp = nvpair_createv_number(value, namefmt, nameap);
847 nvpair_createf_string(const char *value, const char *namefmt, ...)
852 va_start(nameap, namefmt);
853 nvp = nvpair_createv_string(value, namefmt, nameap);
860 nvpair_createf_nvlist(const nvlist_t *value, const char *namefmt, ...)
865 va_start(nameap, namefmt);
866 nvp = nvpair_createv_nvlist(value, namefmt, nameap);
873 nvpair_createf_descriptor(int value, const char *namefmt, ...)
878 va_start(nameap, namefmt);
879 nvp = nvpair_createv_descriptor(value, namefmt, nameap);
886 nvpair_createf_binary(const void *value, size_t size, const char *namefmt, ...)
891 va_start(nameap, namefmt);
892 nvp = nvpair_createv_binary(value, size, namefmt, nameap);
899 nvpair_createv_null(const char *namefmt, va_list nameap)
902 return (nvpair_allocv(NV_TYPE_NULL, 0, 0, namefmt, nameap));
906 nvpair_createv_bool(bool value, const char *namefmt, va_list nameap)
909 return (nvpair_allocv(NV_TYPE_BOOL, value ? 1 : 0, sizeof(uint8_t),
914 nvpair_createv_number(uint64_t value, const char *namefmt, va_list nameap)
917 return (nvpair_allocv(NV_TYPE_NUMBER, value, sizeof(value), namefmt,
922 nvpair_createv_string(const char *value, const char *namefmt, va_list nameap)
933 data = strdup(value);
936 size = strlen(value) + 1;
938 nvp = nvpair_allocv(NV_TYPE_STRING, (uint64_t)(uintptr_t)data, size,
947 nvpair_createv_nvlist(const nvlist_t *value, const char *namefmt,
958 nvl = nvlist_clone(value);
962 nvp = nvpair_allocv(NV_TYPE_NVLIST, (uint64_t)(uintptr_t)nvl, 0,
967 nvlist_set_parent(nvl, nvp);
973 nvpair_createv_descriptor(int value, const char *namefmt, va_list nameap)
977 if (value < 0 || !fd_is_valid(value)) {
982 value = fcntl(value, F_DUPFD_CLOEXEC, 0);
986 nvp = nvpair_allocv(NV_TYPE_DESCRIPTOR, (uint64_t)value,
987 sizeof(int64_t), namefmt, nameap);
995 nvpair_createv_binary(const void *value, size_t size, const char *namefmt,
1001 if (value == NULL || size == 0) {
1006 data = malloc(size);
1009 memcpy(data, value, size);
1011 nvp = nvpair_allocv(NV_TYPE_BINARY, (uint64_t)(uintptr_t)data, size,
1020 nvpair_move_string(const char *name, char *value)
1023 return (nvpair_movef_string(value, "%s", name));
1027 nvpair_move_nvlist(const char *name, nvlist_t *value)
1030 return (nvpair_movef_nvlist(value, "%s", name));
1034 nvpair_move_descriptor(const char *name, int value)
1037 return (nvpair_movef_descriptor(value, "%s", name));
1041 nvpair_move_binary(const char *name, void *value, size_t size)
1044 return (nvpair_movef_binary(value, size, "%s", name));
1048 nvpair_movef_string(char *value, const char *namefmt, ...)
1053 va_start(nameap, namefmt);
1054 nvp = nvpair_movev_string(value, namefmt, nameap);
1061 nvpair_movef_nvlist(nvlist_t *value, const char *namefmt, ...)
1066 va_start(nameap, namefmt);
1067 nvp = nvpair_movev_nvlist(value, namefmt, nameap);
1074 nvpair_movef_descriptor(int value, const char *namefmt, ...)
1079 va_start(nameap, namefmt);
1080 nvp = nvpair_movev_descriptor(value, namefmt, nameap);
1087 nvpair_movef_binary(void *value, size_t size, const char *namefmt, ...)
1092 va_start(nameap, namefmt);
1093 nvp = nvpair_movev_binary(value, size, namefmt, nameap);
1100 nvpair_movev_string(char *value, const char *namefmt, va_list nameap)
1104 if (value == NULL) {
1109 nvp = nvpair_allocv(NV_TYPE_STRING, (uint64_t)(uintptr_t)value,
1110 strlen(value) + 1, namefmt, nameap);
1118 nvpair_movev_nvlist(nvlist_t *value, const char *namefmt, va_list nameap)
1122 if (value == NULL || nvlist_get_nvpair_parent(value) != NULL) {
1127 nvp = nvpair_allocv(NV_TYPE_NVLIST, (uint64_t)(uintptr_t)value, 0,
1130 nvlist_destroy(value);
1132 nvlist_set_parent(value, nvp);
1138 nvpair_movev_descriptor(int value, const char *namefmt, va_list nameap)
1141 if (value < 0 || !fd_is_valid(value)) {
1146 return (nvpair_allocv(NV_TYPE_DESCRIPTOR, (uint64_t)value,
1147 sizeof(int64_t), namefmt, nameap));
1151 nvpair_movev_binary(void *value, size_t size, const char *namefmt,
1155 if (value == NULL || size == 0) {
1160 return (nvpair_allocv(NV_TYPE_BINARY, (uint64_t)(uintptr_t)value, size,
1165 nvpair_get_bool(const nvpair_t *nvp)
1170 return (nvp->nvp_data == 1);
1174 nvpair_get_number(const nvpair_t *nvp)
1179 return (nvp->nvp_data);
1183 nvpair_get_string(const nvpair_t *nvp)
1187 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_STRING);
1189 return ((const char *)(intptr_t)nvp->nvp_data);
1193 nvpair_get_nvlist(const nvpair_t *nvp)
1197 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_NVLIST);
1199 return ((const nvlist_t *)(intptr_t)nvp->nvp_data);
1203 nvpair_get_descriptor(const nvpair_t *nvp)
1207 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_DESCRIPTOR);
1209 return ((int)nvp->nvp_data);
1213 nvpair_get_binary(const nvpair_t *nvp, size_t *sizep)
1217 PJDLOG_ASSERT(nvp->nvp_type == NV_TYPE_BINARY);
1220 *sizep = nvp->nvp_datasize;
1221 return ((const void *)(intptr_t)nvp->nvp_data);
1225 nvpair_free(nvpair_t *nvp)
1229 PJDLOG_ASSERT(nvp->nvp_list == NULL);
1232 switch (nvp->nvp_type) {
1233 case NV_TYPE_DESCRIPTOR:
1234 close((int)nvp->nvp_data);
1236 case NV_TYPE_NVLIST:
1237 nvlist_destroy((nvlist_t *)(intptr_t)nvp->nvp_data);
1239 case NV_TYPE_STRING:
1240 free((char *)(intptr_t)nvp->nvp_data);
1242 case NV_TYPE_BINARY:
1243 free((void *)(intptr_t)nvp->nvp_data);
1250 nvpair_free_structure(nvpair_t *nvp)
1254 PJDLOG_ASSERT(nvp->nvp_list == NULL);
1261 nvpair_type_string(int type)
1269 case NV_TYPE_NUMBER:
1271 case NV_TYPE_STRING:
1273 case NV_TYPE_NVLIST:
1275 case NV_TYPE_DESCRIPTOR:
1276 return ("DESCRIPTOR");
1277 case NV_TYPE_BINARY:
1280 return ("<UNKNOWN>");