]> git.proxmox.com Git - mirror_zfs-debian.git/blob - module/nvpair/fnvpair.c
Imported Upstream version 0.6.2
[mirror_zfs-debian.git] / module / nvpair / fnvpair.c
1 /*
2 * CDDL HEADER START
3 *
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
7 *
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21
22 /*
23 * Copyright (c) 2012 by Delphix. All rights reserved.
24 */
25
26 #include <sys/nvpair.h>
27 #include <sys/kmem.h>
28 #include <sys/debug.h>
29 #ifndef _KERNEL
30 #include <stdlib.h>
31 #endif
32
33 /*
34 * "Force" nvlist wrapper.
35 *
36 * These functions wrap the nvlist_* functions with assertions that assume
37 * the operation is successful. This allows the caller's code to be much
38 * more readable, especially for the fnvlist_lookup_* and fnvpair_value_*
39 * functions, which can return the requested value (rather than filling in
40 * a pointer).
41 *
42 * These functions use NV_UNIQUE_NAME, encoding NV_ENCODE_NATIVE, and allocate
43 * with KM_SLEEP.
44 *
45 * More wrappers should be added as needed -- for example
46 * nvlist_lookup_*_array and nvpair_value_*_array.
47 */
48
49 nvlist_t *
50 fnvlist_alloc(void)
51 {
52 nvlist_t *nvl;
53 VERIFY0(nvlist_alloc(&nvl, NV_UNIQUE_NAME, KM_SLEEP));
54 return (nvl);
55 }
56
57 void
58 fnvlist_free(nvlist_t *nvl)
59 {
60 nvlist_free(nvl);
61 }
62
63 size_t
64 fnvlist_size(nvlist_t *nvl)
65 {
66 size_t size;
67 VERIFY0(nvlist_size(nvl, &size, NV_ENCODE_NATIVE));
68 return (size);
69 }
70
71 /*
72 * Returns allocated buffer of size *sizep. Caller must free the buffer with
73 * fnvlist_pack_free().
74 */
75 char *
76 fnvlist_pack(nvlist_t *nvl, size_t *sizep)
77 {
78 char *packed = 0;
79 VERIFY3U(nvlist_pack(nvl, &packed, sizep, NV_ENCODE_NATIVE,
80 KM_SLEEP), ==, 0);
81 return (packed);
82 }
83
84 /*ARGSUSED*/
85 void
86 fnvlist_pack_free(char *pack, size_t size)
87 {
88 #ifdef _KERNEL
89 kmem_free(pack, size);
90 #else
91 free(pack);
92 #endif
93 }
94
95 nvlist_t *
96 fnvlist_unpack(char *buf, size_t buflen)
97 {
98 nvlist_t *rv;
99 VERIFY0(nvlist_unpack(buf, buflen, &rv, KM_SLEEP));
100 return (rv);
101 }
102
103 nvlist_t *
104 fnvlist_dup(nvlist_t *nvl)
105 {
106 nvlist_t *rv;
107 VERIFY0(nvlist_dup(nvl, &rv, KM_SLEEP));
108 return (rv);
109 }
110
111 void
112 fnvlist_merge(nvlist_t *dst, nvlist_t *src)
113 {
114 VERIFY0(nvlist_merge(dst, src, KM_SLEEP));
115 }
116
117 void
118 fnvlist_add_boolean(nvlist_t *nvl, const char *name)
119 {
120 VERIFY0(nvlist_add_boolean(nvl, name));
121 }
122
123 void
124 fnvlist_add_boolean_value(nvlist_t *nvl, const char *name, boolean_t val)
125 {
126 VERIFY0(nvlist_add_boolean_value(nvl, name, val));
127 }
128
129 void
130 fnvlist_add_byte(nvlist_t *nvl, const char *name, uchar_t val)
131 {
132 VERIFY0(nvlist_add_byte(nvl, name, val));
133 }
134
135 void
136 fnvlist_add_int8(nvlist_t *nvl, const char *name, int8_t val)
137 {
138 VERIFY0(nvlist_add_int8(nvl, name, val));
139 }
140
141 void
142 fnvlist_add_uint8(nvlist_t *nvl, const char *name, uint8_t val)
143 {
144 VERIFY0(nvlist_add_uint8(nvl, name, val));
145 }
146
147 void
148 fnvlist_add_int16(nvlist_t *nvl, const char *name, int16_t val)
149 {
150 VERIFY0(nvlist_add_int16(nvl, name, val));
151 }
152
153 void
154 fnvlist_add_uint16(nvlist_t *nvl, const char *name, uint16_t val)
155 {
156 VERIFY0(nvlist_add_uint16(nvl, name, val));
157 }
158
159 void
160 fnvlist_add_int32(nvlist_t *nvl, const char *name, int32_t val)
161 {
162 VERIFY0(nvlist_add_int32(nvl, name, val));
163 }
164
165 void
166 fnvlist_add_uint32(nvlist_t *nvl, const char *name, uint32_t val)
167 {
168 VERIFY0(nvlist_add_uint32(nvl, name, val));
169 }
170
171 void
172 fnvlist_add_int64(nvlist_t *nvl, const char *name, int64_t val)
173 {
174 VERIFY0(nvlist_add_int64(nvl, name, val));
175 }
176
177 void
178 fnvlist_add_uint64(nvlist_t *nvl, const char *name, uint64_t val)
179 {
180 VERIFY0(nvlist_add_uint64(nvl, name, val));
181 }
182
183 void
184 fnvlist_add_string(nvlist_t *nvl, const char *name, const char *val)
185 {
186 VERIFY0(nvlist_add_string(nvl, name, val));
187 }
188
189 void
190 fnvlist_add_nvlist(nvlist_t *nvl, const char *name, nvlist_t *val)
191 {
192 VERIFY0(nvlist_add_nvlist(nvl, name, val));
193 }
194
195 void
196 fnvlist_add_nvpair(nvlist_t *nvl, nvpair_t *pair)
197 {
198 VERIFY0(nvlist_add_nvpair(nvl, pair));
199 }
200
201 void
202 fnvlist_add_boolean_array(nvlist_t *nvl, const char *name,
203 boolean_t *val, uint_t n)
204 {
205 VERIFY0(nvlist_add_boolean_array(nvl, name, val, n));
206 }
207
208 void
209 fnvlist_add_byte_array(nvlist_t *nvl, const char *name, uchar_t *val, uint_t n)
210 {
211 VERIFY0(nvlist_add_byte_array(nvl, name, val, n));
212 }
213
214 void
215 fnvlist_add_int8_array(nvlist_t *nvl, const char *name, int8_t *val, uint_t n)
216 {
217 VERIFY0(nvlist_add_int8_array(nvl, name, val, n));
218 }
219
220 void
221 fnvlist_add_uint8_array(nvlist_t *nvl, const char *name, uint8_t *val, uint_t n)
222 {
223 VERIFY0(nvlist_add_uint8_array(nvl, name, val, n));
224 }
225
226 void
227 fnvlist_add_int16_array(nvlist_t *nvl, const char *name, int16_t *val, uint_t n)
228 {
229 VERIFY0(nvlist_add_int16_array(nvl, name, val, n));
230 }
231
232 void
233 fnvlist_add_uint16_array(nvlist_t *nvl, const char *name,
234 uint16_t *val, uint_t n)
235 {
236 VERIFY0(nvlist_add_uint16_array(nvl, name, val, n));
237 }
238
239 void
240 fnvlist_add_int32_array(nvlist_t *nvl, const char *name, int32_t *val, uint_t n)
241 {
242 VERIFY0(nvlist_add_int32_array(nvl, name, val, n));
243 }
244
245 void
246 fnvlist_add_uint32_array(nvlist_t *nvl, const char *name,
247 uint32_t *val, uint_t n)
248 {
249 VERIFY0(nvlist_add_uint32_array(nvl, name, val, n));
250 }
251
252 void
253 fnvlist_add_int64_array(nvlist_t *nvl, const char *name, int64_t *val, uint_t n)
254 {
255 VERIFY0(nvlist_add_int64_array(nvl, name, val, n));
256 }
257
258 void
259 fnvlist_add_uint64_array(nvlist_t *nvl, const char *name,
260 uint64_t *val, uint_t n)
261 {
262 VERIFY0(nvlist_add_uint64_array(nvl, name, val, n));
263 }
264
265 void
266 fnvlist_add_string_array(nvlist_t *nvl, const char *name,
267 char * const *val, uint_t n)
268 {
269 VERIFY0(nvlist_add_string_array(nvl, name, val, n));
270 }
271
272 void
273 fnvlist_add_nvlist_array(nvlist_t *nvl, const char *name,
274 nvlist_t **val, uint_t n)
275 {
276 VERIFY0(nvlist_add_nvlist_array(nvl, name, val, n));
277 }
278
279 void
280 fnvlist_remove(nvlist_t *nvl, const char *name)
281 {
282 VERIFY0(nvlist_remove_all(nvl, name));
283 }
284
285 void
286 fnvlist_remove_nvpair(nvlist_t *nvl, nvpair_t *pair)
287 {
288 VERIFY0(nvlist_remove_nvpair(nvl, pair));
289 }
290
291 nvpair_t *
292 fnvlist_lookup_nvpair(nvlist_t *nvl, const char *name)
293 {
294 nvpair_t *rv;
295 VERIFY0(nvlist_lookup_nvpair(nvl, name, &rv));
296 return (rv);
297 }
298
299 /* returns B_TRUE if the entry exists */
300 boolean_t
301 fnvlist_lookup_boolean(nvlist_t *nvl, const char *name)
302 {
303 return (nvlist_lookup_boolean(nvl, name) == 0);
304 }
305
306 boolean_t
307 fnvlist_lookup_boolean_value(nvlist_t *nvl, const char *name)
308 {
309 boolean_t rv;
310 VERIFY0(nvlist_lookup_boolean_value(nvl, name, &rv));
311 return (rv);
312 }
313
314 uchar_t
315 fnvlist_lookup_byte(nvlist_t *nvl, const char *name)
316 {
317 uchar_t rv;
318 VERIFY0(nvlist_lookup_byte(nvl, name, &rv));
319 return (rv);
320 }
321
322 int8_t
323 fnvlist_lookup_int8(nvlist_t *nvl, const char *name)
324 {
325 int8_t rv;
326 VERIFY0(nvlist_lookup_int8(nvl, name, &rv));
327 return (rv);
328 }
329
330 int16_t
331 fnvlist_lookup_int16(nvlist_t *nvl, const char *name)
332 {
333 int16_t rv;
334 VERIFY0(nvlist_lookup_int16(nvl, name, &rv));
335 return (rv);
336 }
337
338 int32_t
339 fnvlist_lookup_int32(nvlist_t *nvl, const char *name)
340 {
341 int32_t rv;
342 VERIFY0(nvlist_lookup_int32(nvl, name, &rv));
343 return (rv);
344 }
345
346 int64_t
347 fnvlist_lookup_int64(nvlist_t *nvl, const char *name)
348 {
349 int64_t rv;
350 VERIFY0(nvlist_lookup_int64(nvl, name, &rv));
351 return (rv);
352 }
353
354 uint8_t
355 fnvlist_lookup_uint8(nvlist_t *nvl, const char *name)
356 {
357 uint8_t rv;
358 VERIFY0(nvlist_lookup_uint8(nvl, name, &rv));
359 return (rv);
360 }
361
362 uint16_t
363 fnvlist_lookup_uint16(nvlist_t *nvl, const char *name)
364 {
365 uint16_t rv;
366 VERIFY0(nvlist_lookup_uint16(nvl, name, &rv));
367 return (rv);
368 }
369
370 uint32_t
371 fnvlist_lookup_uint32(nvlist_t *nvl, const char *name)
372 {
373 uint32_t rv;
374 VERIFY0(nvlist_lookup_uint32(nvl, name, &rv));
375 return (rv);
376 }
377
378 uint64_t
379 fnvlist_lookup_uint64(nvlist_t *nvl, const char *name)
380 {
381 uint64_t rv;
382 VERIFY0(nvlist_lookup_uint64(nvl, name, &rv));
383 return (rv);
384 }
385
386 char *
387 fnvlist_lookup_string(nvlist_t *nvl, const char *name)
388 {
389 char *rv;
390 VERIFY0(nvlist_lookup_string(nvl, name, &rv));
391 return (rv);
392 }
393
394 nvlist_t *
395 fnvlist_lookup_nvlist(nvlist_t *nvl, const char *name)
396 {
397 nvlist_t *rv;
398 VERIFY0(nvlist_lookup_nvlist(nvl, name, &rv));
399 return (rv);
400 }
401
402 boolean_t
403 fnvpair_value_boolean_value(nvpair_t *nvp)
404 {
405 boolean_t rv;
406 VERIFY0(nvpair_value_boolean_value(nvp, &rv));
407 return (rv);
408 }
409
410 uchar_t
411 fnvpair_value_byte(nvpair_t *nvp)
412 {
413 uchar_t rv;
414 VERIFY0(nvpair_value_byte(nvp, &rv));
415 return (rv);
416 }
417
418 int8_t
419 fnvpair_value_int8(nvpair_t *nvp)
420 {
421 int8_t rv;
422 VERIFY0(nvpair_value_int8(nvp, &rv));
423 return (rv);
424 }
425
426 int16_t
427 fnvpair_value_int16(nvpair_t *nvp)
428 {
429 int16_t rv;
430 VERIFY0(nvpair_value_int16(nvp, &rv));
431 return (rv);
432 }
433
434 int32_t
435 fnvpair_value_int32(nvpair_t *nvp)
436 {
437 int32_t rv;
438 VERIFY0(nvpair_value_int32(nvp, &rv));
439 return (rv);
440 }
441
442 int64_t
443 fnvpair_value_int64(nvpair_t *nvp)
444 {
445 int64_t rv;
446 VERIFY0(nvpair_value_int64(nvp, &rv));
447 return (rv);
448 }
449
450 uint8_t
451 fnvpair_value_uint8(nvpair_t *nvp)
452 {
453 uint8_t rv;
454 VERIFY0(nvpair_value_uint8(nvp, &rv));
455 return (rv);
456 }
457
458 uint16_t
459 fnvpair_value_uint16(nvpair_t *nvp)
460 {
461 uint16_t rv;
462 VERIFY0(nvpair_value_uint16(nvp, &rv));
463 return (rv);
464 }
465
466 uint32_t
467 fnvpair_value_uint32(nvpair_t *nvp)
468 {
469 uint32_t rv;
470 VERIFY0(nvpair_value_uint32(nvp, &rv));
471 return (rv);
472 }
473
474 uint64_t
475 fnvpair_value_uint64(nvpair_t *nvp)
476 {
477 uint64_t rv;
478 VERIFY0(nvpair_value_uint64(nvp, &rv));
479 return (rv);
480 }
481
482 char *
483 fnvpair_value_string(nvpair_t *nvp)
484 {
485 char *rv;
486 VERIFY0(nvpair_value_string(nvp, &rv));
487 return (rv);
488 }
489
490 nvlist_t *
491 fnvpair_value_nvlist(nvpair_t *nvp)
492 {
493 nvlist_t *rv;
494 VERIFY0(nvpair_value_nvlist(nvp, &rv));
495 return (rv);
496 }
497
498 #if defined(_KERNEL) && defined(HAVE_SPL)
499
500 EXPORT_SYMBOL(fnvlist_alloc);
501 EXPORT_SYMBOL(fnvlist_free);
502 EXPORT_SYMBOL(fnvlist_size);
503 EXPORT_SYMBOL(fnvlist_pack);
504 EXPORT_SYMBOL(fnvlist_unpack);
505 EXPORT_SYMBOL(fnvlist_dup);
506 EXPORT_SYMBOL(fnvlist_merge);
507
508 EXPORT_SYMBOL(fnvlist_add_nvpair);
509 EXPORT_SYMBOL(fnvlist_add_boolean);
510 EXPORT_SYMBOL(fnvlist_add_boolean_value);
511 EXPORT_SYMBOL(fnvlist_add_byte);
512 EXPORT_SYMBOL(fnvlist_add_int8);
513 EXPORT_SYMBOL(fnvlist_add_uint8);
514 EXPORT_SYMBOL(fnvlist_add_int16);
515 EXPORT_SYMBOL(fnvlist_add_uint16);
516 EXPORT_SYMBOL(fnvlist_add_int32);
517 EXPORT_SYMBOL(fnvlist_add_uint32);
518 EXPORT_SYMBOL(fnvlist_add_int64);
519 EXPORT_SYMBOL(fnvlist_add_uint64);
520 EXPORT_SYMBOL(fnvlist_add_string);
521 EXPORT_SYMBOL(fnvlist_add_nvlist);
522 EXPORT_SYMBOL(fnvlist_add_boolean_array);
523 EXPORT_SYMBOL(fnvlist_add_byte_array);
524 EXPORT_SYMBOL(fnvlist_add_int8_array);
525 EXPORT_SYMBOL(fnvlist_add_uint8_array);
526 EXPORT_SYMBOL(fnvlist_add_int16_array);
527 EXPORT_SYMBOL(fnvlist_add_uint16_array);
528 EXPORT_SYMBOL(fnvlist_add_int32_array);
529 EXPORT_SYMBOL(fnvlist_add_uint32_array);
530 EXPORT_SYMBOL(fnvlist_add_int64_array);
531 EXPORT_SYMBOL(fnvlist_add_uint64_array);
532 EXPORT_SYMBOL(fnvlist_add_string_array);
533 EXPORT_SYMBOL(fnvlist_add_nvlist_array);
534
535 EXPORT_SYMBOL(fnvlist_remove);
536 EXPORT_SYMBOL(fnvlist_remove_nvpair);
537
538 EXPORT_SYMBOL(fnvlist_lookup_nvpair);
539 EXPORT_SYMBOL(fnvlist_lookup_boolean);
540 EXPORT_SYMBOL(fnvlist_lookup_boolean_value);
541 EXPORT_SYMBOL(fnvlist_lookup_byte);
542 EXPORT_SYMBOL(fnvlist_lookup_int8);
543 EXPORT_SYMBOL(fnvlist_lookup_uint8);
544 EXPORT_SYMBOL(fnvlist_lookup_int16);
545 EXPORT_SYMBOL(fnvlist_lookup_uint16);
546 EXPORT_SYMBOL(fnvlist_lookup_int32);
547 EXPORT_SYMBOL(fnvlist_lookup_uint32);
548 EXPORT_SYMBOL(fnvlist_lookup_int64);
549 EXPORT_SYMBOL(fnvlist_lookup_uint64);
550 EXPORT_SYMBOL(fnvlist_lookup_string);
551 EXPORT_SYMBOL(fnvlist_lookup_nvlist);
552
553 EXPORT_SYMBOL(fnvpair_value_boolean_value);
554 EXPORT_SYMBOL(fnvpair_value_byte);
555 EXPORT_SYMBOL(fnvpair_value_int8);
556 EXPORT_SYMBOL(fnvpair_value_uint8);
557 EXPORT_SYMBOL(fnvpair_value_int16);
558 EXPORT_SYMBOL(fnvpair_value_uint16);
559 EXPORT_SYMBOL(fnvpair_value_int32);
560 EXPORT_SYMBOL(fnvpair_value_uint32);
561 EXPORT_SYMBOL(fnvpair_value_int64);
562 EXPORT_SYMBOL(fnvpair_value_uint64);
563 EXPORT_SYMBOL(fnvpair_value_string);
564 EXPORT_SYMBOL(fnvpair_value_nvlist);
565
566 #endif