xref: /titanic_51/usr/src/uts/common/sys/mdesc.h (revision 908f1e1388f616898b4e515d343c0414f2a6472e)
17c478bd9Sstevel@tonic-gate /*
27c478bd9Sstevel@tonic-gate  * CDDL HEADER START
37c478bd9Sstevel@tonic-gate  *
47c478bd9Sstevel@tonic-gate  * The contents of this file are subject to the terms of the
51ae08745Sheppo  * Common Development and Distribution License (the "License").
61ae08745Sheppo  * You may not use this file except in compliance with the License.
77c478bd9Sstevel@tonic-gate  *
87c478bd9Sstevel@tonic-gate  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
97c478bd9Sstevel@tonic-gate  * or http://www.opensolaris.org/os/licensing.
107c478bd9Sstevel@tonic-gate  * See the License for the specific language governing permissions
117c478bd9Sstevel@tonic-gate  * and limitations under the License.
127c478bd9Sstevel@tonic-gate  *
137c478bd9Sstevel@tonic-gate  * When distributing Covered Code, include this CDDL HEADER in each
147c478bd9Sstevel@tonic-gate  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
157c478bd9Sstevel@tonic-gate  * If applicable, add the following below this CDDL HEADER, with the
167c478bd9Sstevel@tonic-gate  * fields enclosed by brackets "[]" replaced with your own identifying
177c478bd9Sstevel@tonic-gate  * information: Portions Copyright [yyyy] [name of copyright owner]
187c478bd9Sstevel@tonic-gate  *
197c478bd9Sstevel@tonic-gate  * CDDL HEADER END
207c478bd9Sstevel@tonic-gate  */
211ae08745Sheppo 
227c478bd9Sstevel@tonic-gate /*
23*908f1e13Ssd77468  * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
247c478bd9Sstevel@tonic-gate  * Use is subject to license terms.
257c478bd9Sstevel@tonic-gate  */
267c478bd9Sstevel@tonic-gate 
277c478bd9Sstevel@tonic-gate #ifndef	_MDESC_H_
287c478bd9Sstevel@tonic-gate #define	_MDESC_H_
297c478bd9Sstevel@tonic-gate 
307c478bd9Sstevel@tonic-gate #pragma ident	"%Z%%M%	%I%	%E% SMI"
317c478bd9Sstevel@tonic-gate 
326dfee483Stsien #include <sys/types.h>
336dfee483Stsien 
347c478bd9Sstevel@tonic-gate #ifdef __cplusplus
357c478bd9Sstevel@tonic-gate extern "C" {
367c478bd9Sstevel@tonic-gate #endif
377c478bd9Sstevel@tonic-gate 
387c478bd9Sstevel@tonic-gate 
397c478bd9Sstevel@tonic-gate /*
407c478bd9Sstevel@tonic-gate  * Each logical domain is detailed via a (Virtual) Machine Description
417c478bd9Sstevel@tonic-gate  * available to each guest Operating System courtesy of a
427c478bd9Sstevel@tonic-gate  * Hypervisor service.
437c478bd9Sstevel@tonic-gate  */
447c478bd9Sstevel@tonic-gate 
457c478bd9Sstevel@tonic-gate 
467c478bd9Sstevel@tonic-gate 
477c478bd9Sstevel@tonic-gate #ifdef	_ASM
487c478bd9Sstevel@tonic-gate #define	U8(_s)	_s
497c478bd9Sstevel@tonic-gate #define	U16(_s)	_s
507c478bd9Sstevel@tonic-gate #define	U32(_s)	_s
517c478bd9Sstevel@tonic-gate #define	U64(_s)	_s
527c478bd9Sstevel@tonic-gate #else
537c478bd9Sstevel@tonic-gate #define	U8(_s)	((uint8_t)(_s))
547c478bd9Sstevel@tonic-gate #define	U16(_s)	((uint16_t)(_s))
557c478bd9Sstevel@tonic-gate #define	U32(_s)	((uint32_t)(_s))
567c478bd9Sstevel@tonic-gate #define	U64(_s)	((uint64_t)(_s))
577c478bd9Sstevel@tonic-gate #endif
587c478bd9Sstevel@tonic-gate 
597c478bd9Sstevel@tonic-gate 
607c478bd9Sstevel@tonic-gate 
617c478bd9Sstevel@tonic-gate 
627c478bd9Sstevel@tonic-gate 
637c478bd9Sstevel@tonic-gate 	/* the version this library understands */
647c478bd9Sstevel@tonic-gate 
657c478bd9Sstevel@tonic-gate #define	MD_HEADER_VERS_OFF	0x0
667c478bd9Sstevel@tonic-gate #define	MD_HEADER_NODE_OFF	0x4
677c478bd9Sstevel@tonic-gate #define	MD_HEADER_NAME_OFF	0x8
687c478bd9Sstevel@tonic-gate #define	MD_HEADER_DATA_OFF	0xc
697c478bd9Sstevel@tonic-gate 
707c478bd9Sstevel@tonic-gate #define	MD_HEADER_SIZE	0x10
717c478bd9Sstevel@tonic-gate 
727c478bd9Sstevel@tonic-gate #define	MD_TRANSPORT_VERSION	U32(0x10000)
737c478bd9Sstevel@tonic-gate 
747c478bd9Sstevel@tonic-gate #define	MD_ELEMENT_SIZE	0x10
757c478bd9Sstevel@tonic-gate 
767c478bd9Sstevel@tonic-gate #define	MDE_ILLEGAL_IDX		U64(-1)
777c478bd9Sstevel@tonic-gate 
787c478bd9Sstevel@tonic-gate #define	MDET_LIST_END	U8(0x0)
797c478bd9Sstevel@tonic-gate #define	MDET_NULL	U8(' ')
807c478bd9Sstevel@tonic-gate #define	MDET_NODE	U8('N')
817c478bd9Sstevel@tonic-gate #define	MDET_NODE_END	U8('E')
827c478bd9Sstevel@tonic-gate #define	MDET_PROP_ARC	U8('a')
837c478bd9Sstevel@tonic-gate #define	MDET_PROP_VAL	U8('v')
847c478bd9Sstevel@tonic-gate #define	MDET_PROP_STR	U8('s')
857c478bd9Sstevel@tonic-gate #define	MDET_PROP_DAT	U8('d')
867c478bd9Sstevel@tonic-gate 
877c478bd9Sstevel@tonic-gate 
887c478bd9Sstevel@tonic-gate #ifndef _ASM	/* { */
897c478bd9Sstevel@tonic-gate 
901ae08745Sheppo /*
911ae08745Sheppo  * Opaque handles for use in external interfaces
921ae08745Sheppo  */
931ae08745Sheppo 
941ae08745Sheppo typedef void			*md_t;
951ae08745Sheppo 
967c478bd9Sstevel@tonic-gate typedef uint64_t		mde_cookie_t;
977c478bd9Sstevel@tonic-gate #define	MDE_INVAL_ELEM_COOKIE	((mde_cookie_t)-1)
987c478bd9Sstevel@tonic-gate 
997c478bd9Sstevel@tonic-gate typedef	uint32_t		mde_str_cookie_t;
1007c478bd9Sstevel@tonic-gate #define	MDE_INVAL_STR_COOKIE	((mde_str_cookie_t)-1)
1017c478bd9Sstevel@tonic-gate 
1021ae08745Sheppo typedef uint64_t		md_diff_cookie_t;
1031ae08745Sheppo #define	MD_INVAL_DIFF_COOKIE	((md_diff_cookie_t)-1)
1047c478bd9Sstevel@tonic-gate 
1051ae08745Sheppo #define	MDESC_INVAL_GEN		(0)
1061ae08745Sheppo 
1071ae08745Sheppo /*
1081ae08745Sheppo  * External structure for MD diff interface
1091ae08745Sheppo  */
1101ae08745Sheppo typedef struct {
1111ae08745Sheppo 	uint8_t		type;		/* property type */
1121ae08745Sheppo 	char		*namep;		/* property name */
1131ae08745Sheppo } md_prop_match_t;
1147c478bd9Sstevel@tonic-gate 
1157c478bd9Sstevel@tonic-gate 
1161ae08745Sheppo /*
117*908f1e13Ssd77468  * Walk callback function return codes
118*908f1e13Ssd77468  */
119*908f1e13Ssd77468 #define	MDE_WALK_ERROR	-1	/* Terminate walk with error */
120*908f1e13Ssd77468 #define	MDE_WALK_NEXT	0	/* Continue to next node */
121*908f1e13Ssd77468 #define	MDE_WALK_DONE	1	/* Terminate walk with success */
122*908f1e13Ssd77468 
123*908f1e13Ssd77468 /*
124*908f1e13Ssd77468  * The function prototype for a walker callback function.
125*908f1e13Ssd77468  * The machine description session, parent node, current node,
126*908f1e13Ssd77468  * and private data are given to the callback.
127*908f1e13Ssd77468  *
128*908f1e13Ssd77468  * The parent node is given to the callback to provide context
129*908f1e13Ssd77468  * on how the walker arrived at this location.  While the node
130*908f1e13Ssd77468  * may have many parents, it will be visited only once, this
131*908f1e13Ssd77468  * provides context on how the walker arrived at the node.
132*908f1e13Ssd77468  *
133*908f1e13Ssd77468  * Input		Description
134*908f1e13Ssd77468  * -------------------	----------------------------------------
135*908f1e13Ssd77468  * md_t *		Pointer to md session
136*908f1e13Ssd77468  * mde_cookie_t		Index of parent node to provide context
137*908f1e13Ssd77468  * mde_cookie_t		The current node in the walk
138*908f1e13Ssd77468  * void *		Private data for the walking function
139*908f1e13Ssd77468  */
140*908f1e13Ssd77468 typedef int md_walk_fn_t(md_t *, mde_cookie_t, mde_cookie_t, void *);
141*908f1e13Ssd77468 
142*908f1e13Ssd77468 
143*908f1e13Ssd77468 /*
1441ae08745Sheppo  * External Interface
1451ae08745Sheppo  */
1467c478bd9Sstevel@tonic-gate 
1471ae08745Sheppo extern md_t		*md_init_intern(uint64_t *,
1481ae08745Sheppo 				void *(*allocp)(size_t),
1491ae08745Sheppo 				void (*freep)(void *, size_t));
1507c478bd9Sstevel@tonic-gate 
1517c478bd9Sstevel@tonic-gate extern int		md_fini(md_t *);
1527c478bd9Sstevel@tonic-gate 
1537c478bd9Sstevel@tonic-gate extern int		md_node_count(md_t *);
1547c478bd9Sstevel@tonic-gate 
1557c478bd9Sstevel@tonic-gate extern mde_str_cookie_t md_find_name(md_t *, char *namep);
1567c478bd9Sstevel@tonic-gate 
1577c478bd9Sstevel@tonic-gate extern mde_cookie_t	md_root_node(md_t *);
1587c478bd9Sstevel@tonic-gate 
1591ae08745Sheppo extern uint64_t		md_get_gen(md_t *);
1601ae08745Sheppo 
1611ae08745Sheppo extern size_t		md_get_bin_size(md_t *);
1621ae08745Sheppo 
1637c478bd9Sstevel@tonic-gate extern int		md_scan_dag(md_t *,
1647c478bd9Sstevel@tonic-gate 				mde_cookie_t,
1657c478bd9Sstevel@tonic-gate 				mde_str_cookie_t,
1667c478bd9Sstevel@tonic-gate 				mde_str_cookie_t,
1677c478bd9Sstevel@tonic-gate 				mde_cookie_t *);
1687c478bd9Sstevel@tonic-gate 
169*908f1e13Ssd77468 extern int		md_walk_dag(md_t *,
170*908f1e13Ssd77468 				mde_cookie_t,
171*908f1e13Ssd77468 				mde_str_cookie_t,
172*908f1e13Ssd77468 				mde_str_cookie_t,
173*908f1e13Ssd77468 				md_walk_fn_t,
174*908f1e13Ssd77468 				void *);
175*908f1e13Ssd77468 
1767c478bd9Sstevel@tonic-gate extern int		md_get_prop_val(md_t *,
1777c478bd9Sstevel@tonic-gate 				mde_cookie_t,
1787c478bd9Sstevel@tonic-gate 				char *,
1797c478bd9Sstevel@tonic-gate 				uint64_t *);
1807c478bd9Sstevel@tonic-gate 
1817c478bd9Sstevel@tonic-gate extern int		md_get_prop_str(md_t *,
1827c478bd9Sstevel@tonic-gate 				mde_cookie_t,
1837c478bd9Sstevel@tonic-gate 				char *,
1847c478bd9Sstevel@tonic-gate 				char **);
1857c478bd9Sstevel@tonic-gate 
1867c478bd9Sstevel@tonic-gate extern int		md_get_prop_data(md_t *,
1877c478bd9Sstevel@tonic-gate 				mde_cookie_t,
1887c478bd9Sstevel@tonic-gate 				char *,
1897c478bd9Sstevel@tonic-gate 				uint8_t **,
1907c478bd9Sstevel@tonic-gate 				int *);
1917c478bd9Sstevel@tonic-gate 
192*908f1e13Ssd77468 extern int		md_get_prop_arcs(md_t *,
193*908f1e13Ssd77468 				mde_cookie_t,
194*908f1e13Ssd77468 				char *,
195*908f1e13Ssd77468 				mde_cookie_t *,
196*908f1e13Ssd77468 				size_t);
197*908f1e13Ssd77468 
198*908f1e13Ssd77468 
1991ae08745Sheppo extern md_diff_cookie_t	md_diff_init(md_t *,
2001ae08745Sheppo 				mde_cookie_t,
2011ae08745Sheppo 				md_t *,
2021ae08745Sheppo 				mde_cookie_t,
2031ae08745Sheppo 				char *,
2041ae08745Sheppo 				md_prop_match_t *);
2051ae08745Sheppo 
2061ae08745Sheppo extern int		md_diff_added(md_diff_cookie_t,
2071ae08745Sheppo 				mde_cookie_t **);
2081ae08745Sheppo 
2091ae08745Sheppo extern int		md_diff_removed(md_diff_cookie_t,
2101ae08745Sheppo 				mde_cookie_t **);
2111ae08745Sheppo 
2121ae08745Sheppo extern int		md_diff_matched(md_diff_cookie_t,
2131ae08745Sheppo 				mde_cookie_t **,
2141ae08745Sheppo 				mde_cookie_t **);
2151ae08745Sheppo 
2161ae08745Sheppo extern int		md_diff_fini(md_diff_cookie_t);
2177c478bd9Sstevel@tonic-gate 
2187c478bd9Sstevel@tonic-gate 
2197c478bd9Sstevel@tonic-gate #endif	/* } _ASM */
2207c478bd9Sstevel@tonic-gate 
2217c478bd9Sstevel@tonic-gate 
2227c478bd9Sstevel@tonic-gate 
2237c478bd9Sstevel@tonic-gate /*
2247c478bd9Sstevel@tonic-gate  * ioctl info for mdesc device
2257c478bd9Sstevel@tonic-gate  */
2267c478bd9Sstevel@tonic-gate 
2277c478bd9Sstevel@tonic-gate #define	MDESCIOC	('m' << 24 | 'd' << 16 | 'd' << 8)
2287c478bd9Sstevel@tonic-gate 
2297c478bd9Sstevel@tonic-gate #define	MDESCIOCGSZ	(MDESCIOC | 1)   /* Get quote buffer size */
2307c478bd9Sstevel@tonic-gate #define	MDESCIOCSSZ	(MDESCIOC | 2)   /* Set new quote buffer size */
2317c478bd9Sstevel@tonic-gate #define	MDESCIOCDISCARD	(MDESCIOC | 3)   /* Discard quotes and reset */
2327c478bd9Sstevel@tonic-gate 
2337c478bd9Sstevel@tonic-gate #ifdef __cplusplus
2347c478bd9Sstevel@tonic-gate }
2357c478bd9Sstevel@tonic-gate #endif
2367c478bd9Sstevel@tonic-gate 
2377c478bd9Sstevel@tonic-gate #endif	/* _MDESC_H_ */
238