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]
23 * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
24 * Use is subject to license terms.
27 #pragma ident "%Z%%M% %I% %E% SMI"
29 #include <fm/fmd_fmri.h>
30 #include <fm/libtopo.h>
31 #include <fm/topo_mod.h>
32 #include <libdevinfo.h>
48 fmd_fmri_nvl2str(nvlist_t
*nvl
, char *buf
, size_t buflen
)
55 if ((thp
= fmd_fmri_topo_hold(TOPO_VERSION
)) == NULL
)
56 return (fmd_fmri_set_errno(EINVAL
));
58 if (topo_fmri_nvl2str(thp
, nvl
, &str
, &err
) != 0) {
59 fmd_fmri_topo_rele(thp
);
60 return (fmd_fmri_set_errno(EINVAL
));
64 len
= snprintf(buf
, buflen
, "%s", str
);
68 topo_hdl_strfree(thp
, str
);
69 fmd_fmri_topo_rele(thp
);
75 fmd_fmri_present(nvlist_t
*nvl
)
80 if ((thp
= fmd_fmri_topo_hold(TOPO_VERSION
)) == NULL
)
81 return (fmd_fmri_set_errno(EINVAL
));
83 present
= topo_fmri_present(thp
, nvl
, &err
);
84 fmd_fmri_topo_rele(thp
);
90 fmd_fmri_replaced(nvlist_t
*nvl
)
95 if ((thp
= fmd_fmri_topo_hold(TOPO_VERSION
)) == NULL
)
96 return (fmd_fmri_set_errno(EINVAL
));
98 rval
= topo_fmri_replaced(thp
, nvl
, &err
);
99 fmd_fmri_topo_rele(thp
);
105 fmd_fmri_unusable(nvlist_t
*nvl
)
111 if (nvlist_lookup_uint8(nvl
, FM_VERSION
, &version
) != 0 ||
112 version
> FM_DEV_SCHEME_VERSION
)
113 return (fmd_fmri_set_errno(EINVAL
));
115 if ((thp
= fmd_fmri_topo_hold(TOPO_VERSION
)) == NULL
)
116 return (fmd_fmri_set_errno(EINVAL
));
118 unusable
= topo_fmri_unusable(thp
, nvl
, &err
);
119 fmd_fmri_topo_rele(thp
);
128 fmd_fmri_service_state(nvlist_t
*nvl
)
131 int err
, service_state
;
134 if (nvlist_lookup_uint8(nvl
, FM_VERSION
, &version
) != 0 ||
135 version
> FM_DEV_SCHEME_VERSION
)
136 return (fmd_fmri_set_errno(EINVAL
));
138 if ((thp
= fmd_fmri_topo_hold(TOPO_VERSION
)) == NULL
)
139 return (fmd_fmri_set_errno(EINVAL
));
141 service_state
= topo_fmri_service_state(thp
, nvl
, &err
);
142 fmd_fmri_topo_rele(thp
);
145 return (FMD_SERVICE_STATE_UNKNOWN
);
147 return (service_state
);