16683 pthread_cond_timedwait broken when using static initializer
[illumos-gate.git] / usr / src / uts / common / sys / mdesc.h
blob1884a91947b1b8f9ccbb0c9cc335ca4661e4a6e6
1 /*
2 * CDDL HEADER START
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]
19 * CDDL HEADER END
23 * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
24 * Use is subject to license terms.
27 #ifndef _MDESC_H_
28 #define _MDESC_H_
30 #include <sys/types.h>
32 #ifdef __cplusplus
33 extern "C" {
34 #endif
38 * Each logical domain is detailed via a (Virtual) Machine Description
39 * available to each guest Operating System courtesy of a
40 * Hypervisor service.
45 #ifdef _ASM
46 #define U8(_s) _s
47 #define U16(_s) _s
48 #define U32(_s) _s
49 #define U64(_s) _s
50 #else
51 #define U8(_s) ((uint8_t)(_s))
52 #define U16(_s) ((uint16_t)(_s))
53 #define U32(_s) ((uint32_t)(_s))
54 #define U64(_s) ((uint64_t)(_s))
55 #endif
61 /* the version this library understands */
63 #define MD_HEADER_VERS_OFF 0x0
64 #define MD_HEADER_NODE_OFF 0x4
65 #define MD_HEADER_NAME_OFF 0x8
66 #define MD_HEADER_DATA_OFF 0xc
68 #define MD_HEADER_SIZE 0x10
70 #define MD_TRANSPORT_VERSION U32(0x10000)
72 #define MD_ELEMENT_SIZE 0x10
74 #define MDE_ILLEGAL_IDX U64(-1)
76 #define MDET_LIST_END U8(0x0)
77 #define MDET_NULL U8(' ')
78 #define MDET_NODE U8('N')
79 #define MDET_NODE_END U8('E')
80 #define MDET_PROP_ARC U8('a')
81 #define MDET_PROP_VAL U8('v')
82 #define MDET_PROP_STR U8('s')
83 #define MDET_PROP_DAT U8('d')
86 #ifndef _ASM /* { */
89 * Opaque handles for use in external interfaces
92 typedef void *md_t;
94 typedef uint64_t mde_cookie_t;
95 #define MDE_INVAL_ELEM_COOKIE ((mde_cookie_t)-1)
97 typedef uint32_t mde_str_cookie_t;
98 #define MDE_INVAL_STR_COOKIE ((mde_str_cookie_t)-1)
100 typedef uint64_t md_diff_cookie_t;
101 #define MD_INVAL_DIFF_COOKIE ((md_diff_cookie_t)-1)
103 #define MDESC_INVAL_GEN (0)
106 * External structure for MD diff interface
108 typedef struct {
109 uint8_t type; /* property type */
110 char *namep; /* property name */
111 } md_prop_match_t;
115 * Walk callback function return codes
117 #define MDE_WALK_ERROR -1 /* Terminate walk with error */
118 #define MDE_WALK_NEXT 0 /* Continue to next node */
119 #define MDE_WALK_DONE 1 /* Terminate walk with success */
122 * The function prototype for a walker callback function.
123 * The machine description session, parent node, current node,
124 * and private data are given to the callback.
126 * The parent node is given to the callback to provide context
127 * on how the walker arrived at this location. While the node
128 * may have many parents, it will be visited only once, this
129 * provides context on how the walker arrived at the node.
131 * Input Description
132 * ------------------- ----------------------------------------
133 * md_t * Pointer to md session
134 * mde_cookie_t Index of parent node to provide context
135 * mde_cookie_t The current node in the walk
136 * void * Private data for the walking function
138 typedef int md_walk_fn_t(md_t *, mde_cookie_t, mde_cookie_t, void *);
142 * External Interface
145 extern md_t *md_init_intern(uint64_t *,
146 void *(*allocp)(size_t),
147 void (*freep)(void *, size_t));
149 extern int md_fini(md_t *);
151 extern int md_node_count(md_t *);
153 extern mde_str_cookie_t md_find_name(md_t *, char *namep);
155 extern mde_cookie_t md_root_node(md_t *);
157 extern uint64_t md_get_gen(md_t *);
159 extern size_t md_get_bin_size(md_t *);
161 extern int md_scan_dag(md_t *,
162 mde_cookie_t,
163 mde_str_cookie_t,
164 mde_str_cookie_t,
165 mde_cookie_t *);
167 extern int md_walk_dag(md_t *,
168 mde_cookie_t,
169 mde_str_cookie_t,
170 mde_str_cookie_t,
171 md_walk_fn_t,
172 void *);
174 extern int md_get_prop_val(md_t *,
175 mde_cookie_t,
176 char *,
177 uint64_t *);
179 extern int md_get_prop_str(md_t *,
180 mde_cookie_t,
181 char *,
182 char **);
184 extern int md_get_prop_data(md_t *,
185 mde_cookie_t,
186 char *,
187 uint8_t **,
188 int *);
190 extern int md_get_prop_arcs(md_t *,
191 mde_cookie_t,
192 char *,
193 mde_cookie_t *,
194 size_t);
197 extern md_diff_cookie_t md_diff_init(md_t *,
198 mde_cookie_t,
199 md_t *,
200 mde_cookie_t,
201 char *,
202 md_prop_match_t *);
204 extern int md_diff_added(md_diff_cookie_t,
205 mde_cookie_t **);
207 extern int md_diff_removed(md_diff_cookie_t,
208 mde_cookie_t **);
210 extern int md_diff_matched(md_diff_cookie_t,
211 mde_cookie_t **,
212 mde_cookie_t **);
214 extern int md_diff_fini(md_diff_cookie_t);
217 #endif /* } _ASM */
222 * ioctl info for mdesc device
225 #define MDESCIOC ('m' << 24 | 'd' << 16 | 'd' << 8)
227 #define MDESCIOCGSZ (MDESCIOC | 1) /* Get quote buffer size */
228 #define MDESCIOCSSZ (MDESCIOC | 2) /* Set new quote buffer size */
229 #define MDESCIOCDISCARD (MDESCIOC | 3) /* Discard quotes and reset */
231 #ifdef __cplusplus
233 #endif
235 #endif /* _MDESC_H_ */