1N/A/***************************************************************************
1N/A *
1N/A * devinfo.h : definitions for libdevinfo-based device enumeration
1N/A *
1N/A * Copyright 2007 Sun Microsystems, Inc. All rights reserved.
1N/A * Use is subject to license terms.
1N/A *
1N/A * Licensed under the Academic Free License version 2.1
1N/A *
1N/A **************************************************************************/
1N/A
1N/A#pragma ident "%Z%%M% %I% %E% SMI"
1N/A
1N/A#ifndef DEVINFO_H
1N/A#define DEVINFO_H
1N/A
1N/A#include <glib.h>
1N/A#include <libdevinfo.h>
1N/A
1N/A#include "../hald.h"
1N/A#include "../device_info.h"
1N/A
1N/Atypedef struct DevinfoDevHandler_s
1N/A{
1N/A HalDevice *(*add) (HalDevice *parent, di_node_t node, char *devfs_path, char *device_type);
1N/A
1N/A /* yet unused */
1N/A void (*remove) (char *devfs_path);
1N/A
1N/A void (*hotplug_begin_add) (HalDevice *d, HalDevice *parent, struct DevinfoDevHandler_s *handler, void *end_token);
1N/A
1N/A void (*hotplug_begin_remove) (HalDevice *d, struct DevinfoDevHandler_s *handler, void *end_token);
1N/A
1N/A void (*probing_done) (HalDevice *d, guint32 exit_type, gint return_code, char **error, gpointer userdata1, gpointer userdata2);
1N/A
1N/A const gchar *(*get_prober) (HalDevice *d, int *timeout);
1N/A} DevinfoDevHandler;
1N/A
1N/A#define PROP_INT(d, node, v, diprop, halprop) \
1N/A if (di_prop_lookup_ints(DDI_DEV_T_ANY, node, diprop, &(v)) > 0) { \
1N/A hal_device_property_set_int (d, halprop, *(v)); \
1N/A }
1N/A
1N/A#define PROP_STR(d, node, v, diprop, halprop) \
1N/A if (di_prop_lookup_strings(DDI_DEV_T_ANY, node, diprop, &(v)) > 0) { \
1N/A hal_device_property_set_string (d, halprop, v); \
1N/A }
1N/A
1N/A#define PROP_BOOL(d, node, v, diprop, halprop) \
1N/A hal_device_property_set_bool (d, halprop, \
1N/A (di_prop_lookup_ints(DDI_DEV_T_ANY, node, diprop, &(v)) >= 0));
1N/A
1N/A#define NELEM(a) (sizeof (a) / sizeof (*(a)))
1N/A
1N/Avoid devinfo_add (HalDevice *parent, gchar *path);
1N/Avoid devinfo_set_default_properties (HalDevice *d, HalDevice *parent, di_node_t node, char *devfs_path);
1N/Avoid devinfo_callouts_preprobing_done (HalDevice *d, gpointer userdata1, gpointer userdata2);
1N/Avoid devinfo_callouts_probing_done (HalDevice *d, guint32 exit_type, gint return_code, char **error,
1N/A gpointer userdata1, gpointer userdata2);
1N/Avoid devinfo_callouts_add_done (HalDevice *d, gpointer userdata1, gpointer userdata2);
1N/Avoid devinfo_callouts_remove_done (HalDevice *d, gpointer userdata1, gpointer userdata2);
1N/Avoid hotplug_event_begin_add_devinfo (HalDevice *d, HalDevice *parent, DevinfoDevHandler *handler, void *end_token);
1N/Avoid devinfo_remove (gchar *path);
1N/Avoid devinfo_remove_branch (gchar *path, HalDevice *d);
1N/Avoid hotplug_event_begin_remove_devinfo (HalDevice *d, gchar *devfs_path, void *end_token);
1N/Avoid devinfo_hotplug_enqueue(HalDevice *d, gchar *devfs_path, DevinfoDevHandler *handler, int action, int front);
1N/Avoid devinfo_add_enqueue(HalDevice *d, gchar *devfs_path, DevinfoDevHandler *handler);
1N/Avoid devinfo_add_enqueue_at_front(HalDevice *d, gchar *devfs_path, DevinfoDevHandler *handler);
1N/Avoid devinfo_remove_enqueue(gchar *devfs_path, DevinfoDevHandler *handler);
1N/Agboolean devinfo_device_rescan (HalDevice *d);
1N/Achar *get_devlink(di_devlink_handle_t devlink_hdl, char *re, char *path);
1N/A
1N/A
1N/A#endif /* DEVINFO_H */