xref: /titanic_50/usr/src/uts/common/avs/ns/nsctl/nsc_trap.c (revision aab83bb83be7342f6cfccaed8d5fe0b2f404855d)
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