1*8537SEric.Schrock@Sun.COM /*
2*8537SEric.Schrock@Sun.COM * CDDL HEADER START
3*8537SEric.Schrock@Sun.COM *
4*8537SEric.Schrock@Sun.COM * The contents of this file are subject to the terms of the
5*8537SEric.Schrock@Sun.COM * Common Development and Distribution License (the "License").
6*8537SEric.Schrock@Sun.COM * You may not use this file except in compliance with the License.
7*8537SEric.Schrock@Sun.COM *
8*8537SEric.Schrock@Sun.COM * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9*8537SEric.Schrock@Sun.COM * or http://www.opensolaris.org/os/licensing.
10*8537SEric.Schrock@Sun.COM * See the License for the specific language governing permissions
11*8537SEric.Schrock@Sun.COM * and limitations under the License.
12*8537SEric.Schrock@Sun.COM *
13*8537SEric.Schrock@Sun.COM * When distributing Covered Code, include this CDDL HEADER in each
14*8537SEric.Schrock@Sun.COM * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15*8537SEric.Schrock@Sun.COM * If applicable, add the following below this CDDL HEADER, with the
16*8537SEric.Schrock@Sun.COM * fields enclosed by brackets "[]" replaced with your own identifying
17*8537SEric.Schrock@Sun.COM * information: Portions Copyright [yyyy] [name of copyright owner]
18*8537SEric.Schrock@Sun.COM *
19*8537SEric.Schrock@Sun.COM * CDDL HEADER END
20*8537SEric.Schrock@Sun.COM */
21*8537SEric.Schrock@Sun.COM
22*8537SEric.Schrock@Sun.COM /*
23*8537SEric.Schrock@Sun.COM * Copyright 2009 Sun Microsystems, Inc. All rights reserved.
24*8537SEric.Schrock@Sun.COM * Use is subject to license terms.
25*8537SEric.Schrock@Sun.COM */
26*8537SEric.Schrock@Sun.COM
27*8537SEric.Schrock@Sun.COM #include <fm/fmd_fmri.h>
28*8537SEric.Schrock@Sun.COM #include <fm/libtopo.h>
29*8537SEric.Schrock@Sun.COM #include <fm/topo_mod.h>
30*8537SEric.Schrock@Sun.COM #include <string.h>
31*8537SEric.Schrock@Sun.COM #include <sys/fm/protocol.h>
32*8537SEric.Schrock@Sun.COM
33*8537SEric.Schrock@Sun.COM int
fmd_fmri_init(void)34*8537SEric.Schrock@Sun.COM fmd_fmri_init(void)
35*8537SEric.Schrock@Sun.COM {
36*8537SEric.Schrock@Sun.COM return (0);
37*8537SEric.Schrock@Sun.COM }
38*8537SEric.Schrock@Sun.COM
39*8537SEric.Schrock@Sun.COM void
fmd_fmri_fini(void)40*8537SEric.Schrock@Sun.COM fmd_fmri_fini(void)
41*8537SEric.Schrock@Sun.COM {
42*8537SEric.Schrock@Sun.COM }
43*8537SEric.Schrock@Sun.COM
44*8537SEric.Schrock@Sun.COM ssize_t
fmd_fmri_nvl2str(nvlist_t * nvl,char * buf,size_t buflen)45*8537SEric.Schrock@Sun.COM fmd_fmri_nvl2str(nvlist_t *nvl, char *buf, size_t buflen)
46*8537SEric.Schrock@Sun.COM {
47*8537SEric.Schrock@Sun.COM int err;
48*8537SEric.Schrock@Sun.COM ssize_t len;
49*8537SEric.Schrock@Sun.COM topo_hdl_t *thp;
50*8537SEric.Schrock@Sun.COM char *str;
51*8537SEric.Schrock@Sun.COM
52*8537SEric.Schrock@Sun.COM if ((thp = fmd_fmri_topo_hold(TOPO_VERSION)) == NULL)
53*8537SEric.Schrock@Sun.COM return (fmd_fmri_set_errno(EINVAL));
54*8537SEric.Schrock@Sun.COM
55*8537SEric.Schrock@Sun.COM if (topo_fmri_nvl2str(thp, nvl, &str, &err) != 0) {
56*8537SEric.Schrock@Sun.COM fmd_fmri_topo_rele(thp);
57*8537SEric.Schrock@Sun.COM return (fmd_fmri_set_errno(EINVAL));
58*8537SEric.Schrock@Sun.COM }
59*8537SEric.Schrock@Sun.COM
60*8537SEric.Schrock@Sun.COM if (buf != NULL)
61*8537SEric.Schrock@Sun.COM len = snprintf(buf, buflen, "%s", str);
62*8537SEric.Schrock@Sun.COM else
63*8537SEric.Schrock@Sun.COM len = strlen(str);
64*8537SEric.Schrock@Sun.COM
65*8537SEric.Schrock@Sun.COM topo_hdl_strfree(thp, str);
66*8537SEric.Schrock@Sun.COM fmd_fmri_topo_rele(thp);
67*8537SEric.Schrock@Sun.COM
68*8537SEric.Schrock@Sun.COM return (len);
69*8537SEric.Schrock@Sun.COM }
70*8537SEric.Schrock@Sun.COM
71*8537SEric.Schrock@Sun.COM /*ARGSUSED*/
72*8537SEric.Schrock@Sun.COM int
fmd_fmri_present(nvlist_t * nvl)73*8537SEric.Schrock@Sun.COM fmd_fmri_present(nvlist_t *nvl)
74*8537SEric.Schrock@Sun.COM {
75*8537SEric.Schrock@Sun.COM uint8_t version;
76*8537SEric.Schrock@Sun.COM int err, present;
77*8537SEric.Schrock@Sun.COM topo_hdl_t *thp;
78*8537SEric.Schrock@Sun.COM
79*8537SEric.Schrock@Sun.COM if (nvlist_lookup_uint8(nvl, FM_VERSION, &version) != 0 ||
80*8537SEric.Schrock@Sun.COM version > FM_SVC_SCHEME_VERSION)
81*8537SEric.Schrock@Sun.COM return (fmd_fmri_set_errno(EINVAL));
82*8537SEric.Schrock@Sun.COM
83*8537SEric.Schrock@Sun.COM if ((thp = fmd_fmri_topo_hold(TOPO_VERSION)) == NULL)
84*8537SEric.Schrock@Sun.COM return (fmd_fmri_set_errno(EINVAL));
85*8537SEric.Schrock@Sun.COM present = topo_fmri_present(thp, nvl, &err);
86*8537SEric.Schrock@Sun.COM fmd_fmri_topo_rele(thp);
87*8537SEric.Schrock@Sun.COM
88*8537SEric.Schrock@Sun.COM return (present);
89*8537SEric.Schrock@Sun.COM }
90*8537SEric.Schrock@Sun.COM
91*8537SEric.Schrock@Sun.COM int
fmd_fmri_replaced(nvlist_t * nvl)92*8537SEric.Schrock@Sun.COM fmd_fmri_replaced(nvlist_t *nvl)
93*8537SEric.Schrock@Sun.COM {
94*8537SEric.Schrock@Sun.COM uint8_t version;
95*8537SEric.Schrock@Sun.COM int err, replaced;
96*8537SEric.Schrock@Sun.COM topo_hdl_t *thp;
97*8537SEric.Schrock@Sun.COM
98*8537SEric.Schrock@Sun.COM if (nvlist_lookup_uint8(nvl, FM_VERSION, &version) != 0 ||
99*8537SEric.Schrock@Sun.COM version > FM_SVC_SCHEME_VERSION)
100*8537SEric.Schrock@Sun.COM return (fmd_fmri_set_errno(EINVAL));
101*8537SEric.Schrock@Sun.COM
102*8537SEric.Schrock@Sun.COM if ((thp = fmd_fmri_topo_hold(TOPO_VERSION)) == NULL)
103*8537SEric.Schrock@Sun.COM return (fmd_fmri_set_errno(EINVAL));
104*8537SEric.Schrock@Sun.COM replaced = topo_fmri_replaced(thp, nvl, &err);
105*8537SEric.Schrock@Sun.COM fmd_fmri_topo_rele(thp);
106*8537SEric.Schrock@Sun.COM
107*8537SEric.Schrock@Sun.COM return (replaced);
108*8537SEric.Schrock@Sun.COM }
109*8537SEric.Schrock@Sun.COM
110*8537SEric.Schrock@Sun.COM int
fmd_fmri_service_state(nvlist_t * nvl)111*8537SEric.Schrock@Sun.COM fmd_fmri_service_state(nvlist_t *nvl)
112*8537SEric.Schrock@Sun.COM {
113*8537SEric.Schrock@Sun.COM uint8_t version;
114*8537SEric.Schrock@Sun.COM int err, service_state;
115*8537SEric.Schrock@Sun.COM topo_hdl_t *thp;
116*8537SEric.Schrock@Sun.COM
117*8537SEric.Schrock@Sun.COM if (nvlist_lookup_uint8(nvl, FM_VERSION, &version) != 0 ||
118*8537SEric.Schrock@Sun.COM version > FM_DEV_SCHEME_VERSION)
119*8537SEric.Schrock@Sun.COM return (fmd_fmri_set_errno(EINVAL));
120*8537SEric.Schrock@Sun.COM
121*8537SEric.Schrock@Sun.COM if ((thp = fmd_fmri_topo_hold(TOPO_VERSION)) == NULL)
122*8537SEric.Schrock@Sun.COM return (fmd_fmri_set_errno(EINVAL));
123*8537SEric.Schrock@Sun.COM err = 0;
124*8537SEric.Schrock@Sun.COM service_state = topo_fmri_service_state(thp, nvl, &err);
125*8537SEric.Schrock@Sun.COM fmd_fmri_topo_rele(thp);
126*8537SEric.Schrock@Sun.COM
127*8537SEric.Schrock@Sun.COM if (err != 0)
128*8537SEric.Schrock@Sun.COM return (FMD_SERVICE_STATE_UNKNOWN);
129*8537SEric.Schrock@Sun.COM else
130*8537SEric.Schrock@Sun.COM return (service_state);
131*8537SEric.Schrock@Sun.COM }
132*8537SEric.Schrock@Sun.COM
133*8537SEric.Schrock@Sun.COM /*ARGSUSED*/
134*8537SEric.Schrock@Sun.COM int
fmd_fmri_unusable(nvlist_t * nvl)135*8537SEric.Schrock@Sun.COM fmd_fmri_unusable(nvlist_t *nvl)
136*8537SEric.Schrock@Sun.COM {
137*8537SEric.Schrock@Sun.COM uint8_t version;
138*8537SEric.Schrock@Sun.COM int err, unusable;
139*8537SEric.Schrock@Sun.COM topo_hdl_t *thp;
140*8537SEric.Schrock@Sun.COM
141*8537SEric.Schrock@Sun.COM if (nvlist_lookup_uint8(nvl, FM_VERSION, &version) != 0 ||
142*8537SEric.Schrock@Sun.COM version > FM_SVC_SCHEME_VERSION)
143*8537SEric.Schrock@Sun.COM return (fmd_fmri_set_errno(EINVAL));
144*8537SEric.Schrock@Sun.COM
145*8537SEric.Schrock@Sun.COM if ((thp = fmd_fmri_topo_hold(TOPO_VERSION)) == NULL)
146*8537SEric.Schrock@Sun.COM return (fmd_fmri_set_errno(EINVAL));
147*8537SEric.Schrock@Sun.COM unusable = topo_fmri_unusable(thp, nvl, &err);
148*8537SEric.Schrock@Sun.COM fmd_fmri_topo_rele(thp);
149*8537SEric.Schrock@Sun.COM
150*8537SEric.Schrock@Sun.COM return (unusable == 1 ? 1 : 0);
151*8537SEric.Schrock@Sun.COM }
152