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.
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.
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]
23 * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
24 * Use is subject to license terms.
30 #pragma ident "%Z%%M% %I% %E% SMI"
32 #include <sys/types.h>
40 * Each logical domain is detailed via a (Virtual) Machine Description
41 * available to each guest Operating System courtesy of a
53 #define U8(_s) ((uint8_t)(_s))
54 #define U16(_s) ((uint16_t)(_s))
55 #define U32(_s) ((uint32_t)(_s))
56 #define U64(_s) ((uint64_t)(_s))
63 /* the version this library understands */
65 #define MD_HEADER_VERS_OFF 0x0
66 #define MD_HEADER_NODE_OFF 0x4
67 #define MD_HEADER_NAME_OFF 0x8
68 #define MD_HEADER_DATA_OFF 0xc
70 #define MD_HEADER_SIZE 0x10
72 #define MD_TRANSPORT_VERSION U32(0x10000)
74 #define MD_ELEMENT_SIZE 0x10
76 #define MDE_ILLEGAL_IDX U64(-1)
78 #define MDET_LIST_END U8(0x0)
79 #define MDET_NULL U8(' ')
80 #define MDET_NODE U8('N')
81 #define MDET_NODE_END U8('E')
82 #define MDET_PROP_ARC U8('a')
83 #define MDET_PROP_VAL U8('v')
84 #define MDET_PROP_STR U8('s')
85 #define MDET_PROP_DAT U8('d')
91 * Opaque handles for use in external interfaces
96 typedef uint64_t mde_cookie_t
;
97 #define MDE_INVAL_ELEM_COOKIE ((mde_cookie_t)-1)
99 typedef uint32_t mde_str_cookie_t
;
100 #define MDE_INVAL_STR_COOKIE ((mde_str_cookie_t)-1)
102 typedef uint64_t md_diff_cookie_t
;
103 #define MD_INVAL_DIFF_COOKIE ((md_diff_cookie_t)-1)
105 #define MDESC_INVAL_GEN (0)
108 * External structure for MD diff interface
111 uint8_t type
; /* property type */
112 char *namep
; /* property name */
117 * Walk callback function return codes
119 #define MDE_WALK_ERROR -1 /* Terminate walk with error */
120 #define MDE_WALK_NEXT 0 /* Continue to next node */
121 #define MDE_WALK_DONE 1 /* Terminate walk with success */
124 * The function prototype for a walker callback function.
125 * The machine description session, parent node, current node,
126 * and private data are given to the callback.
128 * The parent node is given to the callback to provide context
129 * on how the walker arrived at this location. While the node
130 * may have many parents, it will be visited only once, this
131 * provides context on how the walker arrived at the node.
134 * ------------------- ----------------------------------------
135 * md_t * Pointer to md session
136 * mde_cookie_t Index of parent node to provide context
137 * mde_cookie_t The current node in the walk
138 * void * Private data for the walking function
140 typedef int md_walk_fn_t(md_t
*, mde_cookie_t
, mde_cookie_t
, void *);
147 extern md_t
*md_init_intern(uint64_t *,
148 void *(*allocp
)(size_t),
149 void (*freep
)(void *, size_t));
151 extern int md_fini(md_t
*);
153 extern int md_node_count(md_t
*);
155 extern mde_str_cookie_t
md_find_name(md_t
*, char *namep
);
157 extern mde_cookie_t
md_root_node(md_t
*);
159 extern uint64_t md_get_gen(md_t
*);
161 extern size_t md_get_bin_size(md_t
*);
163 extern int md_scan_dag(md_t
*,
169 extern int md_walk_dag(md_t
*,
176 extern int md_get_prop_val(md_t
*,
181 extern int md_get_prop_str(md_t
*,
186 extern int md_get_prop_data(md_t
*,
192 extern int md_get_prop_arcs(md_t
*,
199 extern md_diff_cookie_t
md_diff_init(md_t
*,
206 extern int md_diff_added(md_diff_cookie_t
,
209 extern int md_diff_removed(md_diff_cookie_t
,
212 extern int md_diff_matched(md_diff_cookie_t
,
216 extern int md_diff_fini(md_diff_cookie_t
);
224 * ioctl info for mdesc device
227 #define MDESCIOC ('m' << 24 | 'd' << 16 | 'd' << 8)
229 #define MDESCIOCGSZ (MDESCIOC | 1) /* Get quote buffer size */
230 #define MDESCIOCSSZ (MDESCIOC | 2) /* Set new quote buffer size */
231 #define MDESCIOCDISCARD (MDESCIOC | 3) /* Discard quotes and reset */
237 #endif /* _MDESC_H_ */