root/usr/src/lib/fm/topo/libtopo/common/libtopo.h
/*
 * CDDL HEADER START
 *
 * The contents of this file are subject to the terms of the
 * Common Development and Distribution License (the "License").
 * You may not use this file except in compliance with the License.
 *
 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
 * or http://www.opensolaris.org/os/licensing.
 * See the License for the specific language governing permissions
 * and limitations under the License.
 *
 * When distributing Covered Code, include this CDDL HEADER in each
 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
 * If applicable, add the following below this CDDL HEADER, with the
 * fields enclosed by brackets "[]" replaced with your own identifying
 * information: Portions Copyright [yyyy] [name of copyright owner]
 *
 * CDDL HEADER END
 */

/*
 * Copyright (c) 2006, 2010, Oracle and/or its affiliates. All rights reserved.
 */
/*
 * Copyright 2020 Joyent, Inc.
 * Copyright 2024 Oxide Computer Company
 */

#ifndef _LIBTOPO_H
#define _LIBTOPO_H

#include <sys/nvpair.h>
#include <stdio.h>
#include <stdarg.h>
#include <libdevinfo.h>

#ifdef __cplusplus
extern "C" {
#endif

#define TOPO_VERSION    1       /* Library ABI Interface Version */

typedef struct topo_hdl topo_hdl_t;
typedef struct topo_node tnode_t;
typedef struct topo_walk topo_walk_t;
typedef struct topo_schema_walk topo_schema_walk_t;
typedef uint64_t topo_instance_t;
typedef uint32_t topo_version_t;

typedef struct topo_list {
        struct topo_list *l_prev;
        struct topo_list *l_next;
} topo_list_t;

typedef struct topo_faclist {
        topo_list_t     tf_list;
        tnode_t         *tf_node;
} topo_faclist_t;

typedef struct topo_digraph topo_digraph_t;
typedef struct topo_vertex topo_vertex_t;
typedef struct topo_edge topo_edge_t;

typedef struct topo_path {
        const char      *tsp_fmristr;
        nvlist_t        *tsp_fmri;
        topo_list_t     tsp_components;
} topo_path_t;

typedef struct topo_path_component {
        topo_list_t     tspc_link;
        topo_vertex_t   *tspc_vertex;
} topo_path_component_t;

/*
 * The following functions, error codes and data structures are private
 * to libtopo snapshot consumers and enumerator modules.
 */
extern topo_hdl_t *topo_open(int, const char *, int *);
extern void topo_close(topo_hdl_t *);
extern char *topo_snap_hold(topo_hdl_t *, const char *, int *);
extern void topo_snap_release(topo_hdl_t *);

/*
 * Snapshot walker support
 */
typedef int (*topo_walk_cb_t)(topo_hdl_t *, tnode_t *, void *);

extern topo_walk_t *topo_walk_init(topo_hdl_t *, const char *, topo_walk_cb_t,
    void *, int *);
extern int topo_walk_step(topo_walk_t *, int);
extern void topo_walk_fini(topo_walk_t *);
extern di_node_t topo_hdl_devinfo(topo_hdl_t *);
extern di_prom_handle_t topo_hdl_prominfo(topo_hdl_t *);

/*
 * Walk status returned from walker
 */
#define TOPO_WALK_ERR           -1
#define TOPO_WALK_NEXT          0
#define TOPO_WALK_TERMINATE     1

/*
 * Types of walks: depth-first (child) or breadth-first (sibling)
 */
#define TOPO_WALK_CHILD         0x0001
#define TOPO_WALK_SIBLING       0x0002

/*
 * Snapshot scheme walker support.
 */

typedef enum topo_scheme_type {
        TOPO_SCHEME_TREE,
        TOPO_SCHEME_DIGRAPH
} topo_scheme_type_t;

/*
 * Callers should not copy this structure. It should be assumed that it will
 * grow in the future.
 */
typedef struct topo_scheme_info {
        const char *tsi_scheme;
        topo_scheme_type_t tsi_type;
} topo_scheme_info_t;

typedef int (*topo_scheme_walk_cb_f)(topo_hdl_t *, const topo_scheme_info_t *,
    void *);
extern int topo_scheme_walk(topo_hdl_t *, topo_scheme_walk_cb_f, void *);

/*
 * FMRI helper routines
 */
extern int topo_fmri_present(topo_hdl_t *, nvlist_t *, int *);
extern int topo_fmri_replaced(topo_hdl_t *, nvlist_t *, int *);
extern int topo_fmri_contains(topo_hdl_t *, nvlist_t *, nvlist_t *, int *);
extern int topo_fmri_expand(topo_hdl_t *, nvlist_t *, int *);
extern int topo_fmri_unusable(topo_hdl_t *, nvlist_t *, int *);
extern int topo_fmri_service_state(topo_hdl_t *, nvlist_t *, int *);
extern int topo_fmri_retire(topo_hdl_t *, nvlist_t *, int *);
extern int topo_fmri_unretire(topo_hdl_t *, nvlist_t *, int *);
extern int topo_fmri_nvl2str(topo_hdl_t *, nvlist_t *, char **, int *);
extern int topo_fmri_str2nvl(topo_hdl_t *, const char *, nvlist_t **, int *);
extern int topo_fmri_asru(topo_hdl_t *, nvlist_t *, nvlist_t **, int *);
extern int topo_fmri_fru(topo_hdl_t *, nvlist_t *, nvlist_t **,
    int *);
extern int topo_fmri_label(topo_hdl_t *, nvlist_t *, char **, int *);
extern int topo_fmri_serial(topo_hdl_t *, nvlist_t *, char **, int *);
extern int topo_fmri_compare(topo_hdl_t *, nvlist_t *, nvlist_t *, int *);
extern int topo_fmri_facility(topo_hdl_t *, nvlist_t *, const char *,
    uint32_t, topo_walk_cb_t, void *, int *);

/*
 * Consolidation private utility functions
 */
extern ulong_t topo_fmri_strhash(topo_hdl_t *, const char *);
extern ulong_t topo_fmri_strhash_noauth(topo_hdl_t *, const char *);
extern boolean_t topo_fmri_strcmp(topo_hdl_t *, const char *, const char *);
extern boolean_t topo_fmri_strcmp_noauth(topo_hdl_t *, const char *,
    const char *);

/*
 * Topo node utilities: callable from topo_walk_step() callback or module
 * enumeration, topo_mod_enumerate()
 */
extern char *topo_node_name(tnode_t *);
extern topo_instance_t topo_node_instance(tnode_t *);
extern tnode_t *topo_node_parent(tnode_t *);
extern void *topo_node_private(tnode_t *);
extern int topo_node_flags(tnode_t *);
extern int topo_node_asru(tnode_t *, nvlist_t **, nvlist_t *, int *);
extern int topo_node_fru(tnode_t *, nvlist_t **, nvlist_t *, int *);
extern int topo_node_resource(tnode_t *, nvlist_t **, int *);
extern int topo_node_label(tnode_t *, char **, int *);
extern tnode_t *topo_node_lookup(tnode_t *, const char *, topo_instance_t);
extern int topo_method_invoke(tnode_t *node, const char *, topo_version_t,
    nvlist_t *, nvlist_t **, int *);
extern boolean_t topo_method_supported(tnode_t *, const char *,
    topo_version_t);
extern int topo_node_facility(topo_hdl_t *, tnode_t *, const char *,
    uint32_t, topo_faclist_t *, int *);
extern int topo_node_child_walk(topo_hdl_t *, tnode_t *, topo_walk_cb_t,
    void *, int *);
extern int topo_node_occupied(tnode_t *, boolean_t *);

/*
 * Node flags: denotes type of node
 */
#define TOPO_NODE_DEFAULT       0
#define TOPO_NODE_FACILITY      1

#define TOPO_FAC_TYPE_SENSOR    "sensor"
#define TOPO_FAC_TYPE_INDICATOR "indicator"

/*
 * Topo property get functions
 */
extern int topo_prop_get_int32(tnode_t *, const char *, const char *,
    int32_t *, int *);
extern int topo_prop_get_uint32(tnode_t *, const char *, const char *,
    uint32_t *, int *);
extern int topo_prop_get_int64(tnode_t *, const char *, const char *,
    int64_t *, int *);
extern int topo_prop_get_uint64(tnode_t *, const char *, const char *,
    uint64_t *, int *);
extern int topo_prop_get_double(tnode_t *, const char *, const char *,
    double *, int *);
extern int topo_prop_get_string(tnode_t *, const char *, const char *,
    char **, int *);
extern int topo_prop_get_fmri(tnode_t *, const char *, const char *,
    nvlist_t **, int *);
extern int topo_prop_get_int32_array(tnode_t *, const char *, const char *,
    int32_t **, uint_t *, int *);
extern int topo_prop_get_uint32_array(tnode_t *, const char *, const char *,
    uint32_t **, uint_t *, int *);
extern int topo_prop_get_int64_array(tnode_t *, const char *, const char *,
    int64_t **, uint_t *, int *);
extern int topo_prop_get_uint64_array(tnode_t *, const char *, const char *,
    uint64_t **, uint_t *, int *);
extern int topo_prop_get_string_array(tnode_t *, const char *, const char *,
    char ***, uint_t *, int *);
extern int topo_prop_get_fmri_array(tnode_t *, const char *, const char *,
    nvlist_t ***, uint_t *, int *);

/*
 * Topo property set functions
 */
extern int topo_prop_set_int32(tnode_t *, const char *, const char *, int,
    int32_t, int *);
extern int topo_prop_set_uint32(tnode_t *, const char *, const char *, int,
    uint32_t, int *);
extern int topo_prop_set_int64(tnode_t *, const char *, const char *,
    int, int64_t, int *);
extern int topo_prop_set_uint64(tnode_t *, const char *, const char *,
    int, uint64_t, int *);
extern int topo_prop_set_double(tnode_t *, const char *, const char *,
    int, double, int *);
extern int topo_prop_set_string(tnode_t *, const char *, const char *,
    int, const char *, int *);
extern int topo_prop_set_fmri(tnode_t *, const char *, const char *,
    int, const nvlist_t *, int *);
extern int topo_prop_set_int32_array(tnode_t *, const char *, const char *, int,
    int32_t *, uint_t, int *);
extern int topo_prop_set_uint32_array(tnode_t *, const char *, const char *,
    int, uint32_t *, uint_t, int *);
extern int topo_prop_set_int64_array(tnode_t *, const char *, const char *,
    int, int64_t *, uint_t, int *);
extern int topo_prop_set_uint64_array(tnode_t *, const char *, const char *,
    int, uint64_t *, uint_t, int *);
extern int topo_prop_set_string_array(tnode_t *, const char *, const char *,
    int, const char **, uint_t, int *);
extern int topo_prop_set_fmri_array(tnode_t *, const char *, const char *,
    int, const nvlist_t **, uint_t, int *);

#define TOPO_PROP_IMMUTABLE     0
#define TOPO_PROP_MUTABLE       0x01
#define TOPO_PROP_NONVOLATILE   0x02

/* Protocol property group and property names */
#define TOPO_PGROUP_PROTOCOL    "protocol"      /* Required property group */
#define TOPO_PROP_RESOURCE      "resource"      /* resource FMRI */
#define TOPO_PROP_ASRU          "ASRU"          /* ASRU FMRI */
#define TOPO_PROP_FRU           "FRU"           /* FRU FMRI */
#define TOPO_PROP_MOD           "module"        /* software module FMRI */
#define TOPO_PROP_PKG           "package"       /* software package FMRI */
#define TOPO_PROP_LABEL         "label"         /*  property LABEL */

#define TOPO_METH_FAC_ENUM      "fac_enum"

/*
 * System property group
 */
#define TOPO_PGROUP_SYSTEM      "system"
#define TOPO_PROP_ISA           "isa"
#define TOPO_PROP_MACHINE       "machine"

#define TOPO_PGROUP_IPMI        "ipmi"

/*
 * These enum definitions are used to define a set of error tags associated with
 * libtopo error conditions occuring during the adminstration of
 * properties, invocation of methods and fmri-based queries.  The shell script
 * mkerror.sh is used to parse this file and create a corresponding topo_error.c
 * source file.
 *
 * If you do something other than add a new error tag here, you may need to
 * update the mkerror shell script as it is based upon simple regexps.
 */
typedef enum topo_prop_errno {
    ETOPO_PROP_UNKNOWN = 3000, /* unknown topo prop error */
    ETOPO_PROP_NOENT,   /* undefined property or property group */
    ETOPO_PROP_DEFD,    /* static property already defined */
    ETOPO_PROP_NOMEM,   /* memory limit exceeded during property allocation */
    ETOPO_PROP_TYPE,    /* invalid property type */
    ETOPO_PROP_NAME,    /* invalid property name */
    ETOPO_PROP_NOINHERIT, /* can not inherit property */
    ETOPO_PROP_NVL,     /* malformed property nvlist */
    ETOPO_PROP_METHOD,  /* get property method failed */
    ETOPO_PROP_END      /* end of prop errno list (to ease auto-merge) */
} topo_prop_errno_t;

typedef enum topo_method_errno {
    ETOPO_METHOD_UNKNOWN = 3100, /* unknown topo method error */
    ETOPO_METHOD_INVAL,         /* invalid method registration */
    ETOPO_METHOD_NOTSUP,        /* method not supported */
    ETOPO_METHOD_FAIL,          /* method failed */
    ETOPO_METHOD_VEROLD,        /* app is compiled to use obsolete method */
    ETOPO_METHOD_VERNEW,        /* app is compiled to use obsolete method */
    ETOPO_METHOD_NOMEM,         /* memory limit exceeded during method op */
    ETOPO_METHOD_DEFD,          /* method op already defined */
    ETOPO_METHOD_END            /* end of method errno list */
} topo_method_errno_t;

typedef enum topo_fmri_errno {
    ETOPO_FMRI_UNKNOWN = 3200, /* unknown topo fmri error */
    ETOPO_FMRI_NVL,             /* nvlist allocation failure for FMRI */
    ETOPO_FMRI_VERSION,         /* invalid FMRI scheme version */
    ETOPO_FMRI_MALFORM,         /* malformed FMRI */
    ETOPO_FMRI_NOMEM,           /* memory limit exceeded */
    ETOPO_FMRI_END              /* end of fmri errno list */
} topo_fmri_errno_t;

typedef enum topo_hdl_errno {
    ETOPO_HDL_UNKNOWN = 3300,   /* unknown topo handle error */
    ETOPO_HDL_ABIVER,           /* handle opened with invalid ABI version */
    ETOPO_HDL_SNAP,             /* snapshot already taken */
    ETOPO_HDL_INVAL,            /* invalid argument specified */
    ETOPO_HDL_UUID,             /* uuid already set */
    ETOPO_HDL_NOMEM,            /* memory limit exceeded */
    ETOPO_HDL_END               /* end of handle errno list */
} topo_hdl_errno_t;

extern const char *topo_strerror(int);
extern void topo_hdl_strfree(topo_hdl_t *, char *);
extern void topo_hdl_strfreev(topo_hdl_t *, char **, uint_t);
extern void topo_debug_set(topo_hdl_t *, const char *, const char *);

/*
 * The following functions and data structures to support property
 * observability are private to the fmtopo command.
 */

/*
 * Each topology node advertises the name and data stability of each of its
 * modules and properties. (see attributes(7)).
 */

/*
 * Topo stability attributes
 */
typedef enum topo_stability {
        TOPO_STABILITY_UNKNOWN = 0,     /* private to libtopo */
        TOPO_STABILITY_INTERNAL,        /* private to libtopo */
        TOPO_STABILITY_PRIVATE,         /* private to Sun */
        TOPO_STABILITY_OBSOLETE,        /* scheduled for removal */
        TOPO_STABILITY_EXTERNAL,        /* not controlled by Sun */
        TOPO_STABILITY_UNSTABLE,        /* new or rapidly changing */
        TOPO_STABILITY_EVOLVING,        /* less rapidly changing */
        TOPO_STABILITY_STABLE,          /* mature interface from Sun */
        TOPO_STABILITY_STANDARD         /* industry standard */
} topo_stability_t;

#define TOPO_STABILITY_MAX      TOPO_STABILITY_STANDARD /* max valid stab */

typedef struct topo_pgroup_info {
        const char *tpi_name;           /* property group name */
        topo_stability_t tpi_namestab;  /* stability of group name */
        topo_stability_t tpi_datastab;  /* stability of all property values */
        topo_version_t tpi_version;     /* version of pgroup definition */
} topo_pgroup_info_t;

extern topo_stability_t topo_name2stability(const char *);
extern const char *topo_stability2name(topo_stability_t);
extern void topo_pgroup_destroy(tnode_t *, const char *);
extern topo_pgroup_info_t *topo_pgroup_info(tnode_t *, const char *, int *);

typedef enum {
        TOPO_TYPE_INVALID = 0,
        TOPO_TYPE_BOOLEAN,      /* boolean */
        TOPO_TYPE_INT32,        /* int32_t */
        TOPO_TYPE_UINT32,       /* uint32_t */
        TOPO_TYPE_INT64,        /* int64_t */
        TOPO_TYPE_UINT64,       /* uint64_t */
        TOPO_TYPE_STRING,       /* const char* */
        TOPO_TYPE_TIME,         /* uint64_t */
        TOPO_TYPE_SIZE,         /* uint64_t */
        TOPO_TYPE_FMRI,         /* nvlist_t */
        TOPO_TYPE_INT32_ARRAY,  /* array of int32_t */
        TOPO_TYPE_UINT32_ARRAY, /* array of uint32_t */
        TOPO_TYPE_INT64_ARRAY,  /* array of int64_t */
        TOPO_TYPE_UINT64_ARRAY, /* array of uint64_t */
        TOPO_TYPE_STRING_ARRAY, /* array of const char* */
        TOPO_TYPE_FMRI_ARRAY,   /* array of nvlist_t */
        TOPO_TYPE_DOUBLE        /* double */
} topo_type_t;

extern nvlist_t *topo_prop_getprops(tnode_t *, int *err);
extern int topo_prop_getprop(tnode_t *, const char *, const char *,
    nvlist_t *, nvlist_t **, int *);
extern int topo_prop_getpgrp(tnode_t *, const char *, nvlist_t **, int *);
extern int topo_prop_setprop(tnode_t *, const char *, nvlist_t *,
    int, nvlist_t *, int *);
extern int topo_fmri_getprop(topo_hdl_t *, nvlist_t *, const char *,
    const char *, nvlist_t *,  nvlist_t **, int *);
extern int topo_fmri_getpgrp(topo_hdl_t *, nvlist_t *, const char *,
    nvlist_t **, int *);
extern int topo_fmri_setprop(topo_hdl_t *, nvlist_t *, const char *,
    nvlist_t *, int, nvlist_t *, int *);
extern void topo_pgroup_hcset(tnode_t *, nvlist_t *);

/* Property node NVL names used in topo_prop_getprops */
#define TOPO_PROP_GROUP         "property-group"
#define TOPO_PROP_GROUP_NAME    "property-group-name"
#define TOPO_PROP_GROUP_DSTAB   "property-group-data-stability"
#define TOPO_PROP_GROUP_NSTAB   "property-group-name-stability"
#define TOPO_PROP_GROUP_VERSION "property-group-version"
#define TOPO_PROP_VAL           "property"
#define TOPO_PROP_VAL_NAME      "property-name"
#define TOPO_PROP_VAL_VAL       "property-value"
#define TOPO_PROP_VAL_TYPE      "property-type"
#define TOPO_PROP_FLAG          "property-flag"

/*
 * ARGS list used in topo property methods
 */
#define TOPO_PROP_ARGS  "args"
#define TOPO_PROP_PARGS "private-args"

extern int topo_xml_print(topo_hdl_t *, FILE *, const char *scheme, int *);

extern void *topo_hdl_alloc(topo_hdl_t *, size_t);
extern void *topo_hdl_zalloc(topo_hdl_t *, size_t);
extern void topo_hdl_free(topo_hdl_t *, void *, size_t);
extern int topo_hdl_nvalloc(topo_hdl_t *, nvlist_t **, uint_t);
extern int topo_hdl_nvdup(topo_hdl_t *, nvlist_t *, nvlist_t **);
extern char *topo_hdl_strdup(topo_hdl_t *, const char *);
extern int topo_hdl_vasprintf(topo_hdl_t *, char **, const char *,
    va_list) __VPRINTFLIKE(3);
extern int topo_hdl_asprintf(topo_hdl_t *, char **, const char *,
    ...) __PRINTFLIKE(3);

/*
 * Interfaces for interacting with directed graph topologies
 */
extern topo_digraph_t *topo_digraph_get(topo_hdl_t *, const char *);
extern int topo_vertex_iter(topo_hdl_t *, topo_digraph_t *,
    int (*)(topo_hdl_t *, topo_vertex_t *, boolean_t, void *), void *);
extern tnode_t *topo_vertex_node(topo_vertex_t *);
extern int topo_edge_iter(topo_hdl_t *, topo_vertex_t *,
    int (*)(topo_hdl_t *, topo_edge_t *, boolean_t, void *), void *);
extern int topo_digraph_paths(topo_hdl_t *, topo_digraph_t *,
    topo_vertex_t *, topo_vertex_t *, topo_path_t ***, uint_t *);
extern void topo_path_destroy(topo_hdl_t *, topo_path_t *);
extern int topo_digraph_serialize(topo_hdl_t *, topo_digraph_t *, FILE *);
extern topo_digraph_t *topo_digraph_deserialize(topo_hdl_t *, const char *,
    size_t);
extern topo_vertex_t *topo_node_vertex(tnode_t *);

/*
 * Interfaces for converting sensor/indicator types, units, states, etc to
 * a string
 */
extern void topo_sensor_type_name(uint32_t, char *, size_t);
extern void topo_sensor_units_name(uint32_t, char *, size_t);
extern void topo_led_type_name(uint32_t, char *, size_t);
extern void topo_led_state_name(uint32_t, char *, size_t);
extern void topo_sensor_state_name(uint32_t, uint32_t, char *,
    size_t len);

/*
 * Defines for standard properties for sensors and indicators
 */
#define TOPO_PGROUP_FACILITY    "facility"

#define TOPO_SENSOR_READING     "reading"
#define TOPO_SENSOR_STATE       "state"
#define TOPO_SENSOR_CLASS       "sensor-class"
#define TOPO_FACILITY_TYPE      "type"
#define TOPO_SENSOR_UNITS       "units"
#define TOPO_LED_MODE           "mode"

#define TOPO_PROP_THRESHOLD_LNC         "threshold-lower-non-critical"
#define TOPO_PROP_THRESHOLD_LCR         "threshold-lower-critical"
#define TOPO_PROP_THRESHOLD_LNR         "threshold-lower-non-recoverable"

#define TOPO_PROP_THRESHOLD_UNC         "threshold-upper-non-critical"
#define TOPO_PROP_THRESHOLD_UCR         "threshold-upper-critical"
#define TOPO_PROP_THRESHOLD_UNR         "threshold-upper-non-recoverable"

/*
 * Sensor Classes
 *
 * The "sensor-class" property in the "facility" propgroup on
 * facility nodes of type "sensor" should be set to one of these
 * two values.
 *
 * Threshold sensors provide an analog sensor reading via the
 * "reading" property in the facility propgroup.  They will also
 * provide one or more discrete states via the "state" property
 * in the facility propgroup.
 *
 * Discrete sensors will not provide an analog reading by will
 * provide one or more discrete states via the "state" property
 * in the facility propgroup.
 */
#define TOPO_SENSOR_CLASS_THRESHOLD     "threshold"
#define TOPO_SENSOR_CLASS_DISCRETE      "discrete"

/*
 * Sensor unit types.  We're using the unit types and corresponding
 * codes described in section 43.17 of the IPMI 2.0 as a reference as it seems
 * to be a reasonably comprehensive list.  This also simplifies the IPMI
 * facility provider code since the unit type codes will map exactly to what
 * libtopo uses (so no conversion necessary).  To allow for future growth if
 * new unit types are added to IPMI in the future, while still allowing unit
 * types not supported by IPMI to be represented, we include a gap between
 * the last IPMI unit type and the first non-IPMI unit type.
 */
typedef enum topo_sensor_unit {
        TOPO_SENSOR_UNITS_UNSPECIFIED = 0,
        TOPO_SENSOR_UNITS_DEGREES_C,
        TOPO_SENSOR_UNITS_DEGREES_F,
        TOPO_SENSOR_UNITS_DEGREES_K,
        TOPO_SENSOR_UNITS_VOLTS,
        TOPO_SENSOR_UNITS_AMPS,
        TOPO_SENSOR_UNITS_WATTS,
        TOPO_SENSOR_UNITS_JOULES,
        TOPO_SENSOR_UNITS_COULOMBS,
        TOPO_SENSOR_UNITS_VA,
        TOPO_SENSOR_UNITS_NITS,
        TOPO_SENSOR_UNITS_LUMEN,
        TOPO_SENSOR_UNITS_LUX,
        TOPO_SENSOR_UNITS_CANDELA,
        TOPO_SENSOR_UNITS_KPA,
        TOPO_SENSOR_UNITS_PSI,

        TOPO_SENSOR_UNITS_NEWTON,
        TOPO_SENSOR_UNITS_CFM,
        TOPO_SENSOR_UNITS_RPM,
        TOPO_SENSOR_UNITS_HZ,
        TOPO_SENSOR_UNITS_MICROSEC,
        TOPO_SENSOR_UNITS_MILLISEC,
        TOPO_SENSOR_UNITS_SECS,
        TOPO_SENSOR_UNITS_MIN,
        TOPO_SENSOR_UNITS_HOUR,
        TOPO_SENSOR_UNITS_DAY,
        TOPO_SENSOR_UNITS_WEEK,
        TOPO_SENSOR_UNITS_MIL,
        TOPO_SENSOR_UNITS_INCHES,
        TOPO_SENSOR_UNITS_FEET,
        TOPO_SENSOR_UNITS_CUB_INCH,
        TOPO_SENSOR_UNITS_CUB_FEET,

        TOPO_SENSOR_UNITS_MM,
        TOPO_SENSOR_UNITS_CM,
        TOPO_SENSOR_UNITS_METERS,
        TOPO_SENSOR_UNITS_CUB_CM,
        TOPO_SENSOR_UNITS_CUB_METER,
        TOPO_SENSOR_UNITS_LITERS,
        TOPO_SENSOR_UNITS_FLUID_OUNCE,
        TOPO_SENSOR_UNITS_RADIANS,
        TOPO_SENSOR_UNITS_STERADIANS,
        TOPO_SENSOR_UNITS_REVOLUTIONS,
        TOPO_SENSOR_UNITS_CYCLES,
        TOPO_SENSOR_UNITS_GRAVITIES,
        TOPO_SENSOR_UNITS_OUNCE,
        TOPO_SENSOR_UNITS_POUND,
        TOPO_SENSOR_UNITS_FOOT_POUND,
        TOPO_SENSOR_UNITS_OZ_INCH,

        TOPO_SENSOR_UNITS_GAUSS,
        TOPO_SENSOR_UNITS_GILBERTS,
        TOPO_SENSOR_UNITS_HENRY,
        TOPO_SENSOR_UNITS_MILHENRY,
        TOPO_SENSOR_UNITS_FARAD,
        TOPO_SENSOR_UNITS_MICROFARAD,
        TOPO_SENSOR_UNITS_OHMS,
        TOPO_SENSOR_UNITS_SIEMENS,
        TOPO_SENSOR_UNITS_MOLE,
        TOPO_SENSOR_UNITS_BECQUEREL,
        TOPO_SENSOR_UNITS_PPM,
        TOPO_SENSOR_UNITS_RESERVED1,
        TOPO_SENSOR_UNITS_DECIBELS,
        TOPO_SENSOR_UNITS_DBA,
        TOPO_SENSOR_UNITS_DBC,
        TOPO_SENSOR_UNITS_GRAY,

        TOPO_SENSOR_UNITS_SIEVERT,
        TOPO_SENSOR_UNITS_COLOR_TEMP_K,
        TOPO_SENSOR_UNITS_BIT,
        TOPO_SENSOR_UNITS_KILOBIT,
        TOPO_SENSOR_UNITS_MEGABIT,
        TOPO_SENSOR_UNITS_GIGABIT,
        TOPO_SENSOR_UNITS_BYTE,
        TOPO_SENSOR_UNITS_KILOBYTE,
        TOPO_SENSOR_UNITS_MEGABYTE,
        TOPO_SENSOR_UNITS_GIGABYTE,
        TOPO_SENSOR_UNITS_WORD,
        TOPO_SENSOR_UNITS_DWORD,
        TOPO_SENSOR_UNITS_QWORD,
        TOPO_SENSOR_UNITS_MEMLINE,
        TOPO_SENSOR_UNITS_HIT,
        TOPO_SENSOR_UNITS_MISS,

        TOPO_SENSOR_UNITS_RETRY,
        TOPO_SENSOR_UNITS_RESET,
        TOPO_SENSOR_UNITS_OVERFLOW,
        TOPO_SENSOR_UNITS_UNDERRUN,
        TOPO_SENSOR_UNITS_COLLISION,
        TOPO_SENSOR_UNITS_PACKETS,
        TOPO_SENSOR_UNITS_MESSAGES,
        TOPO_SENSOR_UNITS_CHARACTERS,
        TOPO_SENSOR_UNITS_ERROR,
        TOPO_SENSOR_UNITS_CE,
        TOPO_SENSOR_UNITS_UE,
        TOPO_SENSOR_UNITS_FATAL_ERROR,
        TOPO_SENSOR_UNITS_GRAMS,

        TOPO_SENSOR_UNITS_PERCENT = 512,
        /*
         * This is used for a unitless control type sensor.
         */
        TOPO_SENSOR_UNITS_NONE
} topo_sensor_unit_t;

/*
 * These defines are used by the topo_method_sensor_failure to indicate
 * whether the source of a sensor failure is believed to be the result of an
 * internal failure, external condition or unknown
 */
#define TOPO_SENSOR_ERRSRC_UNKNOWN      0
#define TOPO_SENSOR_ERRSRC_INTERNAL     1
#define TOPO_SENSOR_ERRSRC_EXTERNAL     2

/*
 * Sensor Types amd the associated sensor-type-specific states
 *
 * These are used to decode the type and state properties in the facility
 * propgroup on facility nodes of type sensor.
 *
 * Again we're basically using the same defines as listed in the IPMI
 * specification (see section 42) as it's serves as a good starting point and
 * simplifies the IPMI provider code.  Of course other facility providers will
 * need to convert from their native codes to the topo code when they set the
 * type and state properties.
 */
#define TOPO_SENSOR_TYPE_RESERVED                       0x0000
#define TOPO_SENSOR_TYPE_TEMP                           0x0001
#define TOPO_SENSOR_TYPE_VOLTAGE                        0x0002
#define TOPO_SENSOR_TYPE_CURRENT                        0x0003
#define TOPO_SENSOR_TYPE_FAN                            0x0004
#define TOPO_SENSOR_TYPE_PHYSICAL                       0x0005

#define TOPO_SENSOR_STATE_PHYSICAL_GENERAL              0x0001
#define TOPO_SENSOR_STATE_PHYSICAL_BAY                  0x0002
#define TOPO_SENSOR_STATE_PHYSICAL_CARD                 0x0004
#define TOPO_SENSOR_STATE_PHYSICAL_PROCESSOR            0x0008
#define TOPO_SENSOR_STATE_PHYSICAL_LAN                  0x0010
#define TOPO_SENSOR_STATE_PHYSICAL_DOCK                 0x0020
#define TOPO_SENSOR_STATE_PHYSICAL_FAN                  0x0040

#define TOPO_SENSOR_TYPE_PLATFORM                       0x0006

#define TOPO_SENSOR_STATE_PLATFORM_SECURE               0x0001
#define TOPO_SENSOR_STATE_PLATFORM_USER_PASS            0x0002
#define TOPO_SENSOR_STATE_PLATFORM_SETUP_PASS           0x0004
#define TOPO_SENSOR_STATE_PLATFORM_NETWORK_PASS         0x0008
#define TOPO_SENSOR_STATE_PLATFORM_OTHER_PASS           0x0010
#define TOPO_SENSOR_STATE_PLATFORM_OUT_OF_BAND          0x0020

#define TOPO_SENSOR_TYPE_PROCESSOR                      0x0007

#define TOPO_SENSOR_STATE_PROCESSOR_IERR                0x0001
#define TOPO_SENSOR_STATE_PROCESSOR_THERMAL             0x0002
#define TOPO_SENSOR_STATE_PROCESSOR_FRB1                0x0004
#define TOPO_SENSOR_STATE_PROCESSOR_FRB2                0x0008
#define TOPO_SENSOR_STATE_PROCESSOR_FRB3                0x0010
#define TOPO_SENSOR_STATE_PROCESSOR_CONFIG              0x0020
#define TOPO_SENSOR_STATE_PROCESSOR_SMBIOS              0x0040
#define TOPO_SENSOR_STATE_PROCESSOR_PRESENT             0x0080
#define TOPO_SENSOR_STATE_PROCESSOR_DISABLED            0x0100
#define TOPO_SENSOR_STATE_PROCESSOR_TERMINATOR          0x0200
#define TOPO_SENSOR_STATE_PROCESSOR_THROTTLED           0x0400

#define TOPO_SENSOR_TYPE_POWER_SUPPLY                   0x0008

#define TOPO_SENSOR_STATE_POWER_SUPPLY_PRESENT          0x0001
#define TOPO_SENSOR_STATE_POWER_SUPPLY_FAILURE          0x0002
#define TOPO_SENSOR_STATE_POWER_SUPPLY_PREDFAIL         0x0004
#define TOPO_SENSOR_STATE_POWER_SUPPLY_INPUT_LOST       0x0008
#define TOPO_SENSOR_STATE_POWER_SUPPLY_INPUT_RANGE      0x0010
#define TOPO_SENSOR_STATE_POWER_SUPPLY_INPUT_RANGE_PRES 0x0020
#define TOPO_SENSOR_STATE_POWER_SUPPLY_CONFIG_ERR       0x0040

#define TOPO_SENSOR_TYPE_POWER_UNIT                     0x0009

#define TOPO_SENSOR_STATE_POWER_UNIT_OFF                0x0001
#define TOPO_SENSOR_STATE_POWER_UNIT_CYCLE              0x0002
#define TOPO_SENSOR_STATE_POWER_UNIT_240_DOWN           0x0004
#define TOPO_SENSOR_STATE_POWER_UNIT_INTERLOCK_DOWN     0x0008
#define TOPO_SENSOR_STATE_POWER_UNIT_AC_LOST            0x0010
#define TOPO_SENSOR_STATE_POWER_UNIT_SOFT_FAILURE       0x0020
#define TOPO_SENSOR_STATE_POWER_UNIT_FAIL               0x0040
#define TOPO_SENSOR_STATE_POWER_UNIT_PREDFAIL           0x0080

#define TOPO_SENSOR_TYPE_COOLING                        0x000A
#define TOPO_SENSOR_TYPE_OTHER                          0x000B

#define TOPO_SENSOR_TYPE_MEMORY                         0x000C

#define TOPO_SENSOR_STATE_MEMORY_CE                     0x0001
#define TOPO_SENSOR_STATE_MEMORY_UE                     0x0002
#define TOPO_SENSOR_STATE_MEMORY_PARITY                 0x0004
#define TOPO_SENSOR_STATE_MEMORY_SCRUB_FAIL             0x0008
#define TOPO_SENSOR_STATE_MEMORY_DISABLED               0x0010
#define TOPO_SENSOR_STATE_MEMORY_CE_LOG_LIMIT           0x0020
#define TOPO_SENSOR_STATE_MEMORY_PRESENT                0x0040
#define TOPO_SENSOR_STATE_MEMORY_CONFIG_ERR             0x0080
#define TOPO_SENSOR_STATE_MEMORY_SPARE                  0x0100
#define TOPO_SENSOR_STATE_MEMORY_THROTTLED              0x0200
#define TOPO_SENSOR_STATE_MEMORY_OVERTEMP               0x0400

#define TOPO_SENSOR_TYPE_BAY                            0x000D

#define TOPO_SENSOR_STATE_BAY_PRESENT                   0x0001
#define TOPO_SENSOR_STATE_BAY_FAULT                     0x0002
#define TOPO_SENSOR_STATE_BAY_PREDFAIL                  0x0004
#define TOPO_SENSOR_STATE_BAY_SPARE                     0x0008
#define TOPO_SENSOR_STATE_BAY_CHECK                     0x0010
#define TOPO_SENSOR_STATE_BAY_CRITICAL                  0x0020
#define TOPO_SENSOR_STATE_BAY_FAILED                    0x0040
#define TOPO_SENSOR_STATE_BAY_REBUILDING                0x0080
#define TOPO_SENSOR_STATE_BAY_ABORTED                   0x0100

#define TOPO_SENSOR_TYPE_POST_RESIZE                    0x000E

#define TOPO_SENSOR_TYPE_FIRMWARE                       0x000F

#define TOPO_SENSOR_STATE_FIRMWARE_ERROR                0x0001
#define TOPO_SENSOR_STATE_FIRMWARE_HANG                 0x0002
#define TOPO_SENSOR_STATE_FIRMWARE_PROGRESS             0x0004

#define TOPO_SENSOR_TYPE_EVENT_LOG                      0x0010

#define TOPO_SENSOR_STATE_EVENT_LOG_CE                  0x0001
#define TOPO_SENSOR_STATE_EVENT_LOG_TYPE                0x0002
#define TOPO_SENSOR_STATE_EVENT_LOG_RESET               0x0004
#define TOPO_SENSOR_STATE_EVENT_LOG_ALL                 0x0008
#define TOPO_SENSOR_STATE_EVENT_LOG_FULL                0x0010
#define TOPO_SENSOR_STATE_EVENT_LOG_ALMOST_FULL         0x0020

#define TOPO_SENSOR_TYPE_WATCHDOG1                      0x0011

#define TOPO_SENSOR_STATE_WATCHDOG_BIOS_RESET           0x0001
#define TOPO_SENSOR_STATE_WATCHDOG_OS_RESET             0x0002
#define TOPO_SENSOR_STATE_WATCHDOG_OS_SHUTDOWN          0x0004
#define TOPO_SENSOR_STATE_WATCHDOG_OS_PWR_DOWN          0x0008
#define TOPO_SENSOR_STATE_WATCHDOG_OS_PWR_CYCLE         0x0010
#define TOPO_SENSOR_STATE_WATCHDOG_OS_NMI_DIAG          0x0020
#define TOPO_SENSOR_STATE_WATCHDOG_EXPIRED              0x0040
#define TOPO_SENSOR_STATE_WATCHDOG_PRE_TIMEOUT_INT      0x0080

#define TOPO_SENSOR_TYPE_SYSTEM                         0x0012

#define TOPO_SENSOR_STATE_SYSTEM_RECONF                 0x0001
#define TOPO_SENSOR_STATE_SYSTEM_BOOT                   0x0002
#define TOPO_SENSOR_STATE_SYSTEM_UNKNOWN_HW_FAILURE     0x0004
#define TOPO_SENSOR_STATE_SYSTEM_AUX_LOG_UPDATED        0x0008
#define TOPO_SENSOR_STATE_SYSTEM_PEF_ACTION             0x0010
#define TOPO_SENSOR_STATE_SYSTEM_TIMETAMP_CLOCKSYNC     0x0020

#define TOPO_SENSOR_TYPE_CRITICAL                       0x0013

#define TOPO_SENSOR_STATE_CRITICAL_EXT_NMI              0x0001
#define TOPO_SENSOR_STATE_CRITICAL_BUS_TIMEOUT          0x0002
#define TOPO_SENSOR_STATE_CRITICAL_IO_NMI               0x0004
#define TOPO_SENSOR_STATE_CRITICAL_SW_NMI               0x0008
#define TOPO_SENSOR_STATE_CRITICAL_PCI_PERR             0x0010
#define TOPO_SENSOR_STATE_CRITICAL_PCI_SERR             0x0020
#define TOPO_SENSOR_STATE_CRITICAL_EISA_FAILSAFE        0x0040
#define TOPO_SENSOR_STATE_CRITICAL_BUS_CE               0x0080
#define TOPO_SENSOR_STATE_CRITICAL_BUS_UE               0x0100
#define TOPO_SENSOR_STATE_CRITICAL_FATAL_NMI            0x0200
#define TOPO_SENSOR_STATE_CRITICAL_BUS_FATAL_ERR        0x0400
#define TOPO_SENSOR_STATE_CRITICAL_BUS_DEGRADED         0x0800

#define TOPO_SENSOR_TYPE_BUTTON                         0x0014

#define TOPO_SENSOR_STATE_BUTTON_PWR                    0x0001
#define TOPO_SENSOR_STATE_BUTTON_SLEEP                  0x0002
#define TOPO_SENSOR_STATE_BUTTON_RESET                  0x0004
#define TOPO_SENSOR_STATE_BUTTON_FRU_LATCH              0x0008
#define TOPO_SENSOR_STATE_BUTTON_FRU_SERVICE            0x0010

#define TOPO_SENSOR_TYPE_MODULE                         0x0015
#define TOPO_SENSOR_TYPE_MICROCONTROLLER                0x0016
#define TOPO_SENSOR_TYPE_CARD                           0x0017
#define TOPO_SENSOR_TYPE_CHASSIS                        0x0018

#define TOPO_SENSOR_TYPE_CHIPSET                        0x0019

#define TOPO_SENSOR_STATE_CHIPSET_PWR_CTL_FAIL          0x0001

#define TOPO_SENSOR_TYPE_FRU                            0x001A

#define TOPO_SENSOR_TYPE_CABLE                          0x001B

#define TOPO_SENSOR_STATE_CABLE_CONNECTED               0x0001
#define TOPO_SENSOR_STATE_CABLE_CONFIG_ERR              0x0002

#define TOPO_SENSOR_TYPE_TERMINATOR                     0x001C

#define TOPO_SENSOR_TYPE_BOOT_STATE                     0x001D

#define TOPO_SENSOR_STATE_BOOT_STATE_BIOS_PWR_UP        0x0001
#define TOPO_SENSOR_STATE_BOOT_STATE_BIOS_HARD_RESET    0x0002
#define TOPO_SENSOR_STATE_BOOT_STATE_BIOS_WARM_RESET    0x0004
#define TOPO_SENSOR_STATE_BOOT_STATE_PXE_BOOT           0x0008
#define TOPO_SENSOR_STATE_BOOT_STATE_DIAG_BOOT          0x0010
#define TOPO_SENSOR_STATE_BOOT_STATE_OS_HARD_RESET      0x0020
#define TOPO_SENSOR_STATE_BOOT_STATE_OS_WARM_RESET      0x0040
#define TOPO_SENSOR_STATE_BOOT_STATE_SYS_RESTART        0x0080

#define TOPO_SENSOR_TYPE_BOOT_ERROR                     0x001E

#define TOPO_SENSOR_STATE_BOOT_ERROR_NOMEDIA            0x0001
#define TOPO_SENSOR_STATE_BOOT_ERROR_NON_BOOTABLE_DISK  0x0002
#define TOPO_SENSOR_STATE_BOOT_ERROR_NO_PXE_SERVER      0x0004
#define TOPO_SENSOR_STATE_BOOT_ERROR_INV_BOOT_SECT      0x0008
#define TOPO_SENSOR_STATE_BOOT_ERROR_USR_SELECT_TIMEOUT 0x0010

#define TOPO_SENSOR_TYPE_BOOT_OS                        0x001F

#define TOPO_SENSOR_STATE_BOOT_OS_A_DRV_BOOT_COMPLETE   0x0001
#define TOPO_SENSOR_STATE_BOOT_OS_C_DRV_BOOT_COMPLETE   0x0002
#define TOPO_SENSOR_STATE_BOOT_OS_PXE_BOOT_COMPLETE     0x0004
#define TOPO_SENSOR_STATE_BOOT_OS_DIAG_BOOT_COMPLETE    0x0008
#define TOPO_SENSOR_STATE_BOOT_OS_CDROM_BOOT_COMPLETE   0x0010
#define TOPO_SENSOR_STATE_BOOT_OS_ROM_BOOT_COMPLETE     0x0020
#define TOPO_SENSOR_STATE_BOOT_OS_UNSPEC_BOOT_COMPLETE  0x0040

#define TOPO_SENSOR_TYPE_OS_SHUTDOWN                    0x0020

#define TOPO_SENSOR_STATE_OS_SHUTDOWN_LOADING           0x0001
#define TOPO_SENSOR_STATE_OS_SHUTDOWN_CRASH             0x0002
#define TOPO_SENSOR_STATE_OS_STOP_GRACEFUL              0x0004
#define TOPO_SENSOR_STATE_OS_SHUTDOWN_GRACEFUL          0x0008
#define TOPO_SENSOR_STATE_OS_SHUTDOWN_PEF               0x0010
#define TOPO_SENSOR_STATE_OS_SHUTDOWN_BMC               0x0020

#define TOPO_SENSOR_TYPE_SLOT                           0x0021

#define TOPO_SENSOR_STATE_SLOT_FAULT_ASSERTED           0x0001
#define TOPO_SENSOR_STATE_SLOT_IDENTIFY_ASSERTED        0x0002
#define TOPO_SENSOR_STATE_SLOT_CONNECTED                0x0004
#define TOPO_SENSOR_STATE_SLOT_INSTALL_READY            0x0008
#define TOPO_SENSOR_STATE_SLOT_REMOVE_READY             0x0010
#define TOPO_SENSOR_STATE_SLOT_PWR_OFF                  0x0020
#define TOPO_SENSOR_STATE_SLOT_REMOVED                  0x0040
#define TOPO_SENSOR_STATE_SLOT_INTERLOCK_ASSERTED       0x0080
#define TOPO_SENSOR_STATE_SLOT_DISABLED                 0x0100
#define TOPO_SENSOR_STATE_SLOT_SPARE_DEVICE             0x0200

#define TOPO_SENSOR_TYPE_ACPI                           0x0022

#define TOPO_SENSOR_STATE_ACPI_PSTATE_S0_G0             0x0001
#define TOPO_SENSOR_STATE_ACPI_PSTATE_S1                0x0002
#define TOPO_SENSOR_STATE_ACPI_PSTATE_S2                0x0004
#define TOPO_SENSOR_STATE_ACPI_PSTATE_S3                0x0008
#define TOPO_SENSOR_STATE_ACPI_PSTATE_S4                0x0010
#define TOPO_SENSOR_STATE_ACPI_PSTATE_S5_G2_SOFT_OFF    0x0020
#define TOPO_SENSOR_STATE_ACPI_PSTATE_S4_S5_SOFT_OFF    0x0040
#define TOPO_SENSOR_STATE_ACPI_PSATTE_G3_MECH_OFF       0x0080
#define TOPO_SENSOR_STATE_ACPI_PSTATE_S1_S2_S3_SLEEP    0x0100
#define TOPO_SENSOR_STATE_ACPI_PSTATE_G1_SLEEP          0x0200
#define TOPO_SENSOR_STATE_ACPI_PSTATE_S5_OVERRIDE       0x0400
#define TOPO_SENSOR_STATE_ACPI_PSTATE_LEGACY_ON         0x0800
#define TOPO_SENSOR_STATE_ACPI_PSTATE_LEGACY_OFF        0x1000
#define TOPO_SENSOR_STATE_ACPI_PSTATE_UNKNOWN           0x2000

#define TOPO_SENSOR_TYPE_WATCHDOG2                      0x0023

#define TOPO_SENSOR_STATE_WATCHDOG2_EXPIRED             0x0001
#define TOPO_SENSOR_STATE_WATCHDOG2_HARD_RESET          0x0002
#define TOPO_SENSOR_STATE_WATCHDOG2_PWR_DOWN            0x0004
#define TOPO_SENSOR_STATE_WATCHDOG2_PWR_CYCLE           0x0008
#define TOPO_SENSOR_STATE_WATCHDOG2_RESERVED1           0x0010
#define TOPO_SENSOR_STATE_WATCHDOG2_RESERVED2           0x0020
#define TOPO_SENSOR_STATE_WATCHDOG2_RESERVED3           0x0040
#define TOPO_SENSOR_STATE_WATCHDOG2_RESERVED4           0x0080
#define TOPO_SENSOR_STATE_WATCHDOG2_TIMEOUT_INT         0x0100

#define TOPO_SENSOR_TYPE_ALERT                          0x0024

#define TOPO_SENSOR_STATE_ALERT_PLAT_PAGE               0x0001
#define TOPO_SENSOR_STATE_ALERT_PLAT_LAN_ALERT          0x0002
#define TOPO_SENSOR_STATE_ALERT_PLAT_EVT_TRAP           0x0004
#define TOPO_SENSOR_STATE_ALERT_PLAT_SNMP_TRAP          0x0008

#define TOPO_SENSOR_TYPE_PRESENCE                       0x0025

#define TOPO_SENSOR_STATE_PRESENCE_PRESENT              0x0001
#define TOPO_SENSOR_STATE_PRESENCE_ABSENT               0x0002
#define TOPO_SENSOR_STATE_PRESENCE_DISABLED             0x0004

#define TOPO_SENSOR_TYPE_ASIC                           0x0026

#define TOPO_SENSOR_TYPE_LAN                            0x0027

#define TOPO_SENSOR_STATE_LAN_HEARTBEAT_LOST            0x0001
#define TOPO_SENSOR_STATE_LAN_HEARTBEAT                 0x0002

#define TOPO_SENSOR_TYPE_HEALTH                         0x0028

#define TOPO_SENSOR_STATE_HEALTH_SENSOR_ACC_DEGRADED    0x0001
#define TOPO_SENSOR_STATE_HEALTH_CNTLR_ACC_DEGRADED     0x0002
#define TOPO_SENSOR_STATE_HEALTH_CNTLR_OFFLINE          0x0004
#define TOPO_SENSOR_STATE_HEALTH_CNTLR_UNAVAIL          0x0008
#define TOPO_SENSOR_STATE_HEALTH_SENSOR_FAILURE         0x0010
#define TOPO_SENSOR_STATE_HEALTH_FRU_FAILURE            0x0020

#define TOPO_SENSOR_TYPE_BATTERY                        0x0029

#define TOPO_SENSOR_STATE_BATTERY_LOW                   0x0001
#define TOPO_SENSOR_STATE_BATTERY_FAILED                0x0002
#define TOPO_SENSOR_STATE_BATTERY_PRESENCE              0x0004

#define TOPO_SENSOR_TYPE_AUDIT                          0x002A

#define TOPO_SENSOR_STATE_AUDIT_SESSION_ACTIVATED       0x0001
#define TOPO_SENSOR_STATE_AUDIT_SESSION_DEACTIVATED     0x0002

#define TOPO_SENSOR_TYPE_VERSION                        0x002B

#define TOPO_SENSOR_STATE_VERSION_HW_CHANGE             0x0001
#define TOPO_SENSOR_STATE_VERSION_SW_CHANGE             0x0002
#define TOPO_SENSOR_STATE_VERSION_HW_INCOMPATIBLE       0x0004
#define TOPO_SENSOR_STATE_VERSION_SW_INCOMPATIBLE       0x0008
#define TOPO_SENSOR_STATE_VERSION_HW_INVAL              0x0010
#define TOPO_SENSOR_STATE_VERSION_SW_INVAL              0x0020
#define TOPO_SENSOR_STATE_VERSION_HW_CHANGE_SUCCESS     0x0040
#define TOPO_SENSOR_STATE_VERSION_SW_CHANGE_SUCCESS     0x0080

#define TOPO_SENSOR_TYPE_FRU_STATE                      0x002C

#define TOPO_SENSOR_STATE_FRU_STATE_NOT_INSTALLED       0x0001
#define TOPO_SENSOR_STATE_FRU_STATE_INACTIVE            0x0002
#define TOPO_SENSOR_STATE_FRU_STATE_ACT_REQ             0x0004
#define TOPO_SENSOR_STATE_FRU_STATE_ACT_INPROGRESS      0x0008
#define TOPO_SENSOR_STATE_FRU_STATE_ACTIVE              0x0010
#define TOPO_SENSOR_STATE_FRU_STATE_DEACT_REQ           0x0020
#define TOPO_SENSOR_STATE_FRU_STATE_DEACT_INPROGRESS    0x0040
#define TOPO_SENSOR_STATE_FRU_STATE_COMM_LOST           0x0080

/*
 * We simplify the IPMI sensor type code defines by combining the generic
 * and sensor-specific codes into a single range.  Because there's overlap
 * between the two ranges we offset the generic type codes by 0x0100
 * which allows ample room in the hole for future expansion of the table to
 * accommodate either additions to the IPMI spec or to support new sensor types
 * for alternate provider modules.
 */
#define TOPO_SENSOR_TYPE_THRESHOLD_STATE                0x0101

#define TOPO_SENSOR_STATE_THRESH_LOWER_NONCRIT          0x0001
#define TOPO_SENSOR_STATE_THRESH_LOWER_CRIT             0x0002
#define TOPO_SENSOR_STATE_THRESH_LOWER_NONREC           0x0004
#define TOPO_SENSOR_STATE_THRESH_UPPER_NONCRIT          0x0008
#define TOPO_SENSOR_STATE_THRESH_UPPER_CRIT             0x0010
#define TOPO_SENSOR_STATE_THRESH_UPPER_NONREC           0x0020

#define TOPO_SENSOR_TYPE_GENERIC_USAGE                  0x0102

#define TOPO_SENSOR_STATE_GENERIC_USAGE_IDLE            0x0001
#define TOPO_SENSOR_STATE_GENERIC_USAGE_ACTIVE          0x0002
#define TOPO_SENSOR_STATE_GENERIC_USAGE_BUSY            0x0004

#define TOPO_SENSOR_TYPE_GENERIC_STATE                  0x0103

#define TOPO_SENSOR_STATE_GENERIC_STATE_DEASSERTED      0x0001
#define TOPO_SENSOR_STATE_GENERIC_STATE_ASSERTED        0x0002

#define TOPO_SENSOR_TYPE_GENERIC_PREDFAIL               0x0104

#define TOPO_SENSOR_STATE_GENERIC_PREDFAIL_DEASSERTED   0x0001
#define TOPO_SENSOR_STATE_GENERIC_PREDFAIL_ASSERTED     0x0002

#define TOPO_SENSOR_TYPE_GENERIC_LIMIT                  0x0105

#define TOPO_SENSOR_STATE_GENERIC_LIMIT_NOT_EXCEEDED    0x0001
#define TOPO_SENSOR_STATE_GENERIC_LIMIT_EXCEEDED        0x0002

#define TOPO_SENSOR_TYPE_GENERIC_PERFORMANCE            0x0106

#define TOPO_SENSOR_STATE_GENERIC_PERFORMANCE_MET       0x0001
#define TOPO_SENSOR_STATE_GENERIC_PERFORMANCE_LAGS      0x0002

#define TOPO_SENSOR_TYPE_SEVERITY                       0x0107

#define TOPO_SENSOR_STATE_SEVERITY_OK                   0x0001
#define TOPO_SENSOR_STATE_SEVERITY_NONCRIT_GOING_HIGH   0x0002
#define TOPO_SENSOR_STATE_SEVERITY_CRIT_GOING_HIGH      0x0004
#define TOPO_SENSOR_STATE_SEVERITY_NONREC_GOING_HIGH    0x0008
#define TOPO_SENSOR_STATE_SEVERITY_NONCRIT_GOING_LOW    0x0010
#define TOPO_SENSOR_STATE_SEVERITY_CRIT_GOING_LOW       0x0020
#define TOPO_SENSOR_STATE_SEVERITY_NONREC_GOING_LOW     0x0020
#define TOPO_SENSOR_STATE_SEVERITY_MONITOR              0x0040
#define TOPO_SENSOR_STATE_SEVERITY_INFORMATIONAL        0x0080

#define TOPO_SENSOR_TYPE_GENERIC_PRESENCE               0x0108

#define TOPO_SENSOR_STATE_GENERIC_PRESENCE_DEASSERTED   0x0001
#define TOPO_SENSOR_STATE_GENERIC_PRESENCE_ASSERTED     0x0002

#define TOPO_SENSOR_TYPE_GENERIC_AVAILABILITY           0x0109

#define TOPO_SENSOR_STATE_GENERIC_AVAIL_DEASSERTED      0x0001
#define TOPO_SENSOR_STATE_GENERIC_AVAIL_ASSERTED        0x0002

#define TOPO_SENSOR_TYPE_GENERIC_STATUS                 0x010A

#define TOPO_SENSOR_STATE_GENERIC_STATUS_RUNNING        0x0001
#define TOPO_SENSOR_STATE_GENERIC_STATUS_IN_TEST        0x0002
#define TOPO_SENSOR_STATE_GENERIC_STATUS_POWER_OFF      0x0004
#define TOPO_SENSOR_STATE_GENERIC_STATUS_ONLINE         0x0008
#define TOPO_SENSOR_STATE_GENERIC_STATUS_OFFLINE        0x0010
#define TOPO_SENSOR_STATE_GENERIC_STATUS_OFF_DUTY       0x0020
#define TOPO_SENSOR_STATE_GENERIC_STATUS_DEGRADED       0x0040
#define TOPO_SENSOR_STATE_GENERIC_STATUS_POWER_SAVE     0x0080
#define TOPO_SENSOR_STATE_GENERIC_STATUS_INSTALL_ERR    0x0100

#define TOPO_SENSOR_TYPE_GENERIC_REDUNDANCY             0x010B

/*
 * ACPI power state
 */
#define TOPO_SENSOR_TYPE_GENERIC_ACPI                   0x010C

#define TOPO_SENSOR_STATE_GENERIC_ACPI_D0               0x0001
#define TOPO_SENSOR_STATE_GENERIC_ACPI_D1               0x0002
#define TOPO_SENSOR_STATE_GENERIC_ACPI_D2               0x0004
#define TOPO_SENSOR_STATE_GENERIC_ACPI_D3               0x0008

/*
 * These sensor types don't exist in the IPMI spec, but allow consumers to
 * associate discrete sensors with component failure.  The 'ok' sensor is the
 * inverse of the 'failure' sensor.  Note that the values intentionally mimic
 * TOPO_SENSOR_TYPE_GENERIC_STATE, so that you can use existing IPMI sensors
 * but just change the type to get semantically meaningful behavior.
 */
#define TOPO_SENSOR_TYPE_GENERIC_FAILURE                0x010D

#define TOPO_SENSOR_STATE_GENERIC_FAIL_DEASSERTED       0x0001
#define TOPO_SENSOR_STATE_GENERIC_FAIL_NONRECOV         0x0002
#define TOPO_SENSOR_STATE_GENERIC_FAIL_CRITICAL         0x0004

#define TOPO_SENSOR_TYPE_GENERIC_OK                     0x010E

#define TOPO_SENSOR_STATE_GENERIC_OK_DEASSERTED         0x0001
#define TOPO_SENSOR_STATE_GENERIC_OK_ASSERTED           0x0002

/*
 * This represents a synthetic sensor that someone has created. That is, it has
 * a value, but does not represent a true physical measurement of some kind. The
 * most common example of this is a control-style measurement.
 */
#define TOPO_SENSOR_TYPE_SYNTHETIC                      0x10F

/*
 * Indicator modes and types
 */
typedef enum topo_led_state {
        TOPO_LED_STATE_OFF = 0,
        TOPO_LED_STATE_ON
} topo_led_state_t;

#define TOPO_FAC_TYPE_ANY       0xFFFFFFFF

/*
 * This list is limited to the set of LED's that we're likely to manage through
 * FMA.  Thus is does not include things like power or activity LED's
 */
typedef enum topo_led_type {
        TOPO_LED_TYPE_SERVICE = 0,
        TOPO_LED_TYPE_LOCATE,
        TOPO_LED_TYPE_OK2RM,
        TOPO_LED_TYPE_PRESENT
} topo_led_type_t;

typedef enum topo_slot_type {
        TOPO_SLOT_TYPE_DIMM = 1,
        TOPO_SLOT_TYPE_UFM,
        TOPO_SLOT_TYPE_M2
} topo_slot_type_t;

/*
 * Read permission indicates that we can read the raw firmware image in this
 * slot off of the device.
 *
 * Write permission indicates that we can write a firmware image into this
 * slot.
 *
 * These permission are orthogonal to the ability to simply report information
 * about the firmware image in a slot.
 */
typedef enum topo_ufm_slot_mode {
        TOPO_UFM_SLOT_MODE_NONE = 1,
        TOPO_UFM_SLOT_MODE_RO,
        TOPO_UFM_SLOT_MODE_WO,
        TOPO_UFM_SLOT_MODE_RW
} topo_ufm_slot_mode_t;

typedef struct topo_ufm_slot_info {
        uint32_t usi_slotid;
        topo_ufm_slot_mode_t usi_mode;
        const char *usi_version;
        boolean_t usi_active;
        nvlist_t *usi_extra;
} topo_ufm_slot_info_t;

#ifdef __cplusplus
}
#endif

#endif /* _LIBTOPO_H */