| #ifndef _SPARC64_MDESC_H | 
 | #define _SPARC64_MDESC_H | 
 |  | 
 | #include <linux/types.h> | 
 | #include <linux/cpumask.h> | 
 | #include <asm/prom.h> | 
 |  | 
 | struct mdesc_handle; | 
 |  | 
 | /* Machine description operations are to be surrounded by grab and | 
 |  * release calls.  The mdesc_handle returned from the grab is | 
 |  * the first argument to all of the operational calls that work | 
 |  * on mdescs. | 
 |  */ | 
 | extern struct mdesc_handle *mdesc_grab(void); | 
 | extern void mdesc_release(struct mdesc_handle *); | 
 |  | 
 | #define MDESC_NODE_NULL		(~(u64)0) | 
 |  | 
 | extern u64 mdesc_node_by_name(struct mdesc_handle *handle, | 
 | 			      u64 from_node, const char *name); | 
 | #define mdesc_for_each_node_by_name(__hdl, __node, __name) \ | 
 | 	for (__node = mdesc_node_by_name(__hdl, MDESC_NODE_NULL, __name); \ | 
 | 	     (__node) != MDESC_NODE_NULL; \ | 
 | 	     __node = mdesc_node_by_name(__hdl, __node, __name)) | 
 |  | 
 | /* Access to property values returned from mdesc_get_property() are | 
 |  * only valid inside of a mdesc_grab()/mdesc_release() sequence. | 
 |  * Once mdesc_release() is called, the memory backed up by these | 
 |  * pointers may reference freed up memory. | 
 |  * | 
 |  * Therefore callers must make copies of any property values | 
 |  * they need. | 
 |  * | 
 |  * These same rules apply to mdesc_node_name(). | 
 |  */ | 
 | extern const void *mdesc_get_property(struct mdesc_handle *handle, | 
 | 				      u64 node, const char *name, int *lenp); | 
 | extern const char *mdesc_node_name(struct mdesc_handle *hp, u64 node); | 
 |  | 
 | /* MD arc iteration, the standard sequence is: | 
 |  * | 
 |  *	unsigned long arc; | 
 |  *	mdesc_for_each_arc(arc, handle, node, MDESC_ARC_TYPE_{FWD,BACK}) { | 
 |  *		unsigned long target = mdesc_arc_target(handle, arc); | 
 |  *		... | 
 |  *	} | 
 |  */ | 
 |  | 
 | #define MDESC_ARC_TYPE_FWD	"fwd" | 
 | #define MDESC_ARC_TYPE_BACK	"back" | 
 |  | 
 | extern u64 mdesc_next_arc(struct mdesc_handle *handle, u64 from, | 
 | 			  const char *arc_type); | 
 | #define mdesc_for_each_arc(__arc, __hdl, __node, __type) \ | 
 | 	for (__arc = mdesc_next_arc(__hdl, __node, __type); \ | 
 | 	     (__arc) != MDESC_NODE_NULL; \ | 
 | 	     __arc = mdesc_next_arc(__hdl, __arc, __type)) | 
 |  | 
 | extern u64 mdesc_arc_target(struct mdesc_handle *hp, u64 arc); | 
 |  | 
 | extern void mdesc_update(void); | 
 |  | 
 | struct mdesc_notifier_client { | 
 | 	void (*add)(struct mdesc_handle *handle, u64 node); | 
 | 	void (*remove)(struct mdesc_handle *handle, u64 node); | 
 |  | 
 | 	const char			*node_name; | 
 | 	struct mdesc_notifier_client	*next; | 
 | }; | 
 |  | 
 | extern void mdesc_register_notifier(struct mdesc_notifier_client *client); | 
 |  | 
 | extern void mdesc_fill_in_cpu_data(cpumask_t *mask); | 
 | extern void mdesc_populate_present_mask(cpumask_t *mask); | 
 |  | 
 | extern void sun4v_mdesc_init(void); | 
 |  | 
 | #endif |