1 /*
2 * CDDL HEADER START
3 *
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.
7 *
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.
12 *
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]
18 *
19 * CDDL HEADER END
20 */
21 /*
22 * Copyright 2009 Sun Microsystems, Inc. All rights reserved.
23 * Use is subject to license terms.
24 */
25
26 #include <sys/ddi.h>
27 #include <sys/sunddi.h>
28
29 #ifdef DS_DDICT
30 #include "../contract.h"
31 #endif
32
33 #define SVE_STE_CLASS "SVE_STE"
34 #define SVE_II_CLASS "SVE_II"
35 #define SVE_CACHE_CLASS "SVE_CACHE"
36
37 void
nsc_do_sysevent(char * driver_name,char * trap_messages,int errorno,int alertlevel,char * component,dev_info_t * info_dip)38 nsc_do_sysevent(char *driver_name, char *trap_messages, int errorno,
39 int alertlevel, char *component, dev_info_t *info_dip)
40 {
41 #if !defined(DS_DDICT) && !defined(_SunOS_5_6) && \
42 !defined(_SunOS_5_7) && !defined(_SunOS_5_8)
43
44 nvlist_t *attr_list;
45 int rc;
46
47 attr_list = NULL;
48 rc = nvlist_alloc(&attr_list, NV_UNIQUE_NAME_TYPE, KM_SLEEP);
49 if (rc != 0) {
50 goto out;
51 }
52 rc = nvlist_add_int32(attr_list, "alertlevel", alertlevel);
53 if (rc != 0) {
54 goto out;
55 }
56 rc = nvlist_add_string(attr_list, "messagevalue", trap_messages);
57 if (rc != 0) {
58 goto out;
59 }
60 rc = nvlist_add_int32(attr_list, "errorno", errorno);
61 if (rc != 0) {
62 goto out;
63 }
64 if (strcmp(driver_name, "sdbc") == 0)
65 rc = ddi_log_sysevent(info_dip, DDI_VENDOR_SUNW,
66 SVE_CACHE_CLASS, component, attr_list, NULL, DDI_SLEEP);
67 else if (strcmp(driver_name, "ste") == 0)
68 rc = ddi_log_sysevent(info_dip, DDI_VENDOR_SUNW,
69 SVE_STE_CLASS, component, attr_list, NULL, DDI_SLEEP);
70 else if (strcmp(driver_name, "ii") == 0)
71 rc = ddi_log_sysevent(info_dip, DDI_VENDOR_SUNW,
72 SVE_II_CLASS, component, attr_list, NULL, DDI_SLEEP);
73 out:
74 nvlist_free(attr_list);
75
76 if (rc != 0) {
77 cmn_err(CE_WARN, "!%s: unable to log sysevent %d:%s and %d",
78 driver_name, errorno, trap_messages, alertlevel);
79 }
80 #endif /* which O/S? */
81 }
82