Mercurial > illumos > illumos-gate
annotate usr/src/cmd/fm/fmadm/common/faulty.c @ 10928:eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
6874078 fminject should always add __injected payload
6874080 fmd_case_add_ereport() should add any __injected payload from ereports into the suspect list
6796601 fmadm faulty doesn't show the year when events happen
6820523 fmdump -V should display the complete time for all files, not just errlog files
6881060 Subdirectories in /var/fm/fmd/ have overly restrictive permissions
6890955 oodles of FMA messages upon fmd start-up
author | Stephen Hanson <Stephen.Hanson@Sun.COM> |
---|---|
date | Mon, 02 Nov 2009 09:11:35 -0800 |
parents | 217544b3cf73 |
children | be69f645ce17 |
rev | line source |
---|---|
0 | 1 /* |
2 * CDDL HEADER START | |
3 * | |
4 * The contents of this file are subject to the terms of the | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
5 * Common Development and Distribution License (the "License"). |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
6 * You may not use this file except in compliance with the License. |
0 | 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 /* | |
9120
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
22 * Copyright 2009 Sun Microsystems, Inc. All rights reserved. |
0 | 23 * Use is subject to license terms. |
24 */ | |
25 | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
26 #include <sys/types.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
27 #include <fmadm.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
28 #include <errno.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
29 #include <limits.h> |
0 | 30 #include <strings.h> |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
31 #include <stdio.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
32 #include <unistd.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
33 #include <sys/wait.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
34 #include <sys/stat.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
35 #include <fcntl.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
36 #include <fm/fmd_log.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
37 #include <sys/fm/protocol.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
38 #include <fm/libtopo.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
39 #include <fm/fmd_adm.h> |
9501
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
40 #include <fm/fmd_msg.h> |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
41 #include <dlfcn.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
42 #include <sys/systeminfo.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
43 #include <sys/utsname.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
44 #include <libintl.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
45 #include <locale.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
46 #include <sys/smbios.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
47 #include <libdevinfo.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
48 #include <stdlib.h> |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
49 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
50 #define offsetof(s, m) ((size_t)(&(((s*)0)->m))) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
51 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
52 /* |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
53 * Fault records are added to catalog by calling add_fault_record_to_catalog() |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
54 * records are stored in order of importance to the system. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
55 * If -g flag is set or not_suppressed is not set and the class fru, fault, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
56 * type are the same then details are merged into an existing record, with uuid |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
57 * records are stored in time order. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
58 * For each record information is extracted from nvlist and merged into linked |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
59 * list each is checked for identical records for which percentage certainty are |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
60 * added together. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
61 * print_catalog() is called to print out catalog and release external resources |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
62 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
63 * /---------------\ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
64 * status_rec_list -> | | -| |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
65 * \---------------/ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
66 * \/ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
67 * /---------------\ /-------\ /-------\ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
68 * status_fru_list | status_record | -> | uurec | -> | uurec | -| |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
69 * \/ | | |- | | <- | | |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
70 * /-------------\ | | \-------/ \-------/ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
71 * | | -> | | \/ \/ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
72 * \-------------/ | | /-------\ /-------\ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
73 * \/ | | -> | asru | -> | asru | |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
74 * --- | | | | <- | | |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
75 * | | \-------/ \-------/ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
76 * status_asru_list | class | |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
77 * \/ | resource | /-------\ /-------\ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
78 * /-------------\ | fru | -> | list | -> | list | |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
79 * | | -> | serial | | | <- | | |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
80 * \-------------/ | | \-------/ \-------/ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
81 * \/ \---------------/ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
82 * --- \/ /\ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
83 * /---------------\ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
84 * | status_record | |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
85 * \---------------/ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
86 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
87 * Fmadm faulty takes a number of options which affect the format of the |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
88 * output displayed. By default, the display reports the FRU and ASRU along |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
89 * with other information on per-case basis as in the example below. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
90 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
91 * --------------- ------------------------------------ -------------- ------- |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
92 * TIME EVENT-ID MSG-ID SEVERITY |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
93 * --------------- ------------------------------------ -------------- ------- |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
94 * Sep 21 10:01:36 d482f935-5c8f-e9ab-9f25-d0aaafec1e6c AMD-8000-2F Major |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
95 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
96 * Fault class : fault.memory.dimm_sb |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
97 * Affects : mem:///motherboard=0/chip=0/memory-controller=0/dimm=0/rank=0 |
7275 | 98 * faulted but still in service |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
99 * FRU : "CPU 0 DIMM 0" (hc://.../memory-controller=0/dimm=0) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
100 * faulty |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
101 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
102 * Description : The number of errors associated with this memory module has |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
103 * exceeded acceptable levels. Refer to |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
104 * http://sun.com/msg/AMD-8000-2F for more information. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
105 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
106 * Response : Pages of memory associated with this memory module are being |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
107 * removed from service as errors are reported. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
108 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
109 * Impact : Total system memory capacity will be reduced as pages are |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
110 * retired. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
111 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
112 * Action : Schedule a repair procedure to replace the affected memory |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
113 * module. Use fmdump -v -u <EVENT_ID> to identify the module. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
114 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
115 * The -v flag is similar, but adds some additonal information such as the |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
116 * resource. The -s flag is also similar but just gives the top line summary. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
117 * All these options (ie without the -f or -r flags) use the print_catalog() |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
118 * function to do the display. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
119 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
120 * The -f flag changes the output so that it appears sorted on a per-fru basis. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
121 * The output is somewhat cut down compared to the default output. If -f is |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
122 * used, then print_fru() is used to print the output. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
123 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
124 * ----------------------------------------------------------------------------- |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
125 * "SLOT 2" (hc://.../hostbridge=3/pciexrc=3/pciexbus=4/pciexdev=0) faulty |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
126 * 5ca4aeb3-36...f6be-c2e8166dc484 2 suspects in this FRU total certainty 100% |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
127 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
128 * Description : A problem was detected for a PCI device. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
129 * Refer to http://sun.com/msg/PCI-8000-7J for more information. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
130 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
131 * Response : One or more device instances may be disabled |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
132 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
133 * Impact : Possible loss of services provided by the device instances |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
134 * associated with this fault |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
135 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
136 * Action : Schedule a repair procedure to replace the affected device. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
137 * Use fmdump -v -u <EVENT_ID> to identify the device or contact |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
138 * Sun for support. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
139 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
140 * The -r flag changes the output so that it appears sorted on a per-asru basis. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
141 * The output is very much cut down compared to the default output, just giving |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
142 * the asru fmri and state. Here print_asru() is used to print the output. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
143 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
144 * mem:///motherboard=0/chip=0/memory-controller=0/dimm=0/rank=0 degraded |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
145 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
146 * For all fmadm faulty options, the sequence of events is |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
147 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
148 * 1) Walk through all the cases in the system using fmd_adm_case_iter() and |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
149 * for each case call dfault_rec(). This will call add_fault_record_to_catalog() |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
150 * This will extract the data from the nvlist and call catalog_new_record() to |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
151 * save the data away in various linked lists in the catalogue. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
152 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
153 * 2) Once this is done, the data can be supplemented by using |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
154 * fmd_adm_rsrc_iter(). However this is now only necessary for the -i option. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
155 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
156 * 3) Finally print_catalog(), print_fru() or print_asru() are called as |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
157 * appropriate to display the information from the catalogue sorted in the |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
158 * requested way. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
159 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
160 */ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
161 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
162 typedef struct name_list { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
163 struct name_list *next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
164 struct name_list *prev; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
165 char *name; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
166 uint8_t pct; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
167 uint8_t max_pct; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
168 ushort_t count; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
169 int status; |
6002 | 170 char *label; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
171 } name_list_t; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
172 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
173 typedef struct ari_list { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
174 char *ari_uuid; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
175 struct ari_list *next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
176 } ari_list_t; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
177 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
178 typedef struct uurec { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
179 struct uurec *next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
180 struct uurec *prev; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
181 char *uuid; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
182 ari_list_t *ari_uuid_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
183 name_list_t *asru; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
184 uint64_t sec; |
10234
c4cea2ed5803
6839705 libtopo needs updates in order to cope with ILOM 3
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9501
diff
changeset
|
185 nvlist_t *event; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
186 } uurec_t; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
187 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
188 typedef struct uurec_select { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
189 struct uurec_select *next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
190 char *uuid; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
191 } uurec_select_t; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
192 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
193 typedef struct host_id { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
194 char *chassis; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
195 char *server; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
196 char *platform; |
9120
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
197 char *domain; |
10462
ec0e4f3134ef
PSARC/2007/650 Product Serial Number for FMRI
Cheng Sean Ye <Sean.Ye@Sun.COM>
parents:
10234
diff
changeset
|
198 char *product_sn; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
199 } hostid_t; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
200 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
201 typedef struct host_id_list { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
202 hostid_t hostid; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
203 struct host_id_list *next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
204 } host_id_list_t; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
205 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
206 typedef struct status_record { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
207 hostid_t *host; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
208 int nrecs; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
209 uurec_t *uurec; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
210 char *severity; /* in C locale */ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
211 char *msgid; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
212 name_list_t *class; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
213 name_list_t *resource; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
214 name_list_t *asru; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
215 name_list_t *fru; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
216 name_list_t *serial; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
217 uint8_t not_suppressed; |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
218 uint8_t injected; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
219 } status_record_t; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
220 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
221 typedef struct sr_list { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
222 struct sr_list *next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
223 struct sr_list *prev; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
224 struct status_record *status_record; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
225 } sr_list_t; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
226 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
227 typedef struct resource_list { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
228 struct resource_list *next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
229 struct resource_list *prev; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
230 sr_list_t *status_rec_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
231 char *resource; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
232 uint8_t not_suppressed; |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
233 uint8_t injected; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
234 uint8_t max_pct; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
235 } resource_list_t; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
236 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
237 typedef struct tgetlabel_data { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
238 char *label; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
239 char *fru; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
240 } tgetlabel_data_t; |
0 | 241 |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
242 sr_list_t *status_rec_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
243 resource_list_t *status_fru_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
244 resource_list_t *status_asru_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
245 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
246 static int max_display; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
247 static int max_fault = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
248 static topo_hdl_t *topo_handle; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
249 static char *topo_handle_uuid; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
250 static host_id_list_t *host_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
251 static int n_server; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
252 static int opt_g; |
9501
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
253 static fmd_msg_hdl_t *fmadm_msghdl = NULL; /* handle for libfmd_msg calls */ |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
254 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
255 static char * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
256 format_date(char *buf, size_t len, uint64_t sec) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
257 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
258 if (sec > LONG_MAX) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
259 (void) fprintf(stderr, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
260 "record time is too large for 32-bit utility\n"); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
261 (void) snprintf(buf, len, "0x%llx", sec); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
262 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
263 time_t tod = (time_t)sec; |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
264 time_t now = time(NULL); |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
265 if (tod > now+60 || |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
266 tod < now - 6L*30L*24L*60L*60L) { /* 6 months ago */ |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
267 (void) strftime(buf, len, "%b %d %Y ", |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
268 localtime(&tod)); |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
269 } else { |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
270 (void) strftime(buf, len, "%b %d %T", localtime(&tod)); |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
271 } |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
272 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
273 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
274 return (buf); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
275 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
276 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
277 static hostid_t * |
10462
ec0e4f3134ef
PSARC/2007/650 Product Serial Number for FMRI
Cheng Sean Ye <Sean.Ye@Sun.COM>
parents:
10234
diff
changeset
|
278 find_hostid_in_list(char *platform, char *chassis, char *server, char *domain, |
ec0e4f3134ef
PSARC/2007/650 Product Serial Number for FMRI
Cheng Sean Ye <Sean.Ye@Sun.COM>
parents:
10234
diff
changeset
|
279 char *product_sn) |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
280 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
281 hostid_t *rt = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
282 host_id_list_t *hostp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
283 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
284 if (platform == NULL) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
285 platform = "-"; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
286 if (server == NULL) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
287 server = "-"; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
288 hostp = host_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
289 while (hostp) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
290 if (hostp->hostid.platform && |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
291 strcmp(hostp->hostid.platform, platform) == 0 && |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
292 hostp->hostid.server && |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
293 strcmp(hostp->hostid.server, server) == 0 && |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
294 (chassis == NULL || hostp->hostid.chassis == NULL || |
9120
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
295 strcmp(chassis, hostp->hostid.chassis) == 0) && |
10462
ec0e4f3134ef
PSARC/2007/650 Product Serial Number for FMRI
Cheng Sean Ye <Sean.Ye@Sun.COM>
parents:
10234
diff
changeset
|
296 (product_sn == NULL || hostp->hostid.product_sn == NULL || |
ec0e4f3134ef
PSARC/2007/650 Product Serial Number for FMRI
Cheng Sean Ye <Sean.Ye@Sun.COM>
parents:
10234
diff
changeset
|
297 strcmp(product_sn, hostp->hostid.product_sn) == 0) && |
9120
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
298 (domain == NULL || hostp->hostid.domain == NULL || |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
299 strcmp(domain, hostp->hostid.domain) == 0)) { |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
300 rt = &hostp->hostid; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
301 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
302 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
303 hostp = hostp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
304 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
305 if (rt == NULL) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
306 hostp = malloc(sizeof (host_id_list_t)); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
307 hostp->hostid.platform = strdup(platform); |
10462
ec0e4f3134ef
PSARC/2007/650 Product Serial Number for FMRI
Cheng Sean Ye <Sean.Ye@Sun.COM>
parents:
10234
diff
changeset
|
308 hostp->hostid.product_sn = |
ec0e4f3134ef
PSARC/2007/650 Product Serial Number for FMRI
Cheng Sean Ye <Sean.Ye@Sun.COM>
parents:
10234
diff
changeset
|
309 product_sn ? strdup(product_sn) : NULL; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
310 hostp->hostid.server = strdup(server); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
311 hostp->hostid.chassis = chassis ? strdup(chassis) : NULL; |
9120
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
312 hostp->hostid.domain = domain ? strdup(domain) : NULL; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
313 hostp->next = host_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
314 host_list = hostp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
315 rt = &hostp->hostid; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
316 n_server++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
317 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
318 return (rt); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
319 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
320 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
321 static hostid_t * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
322 find_hostid(nvlist_t *nvl) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
323 { |
9120
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
324 char *platform = NULL, *chassis = NULL, *server = NULL, *domain = NULL; |
10462
ec0e4f3134ef
PSARC/2007/650 Product Serial Number for FMRI
Cheng Sean Ye <Sean.Ye@Sun.COM>
parents:
10234
diff
changeset
|
325 char *product_sn = NULL; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
326 nvlist_t *auth, *fmri; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
327 hostid_t *rt = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
328 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
329 if (nvlist_lookup_nvlist(nvl, FM_SUSPECT_DE, &fmri) == 0 && |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
330 nvlist_lookup_nvlist(fmri, FM_FMRI_AUTHORITY, &auth) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
331 (void) nvlist_lookup_string(auth, FM_FMRI_AUTH_PRODUCT, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
332 &platform); |
10462
ec0e4f3134ef
PSARC/2007/650 Product Serial Number for FMRI
Cheng Sean Ye <Sean.Ye@Sun.COM>
parents:
10234
diff
changeset
|
333 (void) nvlist_lookup_string(auth, FM_FMRI_AUTH_PRODUCT_SN, |
ec0e4f3134ef
PSARC/2007/650 Product Serial Number for FMRI
Cheng Sean Ye <Sean.Ye@Sun.COM>
parents:
10234
diff
changeset
|
334 &product_sn); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
335 (void) nvlist_lookup_string(auth, FM_FMRI_AUTH_SERVER, &server); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
336 (void) nvlist_lookup_string(auth, FM_FMRI_AUTH_CHASSIS, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
337 &chassis); |
9120
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
338 (void) nvlist_lookup_string(auth, FM_FMRI_AUTH_DOMAIN, &domain); |
10462
ec0e4f3134ef
PSARC/2007/650 Product Serial Number for FMRI
Cheng Sean Ye <Sean.Ye@Sun.COM>
parents:
10234
diff
changeset
|
339 rt = find_hostid_in_list(platform, chassis, server, |
ec0e4f3134ef
PSARC/2007/650 Product Serial Number for FMRI
Cheng Sean Ye <Sean.Ye@Sun.COM>
parents:
10234
diff
changeset
|
340 domain, product_sn); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
341 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
342 return (rt); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
343 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
344 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
345 /* |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
346 * compare two fru strings which are made up of substrings seperated by '/' |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
347 * return true if every substring is the same in the two strings, or if a |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
348 * substring is null in one. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
349 */ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
350 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
351 static int |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
352 frucmp(char *f1, char *f2) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
353 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
354 char c1, c2; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
355 int i = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
356 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
357 for (;;) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
358 c1 = *f1; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
359 c2 = *f2; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
360 if (c1 == c2) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
361 i = (c1 == '/') ? 0 : i + 1; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
362 } else if (i == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
363 if (c1 == '/') { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
364 do { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
365 f2++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
366 } while ((c2 = *f2) != 0 && c2 != '/'); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
367 if (c2 == NULL) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
368 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
369 } else if (c2 == '/') { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
370 do { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
371 f1++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
372 } while ((c1 = *f1) != 0 && c1 != '/'); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
373 if (c1 == NULL) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
374 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
375 } else |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
376 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
377 } else |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
378 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
379 if (c1 == NULL) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
380 return (0); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
381 f1++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
382 f2++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
383 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
384 return (1); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
385 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
386 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
387 static int |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
388 tgetlabel(topo_hdl_t *thp, tnode_t *node, void *arg) |
0 | 389 { |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
390 int err; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
391 char *fru_name, *lname; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
392 nvlist_t *fru = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
393 int rt = TOPO_WALK_NEXT; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
394 tgetlabel_data_t *tdp = (tgetlabel_data_t *)arg; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
395 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
396 if (topo_node_fru(node, &fru, NULL, &err) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
397 if (topo_fmri_nvl2str(thp, fru, &fru_name, &err) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
398 if (frucmp(tdp->fru, fru_name) == 0 && |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
399 topo_node_label(node, &lname, &err) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
400 tdp->label = strdup(lname); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
401 topo_hdl_strfree(thp, lname); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
402 rt = TOPO_WALK_TERMINATE; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
403 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
404 topo_hdl_strfree(thp, fru_name); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
405 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
406 nvlist_free(fru); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
407 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
408 return (rt); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
409 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
410 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
411 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
412 label_get_topo(void) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
413 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
414 int err; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
415 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
416 topo_handle = topo_open(TOPO_VERSION, 0, &err); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
417 if (topo_handle) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
418 topo_handle_uuid = topo_snap_hold(topo_handle, NULL, &err); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
419 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
420 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
421 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
422 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
423 label_release_topo(void) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
424 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
425 if (topo_handle_uuid) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
426 topo_hdl_strfree(topo_handle, topo_handle_uuid); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
427 if (topo_handle) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
428 topo_snap_release(topo_handle); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
429 topo_close(topo_handle); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
430 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
431 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
432 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
433 static char * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
434 get_fmri_label(char *fru) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
435 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
436 topo_walk_t *twp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
437 tgetlabel_data_t td; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
438 int err; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
439 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
440 td.label = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
441 td.fru = fru; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
442 if (topo_handle == NULL) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
443 label_get_topo(); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
444 if (topo_handle_uuid) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
445 twp = topo_walk_init(topo_handle, FM_FMRI_SCHEME_HC, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
446 tgetlabel, &td, &err); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
447 if (twp) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
448 topo_walk_step(twp, TOPO_WALK_CHILD); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
449 topo_walk_fini(twp); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
450 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
451 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
452 return (td.label); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
453 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
454 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
455 static char * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
456 get_nvl2str_topo(nvlist_t *nvl) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
457 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
458 char *name = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
459 char *tname; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
460 int err; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
461 char *scheme = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
462 char *mod_name = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
463 char buf[128]; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
464 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
465 if (topo_handle == NULL) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
466 label_get_topo(); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
467 if (topo_fmri_nvl2str(topo_handle, nvl, &tname, &err) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
468 name = strdup(tname); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
469 topo_hdl_strfree(topo_handle, tname); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
470 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
471 (void) nvlist_lookup_string(nvl, FM_FMRI_SCHEME, &scheme); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
472 (void) nvlist_lookup_string(nvl, FM_FMRI_MOD_NAME, &mod_name); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
473 if (scheme && strcmp(scheme, FM_FMRI_SCHEME_FMD) == 0 && |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
474 mod_name) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
475 (void) snprintf(buf, sizeof (buf), "%s:///module/%s", |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
476 scheme, mod_name); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
477 name = strdup(buf); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
478 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
479 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
480 return (name); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
481 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
482 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
483 static int |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
484 set_priority(char *s) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
485 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
486 int rt = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
487 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
488 if (s) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
489 if (strcmp(s, "Minor") == 0) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
490 rt = 1; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
491 else if (strcmp(s, "Major") == 0) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
492 rt = 10; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
493 else if (strcmp(s, "Critical") == 0) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
494 rt = 100; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
495 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
496 return (rt); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
497 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
498 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
499 static int |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
500 cmp_priority(char *s1, char *s2, uint64_t t1, uint64_t t2, uint8_t p1, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
501 uint8_t p2) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
502 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
503 int r1, r2; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
504 int rt; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
505 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
506 r1 = set_priority(s1); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
507 r2 = set_priority(s2); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
508 rt = r1 - r2; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
509 if (rt == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
510 if (t1 > t2) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
511 rt = 1; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
512 else if (t1 < t2) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
513 rt = -1; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
514 else |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
515 rt = p1 - p2; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
516 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
517 return (rt); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
518 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
519 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
520 /* |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
521 * merge two lists into one, by comparing enties in new and moving into list if |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
522 * name is not there or free off memory for names which are already there |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
523 * add_pct indicates if pct is the sum or highest pct |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
524 */ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
525 static name_list_t * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
526 merge_name_list(name_list_t **list, name_list_t *new, int add_pct) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
527 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
528 name_list_t *lp, *np, *sp, *rt = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
529 int max_pct; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
530 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
531 rt = *list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
532 np = new; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
533 while (np) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
534 lp = *list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
535 while (lp) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
536 if (strcmp(lp->name, np->name) == 0) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
537 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
538 lp = lp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
539 if (lp == *list) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
540 lp = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
541 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
542 if (np->next == new) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
543 sp = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
544 else |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
545 sp = np->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
546 if (lp) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
547 lp->status |= (np->status & FM_SUSPECT_FAULTY); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
548 if (add_pct) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
549 lp->pct += np->pct; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
550 lp->count += np->count; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
551 } else if (np->pct > lp->pct) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
552 lp->pct = np->pct; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
553 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
554 max_pct = np->max_pct; |
6002 | 555 if (np->label) |
556 free(np->label); | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
557 free(np->name); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
558 free(np); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
559 np = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
560 if (max_pct > lp->max_pct) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
561 lp->max_pct = max_pct; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
562 if (lp->max_pct > lp->prev->max_pct && |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
563 lp != *list) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
564 lp->prev->next = lp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
565 lp->next->prev = lp->prev; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
566 np = lp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
567 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
568 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
569 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
570 if (np) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
571 lp = *list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
572 if (lp) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
573 if (np->max_pct > lp->max_pct) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
574 np->next = lp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
575 np->prev = lp->prev; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
576 lp->prev->next = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
577 lp->prev = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
578 *list = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
579 rt = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
580 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
581 lp = lp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
582 while (lp != *list && |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
583 np->max_pct < lp->max_pct) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
584 lp = lp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
585 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
586 np->next = lp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
587 np->prev = lp->prev; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
588 lp->prev->next = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
589 lp->prev = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
590 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
591 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
592 *list = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
593 np->next = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
594 np->prev = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
595 rt = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
596 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
597 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
598 np = sp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
599 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
600 return (rt); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
601 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
602 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
603 static name_list_t * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
604 alloc_name_list(char *name, uint8_t pct) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
605 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
606 name_list_t *nlp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
607 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
608 nlp = malloc(sizeof (*nlp)); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
609 nlp->name = strdup(name); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
610 nlp->pct = pct; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
611 nlp->max_pct = pct; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
612 nlp->count = 1; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
613 nlp->next = nlp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
614 nlp->prev = nlp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
615 nlp->status = 0; |
6002 | 616 nlp->label = NULL; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
617 return (nlp); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
618 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
619 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
620 static status_record_t * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
621 new_record_init(uurec_t *uurec_p, char *msgid, name_list_t *class, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
622 name_list_t *fru, name_list_t *asru, name_list_t *resource, |
9501
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
623 name_list_t *serial, boolean_t not_suppressed, |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
624 hostid_t *hostid, boolean_t injected) |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
625 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
626 status_record_t *status_rec_p; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
627 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
628 status_rec_p = (status_record_t *)malloc(sizeof (status_record_t)); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
629 status_rec_p->nrecs = 1; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
630 status_rec_p->host = hostid; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
631 status_rec_p->uurec = uurec_p; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
632 uurec_p->next = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
633 uurec_p->prev = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
634 uurec_p->asru = asru; |
9501
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
635 if ((status_rec_p->severity = fmd_msg_getitem_id(fmadm_msghdl, NULL, |
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
636 msgid, FMD_MSG_ITEM_SEVERITY)) == NULL) |
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
637 status_rec_p->severity = strdup("unknown"); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
638 status_rec_p->class = class; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
639 status_rec_p->fru = fru; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
640 status_rec_p->asru = asru; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
641 status_rec_p->resource = resource; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
642 status_rec_p->serial = serial; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
643 status_rec_p->msgid = strdup(msgid); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
644 status_rec_p->not_suppressed = not_suppressed; |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
645 status_rec_p->injected = injected; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
646 return (status_rec_p); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
647 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
648 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
649 /* |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
650 * add record to given list maintaining order higher priority first. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
651 */ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
652 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
653 add_rec_list(status_record_t *status_rec_p, sr_list_t **list_pp) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
654 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
655 sr_list_t *tp, *np, *sp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
656 int order; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
657 uint64_t sec; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
658 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
659 np = malloc(sizeof (sr_list_t)); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
660 np->status_record = status_rec_p; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
661 sec = status_rec_p->uurec->sec; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
662 if ((sp = *list_pp) == NULL) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
663 *list_pp = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
664 np->next = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
665 np->prev = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
666 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
667 /* insert new record in front of lower priority */ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
668 tp = sp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
669 order = cmp_priority(status_rec_p->severity, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
670 sp->status_record->severity, sec, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
671 tp->status_record->uurec->sec, 0, 0); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
672 if (order > 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
673 *list_pp = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
674 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
675 tp = sp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
676 while (tp != sp && |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
677 cmp_priority(status_rec_p->severity, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
678 tp->status_record->severity, sec, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
679 tp->status_record->uurec->sec, 0, 0)) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
680 tp = tp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
681 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
682 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
683 np->next = tp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
684 np->prev = tp->prev; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
685 tp->prev->next = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
686 tp->prev = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
687 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
688 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
689 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
690 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
691 add_resource(status_record_t *status_rec_p, resource_list_t **rp, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
692 resource_list_t *np) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
693 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
694 int order; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
695 uint64_t sec; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
696 resource_list_t *sp, *tp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
697 status_record_t *srp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
698 char *severity = status_rec_p->severity; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
699 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
700 add_rec_list(status_rec_p, &np->status_rec_list); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
701 if ((sp = *rp) == NULL) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
702 np->next = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
703 np->prev = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
704 *rp = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
705 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
706 /* |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
707 * insert new record in front of lower priority |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
708 */ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
709 tp = sp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
710 srp = sp->status_rec_list->status_record; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
711 sec = status_rec_p->uurec->sec; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
712 order = cmp_priority(severity, srp->severity, sec, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
713 srp->uurec->sec, np->max_pct, sp->max_pct); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
714 if (order > 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
715 *rp = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
716 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
717 srp = tp->status_rec_list->status_record; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
718 while (tp != sp && |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
719 cmp_priority(severity, srp->severity, sec, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
720 srp->uurec->sec, np->max_pct, sp->max_pct) < 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
721 tp = tp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
722 srp = tp->status_rec_list->status_record; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
723 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
724 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
725 np->next = tp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
726 np->prev = tp->prev; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
727 tp->prev->next = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
728 tp->prev = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
729 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
730 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
731 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
732 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
733 add_resource_list(status_record_t *status_rec_p, name_list_t *fp, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
734 resource_list_t **rpp) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
735 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
736 int order; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
737 resource_list_t *np, *end; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
738 status_record_t *srp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
739 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
740 np = *rpp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
741 end = np; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
742 while (np) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
743 if (strcmp(fp->name, np->resource) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
744 np->not_suppressed |= status_rec_p->not_suppressed; |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
745 np->injected |= status_rec_p->injected; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
746 srp = np->status_rec_list->status_record; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
747 order = cmp_priority(status_rec_p->severity, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
748 srp->severity, status_rec_p->uurec->sec, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
749 srp->uurec->sec, fp->max_pct, np->max_pct); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
750 if (order > 0 && np != end) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
751 /* |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
752 * remove from list and add again using |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
753 * new priority |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
754 */ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
755 np->prev->next = np->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
756 np->next->prev = np->prev; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
757 add_resource(status_rec_p, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
758 rpp, np); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
759 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
760 add_rec_list(status_rec_p, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
761 &np->status_rec_list); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
762 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
763 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
764 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
765 np = np->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
766 if (np == end) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
767 np = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
768 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
769 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
770 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
771 if (np == NULL) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
772 np = malloc(sizeof (resource_list_t)); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
773 np->resource = fp->name; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
774 np->not_suppressed = status_rec_p->not_suppressed; |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
775 np->injected = status_rec_p->injected; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
776 np->status_rec_list = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
777 np->max_pct = fp->max_pct; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
778 add_resource(status_rec_p, rpp, np); |
0 | 779 } |
780 } | |
781 | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
782 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
783 add_list(status_record_t *status_rec_p, name_list_t *listp, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
784 resource_list_t **glistp) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
785 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
786 name_list_t *fp, *end; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
787 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
788 fp = listp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
789 end = fp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
790 while (fp) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
791 add_resource_list(status_rec_p, fp, glistp); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
792 fp = fp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
793 if (fp == end) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
794 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
795 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
796 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
797 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
798 /* |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
799 * add record to rec, fru and asru lists. |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
800 */ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
801 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
802 catalog_new_record(uurec_t *uurec_p, char *msgid, name_list_t *class, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
803 name_list_t *fru, name_list_t *asru, name_list_t *resource, |
9501
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
804 name_list_t *serial, boolean_t not_suppressed, |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
805 hostid_t *hostid, boolean_t injected) |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
806 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
807 status_record_t *status_rec_p; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
808 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
809 status_rec_p = new_record_init(uurec_p, msgid, class, fru, asru, |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
810 resource, serial, not_suppressed, hostid, injected); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
811 add_rec_list(status_rec_p, &status_rec_list); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
812 if (status_rec_p->fru) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
813 add_list(status_rec_p, status_rec_p->fru, &status_fru_list); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
814 if (status_rec_p->asru) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
815 add_list(status_rec_p, status_rec_p->asru, &status_asru_list); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
816 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
817 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
818 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
819 get_serial_no(nvlist_t *nvl, name_list_t **serial_p, uint8_t pct) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
820 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
821 char *name; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
822 char *serial = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
823 char **lserial = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
824 uint64_t serint; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
825 name_list_t *nlp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
826 int j; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
827 uint_t nelem; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
828 char buf[64]; |
0 | 829 |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
830 if (nvlist_lookup_string(nvl, FM_FMRI_SCHEME, &name) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
831 if (strcmp(name, FM_FMRI_SCHEME_CPU) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
832 if (nvlist_lookup_uint64(nvl, FM_FMRI_CPU_SERIAL_ID, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
833 &serint) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
834 (void) snprintf(buf, sizeof (buf), "%llX", |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
835 serint); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
836 nlp = alloc_name_list(buf, pct); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
837 (void) merge_name_list(serial_p, nlp, 1); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
838 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
839 } else if (strcmp(name, FM_FMRI_SCHEME_MEM) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
840 if (nvlist_lookup_string_array(nvl, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
841 FM_FMRI_MEM_SERIAL_ID, &lserial, &nelem) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
842 nlp = alloc_name_list(lserial[0], pct); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
843 for (j = 1; j < nelem; j++) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
844 name_list_t *n1lp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
845 n1lp = alloc_name_list(lserial[j], pct); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
846 (void) merge_name_list(&nlp, n1lp, 1); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
847 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
848 (void) merge_name_list(serial_p, nlp, 1); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
849 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
850 } else if (strcmp(name, FM_FMRI_SCHEME_HC) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
851 if (nvlist_lookup_string(nvl, FM_FMRI_HC_SERIAL_ID, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
852 &serial) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
853 nlp = alloc_name_list(serial, pct); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
854 (void) merge_name_list(serial_p, nlp, 1); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
855 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
856 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
857 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
858 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
859 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
860 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
861 extract_record_info(nvlist_t *nvl, name_list_t **class_p, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
862 name_list_t **fru_p, name_list_t **serial_p, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
863 name_list_t **resource_p, name_list_t **asru_p, uint8_t status) |
0 | 864 { |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
865 nvlist_t *lfru, *lasru, *rsrc; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
866 name_list_t *nlp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
867 char *name; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
868 uint8_t lpct = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
869 char *lclass = NULL; |
6002 | 870 char *label; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
871 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
872 (void) nvlist_lookup_uint8(nvl, FM_FAULT_CERTAINTY, &lpct); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
873 if (nvlist_lookup_string(nvl, FM_CLASS, &lclass) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
874 nlp = alloc_name_list(lclass, lpct); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
875 (void) merge_name_list(class_p, nlp, 1); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
876 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
877 if (nvlist_lookup_nvlist(nvl, FM_FAULT_FRU, &lfru) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
878 name = get_nvl2str_topo(lfru); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
879 if (name != NULL) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
880 nlp = alloc_name_list(name, lpct); |
7275 | 881 nlp->status = status & ~(FM_SUSPECT_UNUSABLE | |
882 FM_SUSPECT_DEGRADED); | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
883 free(name); |
6002 | 884 if (nvlist_lookup_string(nvl, FM_FAULT_LOCATION, |
885 &label) == 0) | |
886 nlp->label = strdup(label); | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
887 (void) merge_name_list(fru_p, nlp, 1); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
888 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
889 get_serial_no(lfru, serial_p, lpct); |
10656
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
890 } else if (nvlist_lookup_nvlist(nvl, FM_FAULT_RESOURCE, &rsrc) != 0) { |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
891 /* |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
892 * No FRU or resource. But we want to display the repair status |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
893 * somehow, so create a dummy FRU field. |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
894 */ |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
895 nlp = alloc_name_list(dgettext("FMD", "None"), lpct); |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
896 nlp->status = status & ~(FM_SUSPECT_UNUSABLE | |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
897 FM_SUSPECT_DEGRADED); |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
898 (void) merge_name_list(fru_p, nlp, 1); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
899 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
900 if (nvlist_lookup_nvlist(nvl, FM_FAULT_ASRU, &lasru) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
901 name = get_nvl2str_topo(lasru); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
902 if (name != NULL) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
903 nlp = alloc_name_list(name, lpct); |
7275 | 904 nlp->status = status & ~(FM_SUSPECT_NOT_PRESENT | |
905 FM_SUSPECT_REPAIRED | FM_SUSPECT_REPLACED | | |
906 FM_SUSPECT_ACQUITTED); | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
907 free(name); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
908 (void) merge_name_list(asru_p, nlp, 1); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
909 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
910 get_serial_no(lasru, serial_p, lpct); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
911 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
912 if (nvlist_lookup_nvlist(nvl, FM_FAULT_RESOURCE, &rsrc) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
913 name = get_nvl2str_topo(rsrc); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
914 if (name != NULL) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
915 nlp = alloc_name_list(name, lpct); |
6228
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
916 nlp->status = status; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
917 free(name); |
8245
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
918 if (nvlist_lookup_string(nvl, FM_FAULT_LOCATION, |
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
919 &label) == 0) |
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
920 nlp->label = strdup(label); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
921 (void) merge_name_list(resource_p, nlp, 1); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
922 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
923 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
924 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
925 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
926 static void |
9501
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
927 add_fault_record_to_catalog(nvlist_t *nvl, uint64_t sec, char *uuid) |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
928 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
929 char *msgid = "-"; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
930 uint_t i, size = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
931 name_list_t *class = NULL, *resource = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
932 name_list_t *asru = NULL, *fru = NULL, *serial = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
933 nvlist_t **nva; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
934 uint8_t *ba; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
935 uurec_t *uurec_p; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
936 hostid_t *host; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
937 boolean_t not_suppressed = 1; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
938 boolean_t any_present = 0; |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
939 boolean_t injected = 0; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
940 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
941 (void) nvlist_lookup_string(nvl, FM_SUSPECT_DIAG_CODE, &msgid); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
942 (void) nvlist_lookup_uint32(nvl, FM_SUSPECT_FAULT_SZ, &size); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
943 (void) nvlist_lookup_boolean_value(nvl, FM_SUSPECT_MESSAGE, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
944 ¬_suppressed); |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
945 (void) nvlist_lookup_boolean_value(nvl, FM_SUSPECT_INJECTED, &injected); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
946 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
947 if (size != 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
948 (void) nvlist_lookup_nvlist_array(nvl, FM_SUSPECT_FAULT_LIST, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
949 &nva, &size); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
950 (void) nvlist_lookup_uint8_array(nvl, FM_SUSPECT_FAULT_STATUS, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
951 &ba, &size); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
952 for (i = 0; i < size; i++) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
953 extract_record_info(nva[i], &class, &fru, &serial, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
954 &resource, &asru, ba[i]); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
955 if (!(ba[i] & FM_SUSPECT_NOT_PRESENT) && |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
956 (ba[i] & FM_SUSPECT_FAULTY)) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
957 any_present = 1; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
958 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
959 /* |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
960 * also suppress if no resources present |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
961 */ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
962 if (any_present == 0) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
963 not_suppressed = 0; |
0 | 964 } |
965 | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
966 uurec_p = (uurec_t *)malloc(sizeof (uurec_t)); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
967 uurec_p->uuid = strdup(uuid); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
968 uurec_p->sec = sec; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
969 uurec_p->ari_uuid_list = NULL; |
10234
c4cea2ed5803
6839705 libtopo needs updates in order to cope with ILOM 3
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9501
diff
changeset
|
970 uurec_p->event = NULL; |
c4cea2ed5803
6839705 libtopo needs updates in order to cope with ILOM 3
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9501
diff
changeset
|
971 (void) nvlist_dup(nvl, &uurec_p->event, 0); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
972 host = find_hostid(nvl); |
10656
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
973 catalog_new_record(uurec_p, msgid, class, fru, asru, |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
974 resource, serial, not_suppressed, host, injected); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
975 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
976 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
977 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
978 update_asru_state_in_catalog(const char *uuid, const char *ari_uuid) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
979 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
980 sr_list_t *srp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
981 uurec_t *uurp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
982 ari_list_t *ari_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
983 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
984 srp = status_rec_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
985 if (srp) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
986 for (;;) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
987 uurp = srp->status_record->uurec; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
988 while (uurp) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
989 if (strcmp(uuid, uurp->uuid) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
990 ari_list = (ari_list_t *) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
991 malloc(sizeof (ari_list_t)); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
992 ari_list->ari_uuid = strdup(ari_uuid); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
993 ari_list->next = uurp->ari_uuid_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
994 uurp->ari_uuid_list = ari_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
995 return; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
996 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
997 uurp = uurp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
998 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
999 if (srp->next == status_rec_list) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1000 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1001 srp = srp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1002 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1003 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1004 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1005 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1006 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1007 print_line(char *label, char *buf) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1008 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1009 char *cp, *ep, *wp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1010 char c; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1011 int i; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1012 int lsz; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1013 char *padding; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1014 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1015 lsz = strlen(label); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1016 padding = malloc(lsz + 1); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1017 for (i = 0; i < lsz; i++) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1018 padding[i] = ' '; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1019 padding[i] = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1020 cp = buf; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1021 ep = buf; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1022 c = *ep; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1023 (void) printf("\n"); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1024 while (c) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1025 i = lsz; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1026 wp = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1027 while ((c = *ep) != NULL && (wp == NULL || i < 80)) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1028 if (c == ' ') |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1029 wp = ep; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1030 else if (c == '\n') { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1031 i = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1032 *ep = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1033 do { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1034 ep++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1035 } while ((c = *ep) != NULL && c == ' '); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1036 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1037 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1038 ep++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1039 i++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1040 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1041 if (i >= 80 && wp) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1042 *wp = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1043 ep = wp + 1; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1044 c = *ep; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1045 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1046 (void) printf("%s%s\n", label, cp); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1047 cp = ep; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1048 label = padding; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1049 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1050 free(padding); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1051 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1052 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1053 static void |
10234
c4cea2ed5803
6839705 libtopo needs updates in order to cope with ILOM 3
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9501
diff
changeset
|
1054 print_dict_info_line(nvlist_t *e, fmd_msg_item_t what, const char *linehdr) |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1055 { |
10234
c4cea2ed5803
6839705 libtopo needs updates in order to cope with ILOM 3
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9501
diff
changeset
|
1056 char *cp = fmd_msg_getitem_nv(fmadm_msghdl, NULL, e, what); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1057 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1058 if (cp) { |
9501
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
1059 print_line(dgettext("FMD", linehdr), cp); |
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
1060 free(cp); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1061 } |
9501
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
1062 } |
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
1063 |
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
1064 static void |
10234
c4cea2ed5803
6839705 libtopo needs updates in order to cope with ILOM 3
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9501
diff
changeset
|
1065 print_dict_info(nvlist_t *nvl) |
9501
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
1066 { |
10234
c4cea2ed5803
6839705 libtopo needs updates in order to cope with ILOM 3
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9501
diff
changeset
|
1067 print_dict_info_line(nvl, FMD_MSG_ITEM_DESC, "Description : "); |
c4cea2ed5803
6839705 libtopo needs updates in order to cope with ILOM 3
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9501
diff
changeset
|
1068 print_dict_info_line(nvl, FMD_MSG_ITEM_RESPONSE, "Response : "); |
c4cea2ed5803
6839705 libtopo needs updates in order to cope with ILOM 3
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9501
diff
changeset
|
1069 print_dict_info_line(nvl, FMD_MSG_ITEM_IMPACT, "Impact : "); |
c4cea2ed5803
6839705 libtopo needs updates in order to cope with ILOM 3
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9501
diff
changeset
|
1070 print_dict_info_line(nvl, FMD_MSG_ITEM_ACTION, "Action : "); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1071 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1072 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1073 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1074 print_name(name_list_t *list, char *(func)(char *), char *padding, int *np, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1075 int pct, int full) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1076 { |
8245
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
1077 char *name, *fru_label = NULL; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1078 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1079 name = list->name; |
8245
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
1080 if (list->label) { |
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
1081 (void) printf("%s \"%s\" (%s)", padding, list->label, name); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1082 *np += 1; |
8245
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
1083 } else if (func && (fru_label = func(list->name)) != NULL) { |
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
1084 (void) printf("%s \"%s\" (%s)", padding, fru_label, name); |
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
1085 *np += 1; |
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
1086 free(fru_label); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1087 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1088 (void) printf("%s %s", padding, name); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1089 *np += 1; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1090 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1091 if (list->pct && pct > 0 && pct < 100) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1092 if (list->count > 1) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1093 if (full) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1094 (void) printf(" %d @ %s %d%%\n", list->count, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1095 dgettext("FMD", "max"), |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1096 list->max_pct); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1097 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1098 (void) printf(" %s %d%%\n", |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1099 dgettext("FMD", "max"), |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1100 list->max_pct); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1101 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1102 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1103 (void) printf(" %d%%\n", list->pct); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1104 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1105 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1106 (void) printf("\n"); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1107 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1108 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1109 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1110 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1111 print_asru_status(int status, char *label) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1112 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1113 char *msg = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1114 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1115 switch (status) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1116 case 0: |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1117 msg = dgettext("FMD", "ok and in service"); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1118 break; |
7275 | 1119 case FM_SUSPECT_DEGRADED: |
1120 msg = dgettext("FMD", "service degraded, " | |
1121 "but associated components no longer faulty"); | |
1122 break; | |
1123 case FM_SUSPECT_FAULTY | FM_SUSPECT_DEGRADED: | |
1124 msg = dgettext("FMD", "faulted but still " | |
1125 "providing degraded service"); | |
1126 break; | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1127 case FM_SUSPECT_FAULTY: |
7275 | 1128 msg = dgettext("FMD", "faulted but still in service"); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1129 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1130 case FM_SUSPECT_UNUSABLE: |
7275 | 1131 msg = dgettext("FMD", "out of service, " |
1132 "but associated components no longer faulty"); | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1133 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1134 case FM_SUSPECT_FAULTY | FM_SUSPECT_UNUSABLE: |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1135 msg = dgettext("FMD", "faulted and taken out of service"); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1136 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1137 default: |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1138 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1139 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1140 if (msg) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1141 (void) printf("%s %s\n", label, msg); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1142 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1143 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1144 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1145 static void |
6228
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1146 print_fru_status(int status, char *label) |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1147 { |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1148 char *msg = NULL; |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1149 |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1150 if (status & FM_SUSPECT_NOT_PRESENT) |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1151 msg = dgettext("FMD", "not present"); |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1152 else if (status & FM_SUSPECT_FAULTY) |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1153 msg = dgettext("FMD", "faulty"); |
7275 | 1154 else if (status & FM_SUSPECT_REPLACED) |
1155 msg = dgettext("FMD", "replaced"); | |
1156 else if (status & FM_SUSPECT_REPAIRED) | |
1157 msg = dgettext("FMD", "repair attempted"); | |
1158 else if (status & FM_SUSPECT_ACQUITTED) | |
1159 msg = dgettext("FMD", "acquitted"); | |
6228
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1160 else |
7275 | 1161 msg = dgettext("FMD", "removed"); |
6228
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1162 (void) printf("%s %s\n", label, msg); |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1163 } |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1164 |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1165 static void |
9120
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1166 print_rsrc_status(int status, char *label) |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1167 { |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1168 char *msg = ""; |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1169 |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1170 if (status & FM_SUSPECT_NOT_PRESENT) |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1171 msg = dgettext("FMD", "not present"); |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1172 else if (status & FM_SUSPECT_FAULTY) { |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1173 if (status & FM_SUSPECT_DEGRADED) |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1174 msg = dgettext("FMD", |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1175 "faulted but still providing degraded service"); |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1176 else if (status & FM_SUSPECT_UNUSABLE) |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1177 msg = dgettext("FMD", |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1178 "faulted and taken out of service"); |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1179 else |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1180 msg = dgettext("FMD", "faulted but still in service"); |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1181 } else if (status & FM_SUSPECT_REPLACED) |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1182 msg = dgettext("FMD", "replaced"); |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1183 else if (status & FM_SUSPECT_REPAIRED) |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1184 msg = dgettext("FMD", "repair attempted"); |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1185 else if (status & FM_SUSPECT_ACQUITTED) |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1186 msg = dgettext("FMD", "acquitted"); |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1187 else |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1188 msg = dgettext("FMD", "removed"); |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1189 (void) printf("%s %s\n", label, msg); |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1190 } |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1191 |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1192 static void |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1193 print_name_list(name_list_t *list, char *label, char *(func)(char *), |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1194 int limit, int pct, void (func1)(int, char *), int full) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1195 { |
8245
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
1196 char *name, *fru_label = NULL; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1197 char *padding; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1198 int i, j, l, n; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1199 name_list_t *end = list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1200 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1201 l = strlen(label); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1202 padding = malloc(l + 1); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1203 for (i = 0; i < l; i++) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1204 padding[i] = ' '; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1205 padding[l] = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1206 (void) printf("%s", label); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1207 name = list->name; |
8245
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
1208 if (list->label) |
6002 | 1209 (void) printf(" \"%s\" (%s)", list->label, name); |
8245
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
1210 else if (func && (fru_label = func(list->name)) != NULL) { |
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
1211 (void) printf(" \"%s\" (%s)", fru_label, name); |
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
1212 free(fru_label); |
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
1213 } else |
7dbd13b3b276
6763249 eft is disabled on fmadm repair when serdsuffix feature is used
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
7275
diff
changeset
|
1214 (void) printf(" %s", name); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1215 if (list->pct && pct > 0 && pct < 100) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1216 if (list->count > 1) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1217 if (full) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1218 (void) printf(" %d @ %s %d%%\n", list->count, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1219 dgettext("FMD", "max"), list->max_pct); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1220 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1221 (void) printf(" %s %d%%\n", |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1222 dgettext("FMD", "max"), list->max_pct); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1223 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1224 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1225 (void) printf(" %d%%\n", list->pct); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1226 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1227 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1228 (void) printf("\n"); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1229 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1230 if (func1) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1231 func1(list->status, padding); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1232 n = 1; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1233 j = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1234 while ((list = list->next) != end) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1235 if (limit == 0 || n < limit) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1236 print_name(list, func, padding, &n, pct, full); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1237 if (func1) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1238 func1(list->status, padding); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1239 } else |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1240 j++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1241 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1242 if (j == 1) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1243 print_name(list->prev, func, padding, &n, pct, full); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1244 } else if (j > 1) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1245 (void) printf("%s... %d %s\n", padding, j, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1246 dgettext("FMD", "more entries suppressed," |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1247 " use -v option for full list")); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1248 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1249 free(padding); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1250 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1251 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1252 static int |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1253 asru_same_status(name_list_t *list) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1254 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1255 name_list_t *end = list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1256 int status = list->status; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1257 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1258 while ((list = list->next) != end) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1259 if (status == -1) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1260 status = list->status; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1261 continue; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1262 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1263 if (list->status != -1 && status != list->status) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1264 status = -1; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1265 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1266 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1267 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1268 return (status); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1269 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1270 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1271 static int |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1272 serial_in_fru(name_list_t *fru, name_list_t *serial) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1273 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1274 name_list_t *sp = serial; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1275 name_list_t *fp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1276 int nserial = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1277 int found = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1278 char buf[128]; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1279 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1280 while (sp) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1281 fp = fru; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1282 nserial++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1283 (void) snprintf(buf, sizeof (buf), "serial=%s", sp->name); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1284 buf[sizeof (buf) - 1] = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1285 while (fp) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1286 if (strstr(fp->name, buf) != NULL) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1287 found++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1288 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1289 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1290 fp = fp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1291 if (fp == fru) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1292 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1293 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1294 sp = sp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1295 if (sp == serial) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1296 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1297 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1298 return (found == nserial ? 1 : 0); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1299 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1300 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1301 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1302 print_sup_record(status_record_t *srp, int opt_i, int full) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1303 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1304 char buf[32]; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1305 uurec_t *uurp = srp->uurec; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1306 int n, j, k, max; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1307 int status; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1308 ari_list_t *ari_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1309 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1310 n = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1311 max = max_fault; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1312 if (max < 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1313 max = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1314 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1315 j = max / 2; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1316 max -= j; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1317 k = srp->nrecs - max; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1318 while ((uurp = uurp->next) != NULL) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1319 if (full || n < j || n >= k || max_fault == 0 || |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1320 srp->nrecs == max_fault+1) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1321 if (opt_i) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1322 ari_list = uurp->ari_uuid_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1323 while (ari_list) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1324 (void) printf("%-15s %s\n", |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1325 format_date(buf, sizeof (buf), |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1326 uurp->sec), ari_list->ari_uuid); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1327 ari_list = ari_list->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1328 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1329 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1330 (void) printf("%-15s %s\n", |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1331 format_date(buf, sizeof (buf), uurp->sec), |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1332 uurp->uuid); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1333 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1334 } else if (n == j) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1335 (void) printf("... %d %s\n", srp->nrecs - max_fault, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1336 dgettext("FMD", "more entries suppressed")); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1337 n++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1338 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1339 (void) printf("\n"); |
9120
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1340 (void) printf("%s %s", dgettext("FMD", "Host :"), |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1341 srp->host->server); |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1342 if (srp->host->domain) |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1343 (void) printf("\t%s %s", dgettext("FMD", "Domain :"), |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1344 srp->host->domain); |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1345 (void) printf("\n%s %s", dgettext("FMD", "Platform :"), |
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1346 srp->host->platform); |
10462
ec0e4f3134ef
PSARC/2007/650 Product Serial Number for FMRI
Cheng Sean Ye <Sean.Ye@Sun.COM>
parents:
10234
diff
changeset
|
1347 (void) printf("\t%s %s", dgettext("FMD", "Chassis_id :"), |
9120
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1348 srp->host->chassis ? srp->host->chassis : ""); |
10462
ec0e4f3134ef
PSARC/2007/650 Product Serial Number for FMRI
Cheng Sean Ye <Sean.Ye@Sun.COM>
parents:
10234
diff
changeset
|
1349 (void) printf("\n%s %s\n\n", dgettext("FMD", "Product_sn :"), |
ec0e4f3134ef
PSARC/2007/650 Product Serial Number for FMRI
Cheng Sean Ye <Sean.Ye@Sun.COM>
parents:
10234
diff
changeset
|
1350 srp->host->product_sn? srp->host->product_sn : ""); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1351 if (srp->class) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1352 print_name_list(srp->class, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1353 dgettext("FMD", "Fault class :"), NULL, 0, srp->class->pct, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1354 NULL, full); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1355 if (srp->asru) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1356 status = asru_same_status(srp->asru); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1357 if (status != -1) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1358 print_name_list(srp->asru, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1359 dgettext("FMD", "Affects :"), NULL, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1360 full ? 0 : max_display, 0, NULL, full); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1361 print_asru_status(status, " "); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1362 } else |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1363 print_name_list(srp->asru, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1364 dgettext("FMD", "Affects :"), NULL, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1365 full ? 0 : max_display, 0, print_asru_status, full); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1366 } |
9120
fe1f7d8cd967
6533823 need better way of proxying faults across event transport
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
8245
diff
changeset
|
1367 if (full || srp->fru == NULL || srp->asru == NULL) { |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1368 if (srp->resource) { |
10656
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
1369 status = asru_same_status(srp->resource); |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
1370 if (status != -1) { |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
1371 print_name_list(srp->resource, |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
1372 dgettext("FMD", "Problem in :"), NULL, |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
1373 full ? 0 : max_display, 0, NULL, full); |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
1374 print_rsrc_status(status, " "); |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
1375 } else |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
1376 print_name_list(srp->resource, |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
1377 dgettext("FMD", "Problem in :"), |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
1378 NULL, full ? 0 : max_display, 0, |
217544b3cf73
6778240 generic historic diagnosis rules
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10462
diff
changeset
|
1379 print_rsrc_status, full); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1380 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1381 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1382 if (srp->fru) { |
6228
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1383 status = asru_same_status(srp->fru); |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1384 if (status != -1) { |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1385 print_name_list(srp->fru, dgettext("FMD", |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1386 "FRU :"), get_fmri_label, 0, |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1387 srp->fru->pct == 100 ? 100 : srp->fru->max_pct, |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1388 NULL, full); |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1389 print_fru_status(status, " "); |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1390 } else |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1391 print_name_list(srp->fru, dgettext("FMD", |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1392 "FRU :"), get_fmri_label, 0, |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1393 srp->fru->pct == 100 ? 100 : srp->fru->max_pct, |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1394 print_fru_status, full); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1395 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1396 if (srp->serial && !serial_in_fru(srp->fru, srp->serial) && |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1397 !serial_in_fru(srp->asru, srp->serial)) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1398 print_name_list(srp->serial, dgettext("FMD", "Serial ID. :"), |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1399 NULL, 0, 0, NULL, full); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1400 } |
10234
c4cea2ed5803
6839705 libtopo needs updates in order to cope with ILOM 3
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9501
diff
changeset
|
1401 print_dict_info(srp->uurec->event); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1402 (void) printf("\n"); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1403 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1404 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1405 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1406 print_status_record(status_record_t *srp, int summary, int opt_i, int full) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1407 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1408 char buf[32]; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1409 uurec_t *uurp = srp->uurec; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1410 static int header = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1411 char *head; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1412 ari_list_t *ari_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1413 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1414 if (!summary || !header) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1415 if (opt_i) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1416 head = "--------------- " |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1417 "------------------------------------ " |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1418 "-------------- ---------\n" |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1419 "TIME CACHE-ID" |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1420 " MSG-ID" |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1421 " SEVERITY\n--------------- " |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1422 "------------------------------------ " |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1423 " -------------- ---------"; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1424 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1425 head = "--------------- " |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1426 "------------------------------------ " |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1427 "-------------- ---------\n" |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1428 "TIME EVENT-ID" |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1429 " MSG-ID" |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1430 " SEVERITY\n--------------- " |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1431 "------------------------------------ " |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1432 " -------------- ---------"; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1433 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1434 (void) printf("%s\n", dgettext("FMD", head)); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1435 header = 1; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1436 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1437 if (opt_i) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1438 ari_list = uurp->ari_uuid_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1439 while (ari_list) { |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1440 (void) printf("%-15s %-37s %-14s %-9s %s\n", |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1441 format_date(buf, sizeof (buf), uurp->sec), |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1442 ari_list->ari_uuid, srp->msgid, srp->severity, |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1443 srp->injected ? dgettext("FMD", "injected") : ""); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1444 ari_list = ari_list->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1445 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1446 } else { |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1447 (void) printf("%-15s %-37s %-14s %-9s %s\n", |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1448 format_date(buf, sizeof (buf), uurp->sec), |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1449 uurp->uuid, srp->msgid, srp->severity, |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1450 srp->injected ? dgettext("FMD", "injected") : ""); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1451 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1452 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1453 if (!summary) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1454 print_sup_record(srp, opt_i, full); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1455 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1456 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1457 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1458 print_catalog(int summary, int opt_a, int full, int opt_i, int page_feed) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1459 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1460 status_record_t *srp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1461 sr_list_t *slp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1462 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1463 slp = status_rec_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1464 if (slp) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1465 for (;;) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1466 srp = slp->status_record; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1467 if (opt_a || srp->not_suppressed) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1468 if (page_feed) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1469 (void) printf("\f\n"); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1470 print_status_record(srp, summary, opt_i, full); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1471 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1472 if (slp->next == status_rec_list) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1473 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1474 slp = slp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1475 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1476 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1477 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1478 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1479 static name_list_t * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1480 find_fru(status_record_t *srp, char *resource) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1481 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1482 name_list_t *rt = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1483 name_list_t *fru = srp->fru; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1484 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1485 while (fru) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1486 if (strcmp(resource, fru->name) == 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1487 rt = fru; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1488 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1489 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1490 fru = fru->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1491 if (fru == srp->fru) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1492 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1493 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1494 return (rt); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1495 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1496 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1497 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1498 print_fru_line(name_list_t *fru, char *uuid) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1499 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1500 if (fru->pct == 100) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1501 (void) printf("%s %d %s %d%%\n", uuid, fru->count, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1502 dgettext("FMD", "suspects in this FRU total certainty"), |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1503 100); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1504 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1505 (void) printf("%s %d %s %d%%\n", uuid, fru->count, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1506 dgettext("FMD", "suspects in this FRU max certainty"), |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1507 fru->max_pct); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1508 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1509 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1510 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1511 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1512 print_fru(int summary, int opt_a, int opt_i, int page_feed) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1513 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1514 resource_list_t *tp = status_fru_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1515 status_record_t *srp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1516 sr_list_t *slp, *end; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1517 char *msgid, *fru_label; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1518 uurec_t *uurp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1519 name_list_t *fru; |
6228
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1520 int status; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1521 ari_list_t *ari_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1522 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1523 while (tp) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1524 if (opt_a || tp->not_suppressed) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1525 if (page_feed) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1526 (void) printf("\f\n"); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1527 if (!summary) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1528 (void) printf("-----------------------------" |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1529 "---------------------------------------" |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1530 "----------\n"); |
6002 | 1531 slp = tp->status_rec_list; |
1532 end = slp; | |
1533 do { | |
1534 srp = slp->status_record; | |
1535 fru = find_fru(srp, tp->resource); | |
1536 if (fru) { | |
1537 if (fru->label) | |
6228
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1538 (void) printf("\"%s\" (%s) ", |
6002 | 1539 fru->label, fru->name); |
6228
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1540 else if ((fru_label = get_fmri_label( |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1541 fru->name)) != NULL) { |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1542 (void) printf("\"%s\" (%s) ", |
6002 | 1543 fru_label, fru->name); |
1544 free(fru_label); | |
1545 } else | |
6228
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1546 (void) printf("%s ", |
6002 | 1547 fru->name); |
1548 break; | |
1549 } | |
1550 slp = slp->next; | |
1551 } while (slp != end); | |
1552 | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1553 slp = tp->status_rec_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1554 end = slp; |
6228
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1555 status = 0; |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1556 do { |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1557 srp = slp->status_record; |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1558 fru = srp->fru; |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1559 while (fru) { |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1560 if (strcmp(tp->resource, |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1561 fru->name) == 0) |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1562 status |= fru->status; |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1563 fru = fru->next; |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1564 if (fru == srp->fru) |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1565 break; |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1566 } |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1567 slp = slp->next; |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1568 } while (slp != end); |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1569 if (status & FM_SUSPECT_NOT_PRESENT) |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1570 (void) printf(dgettext("FMD", "not present")); |
6228
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1571 else if (status & FM_SUSPECT_FAULTY) |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1572 (void) printf(dgettext("FMD", "faulty")); |
7275 | 1573 else if (status & FM_SUSPECT_REPLACED) |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1574 (void) printf(dgettext("FMD", "replaced")); |
7275 | 1575 else if (status & FM_SUSPECT_REPAIRED) |
1576 (void) printf(dgettext("FMD", | |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1577 "repair attempted")); |
7275 | 1578 else if (status & FM_SUSPECT_ACQUITTED) |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1579 (void) printf(dgettext("FMD", "acquitted")); |
6228
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1580 else |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1581 (void) printf(dgettext("FMD", "removed")); |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1582 |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1583 if (tp->injected) |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1584 (void) printf(dgettext("FMD", " injected\n")); |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1585 else |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1586 (void) printf(dgettext("FMD", "\n")); |
6228
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1587 |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1588 slp = tp->status_rec_list; |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1589 end = slp; |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1590 do { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1591 srp = slp->status_record; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1592 uurp = srp->uurec; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1593 fru = find_fru(srp, tp->resource); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1594 if (fru) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1595 if (opt_i) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1596 ari_list = uurp->ari_uuid_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1597 while (ari_list) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1598 print_fru_line(fru, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1599 ari_list->ari_uuid); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1600 ari_list = |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1601 ari_list->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1602 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1603 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1604 print_fru_line(fru, uurp->uuid); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1605 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1606 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1607 slp = slp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1608 } while (slp != end); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1609 if (!summary) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1610 slp = tp->status_rec_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1611 end = slp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1612 srp = slp->status_record; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1613 if (srp->serial && |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1614 !serial_in_fru(srp->fru, srp->serial)) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1615 print_name_list(srp->serial, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1616 dgettext("FMD", "Serial ID. :"), |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1617 NULL, 0, 0, NULL, 1); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1618 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1619 msgid = NULL; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1620 do { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1621 if (msgid == NULL || |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1622 strcmp(msgid, srp->msgid) != 0) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1623 msgid = srp->msgid; |
10234
c4cea2ed5803
6839705 libtopo needs updates in order to cope with ILOM 3
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9501
diff
changeset
|
1624 print_dict_info(uurp->event); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1625 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1626 slp = slp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1627 } while (slp != end); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1628 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1629 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1630 tp = tp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1631 if (tp == status_fru_list) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1632 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1633 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1634 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1635 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1636 static void |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1637 print_asru(int opt_a) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1638 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1639 resource_list_t *tp = status_asru_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1640 status_record_t *srp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1641 sr_list_t *slp, *end; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1642 char *msg; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1643 int status; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1644 name_list_t *asru; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1645 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1646 while (tp) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1647 if (opt_a || tp->not_suppressed) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1648 status = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1649 slp = tp->status_rec_list; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1650 end = slp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1651 do { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1652 srp = slp->status_record; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1653 asru = srp->asru; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1654 while (asru) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1655 if (strcmp(tp->resource, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1656 asru->name) == 0) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1657 status |= asru->status; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1658 asru = asru->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1659 if (asru == srp->asru) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1660 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1661 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1662 slp = slp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1663 } while (slp != end); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1664 switch (status) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1665 case 0: |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1666 msg = dgettext("FMD", "ok"); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1667 break; |
7275 | 1668 case FM_SUSPECT_DEGRADED: |
1669 msg = dgettext("FMD", "degraded"); | |
1670 break; | |
1671 case FM_SUSPECT_FAULTY | FM_SUSPECT_DEGRADED: | |
1672 msg = dgettext("FMD", "degraded"); | |
1673 break; | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1674 case FM_SUSPECT_FAULTY: |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1675 msg = dgettext("FMD", "degraded"); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1676 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1677 case FM_SUSPECT_UNUSABLE: |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1678 msg = dgettext("FMD", "unknown"); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1679 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1680 case FM_SUSPECT_FAULTY | FM_SUSPECT_UNUSABLE: |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1681 msg = dgettext("FMD", "faulted"); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1682 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1683 default: |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1684 msg = ""; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1685 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1686 } |
10928
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1687 (void) printf("%-69s %s", tp->resource, msg); |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1688 if (tp->injected) |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1689 (void) printf(dgettext("FMD", " injected\n")); |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1690 else |
eb060666c73f
6885689 syseventd: [daemon.error] Fatal:attempting to dump core on snv_124
Stephen Hanson <Stephen.Hanson@Sun.COM>
parents:
10656
diff
changeset
|
1691 (void) printf(dgettext("FMD", "\n")); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1692 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1693 tp = tp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1694 if (tp == status_asru_list) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1695 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1696 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1697 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1698 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1699 static int |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1700 uuid_in_list(char *uuid, uurec_select_t *uurecp) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1701 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1702 while (uurecp) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1703 if (strcmp(uuid, uurecp->uuid) == 0) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1704 return (1); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1705 uurecp = uurecp->next; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1706 } |
0 | 1707 return (0); |
1708 } | |
1709 | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1710 static int |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1711 dfault_rec(const fmd_adm_caseinfo_t *acp, void *arg) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1712 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1713 int64_t *diag_time; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1714 uint_t nelem; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1715 int rt = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1716 char *uuid = "-"; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1717 uurec_select_t *uurecp = (uurec_select_t *)arg; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1718 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1719 if (nvlist_lookup_int64_array(acp->aci_event, FM_SUSPECT_DIAG_TIME, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1720 &diag_time, &nelem) == 0 && nelem >= 2) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1721 (void) nvlist_lookup_string(acp->aci_event, FM_SUSPECT_UUID, |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1722 &uuid); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1723 if (uurecp == NULL || uuid_in_list(uuid, uurecp)) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1724 add_fault_record_to_catalog(acp->aci_event, *diag_time, |
9501
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
1725 uuid); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1726 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1727 rt = -1; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1728 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1729 return (rt); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1730 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1731 |
0 | 1732 /*ARGSUSED*/ |
1733 static int | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1734 dstatus_rec(const fmd_adm_rsrcinfo_t *ari, void *unused) |
0 | 1735 { |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1736 update_asru_state_in_catalog(ari->ari_case, ari->ari_uuid); |
0 | 1737 return (0); |
1738 } | |
1739 | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1740 static int |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1741 get_cases_from_fmd(fmd_adm_t *adm, uurec_select_t *uurecp, int opt_i) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1742 { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1743 int rt = FMADM_EXIT_SUCCESS; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1744 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1745 /* |
10234
c4cea2ed5803
6839705 libtopo needs updates in order to cope with ILOM 3
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9501
diff
changeset
|
1746 * These calls may fail with Protocol error if message payload is |
c4cea2ed5803
6839705 libtopo needs updates in order to cope with ILOM 3
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9501
diff
changeset
|
1747 * too big |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1748 */ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1749 if (fmd_adm_case_iter(adm, NULL, dfault_rec, uurecp) != 0) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1750 die("failed to get case list from fmd"); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1751 if (opt_i && fmd_adm_rsrc_iter(adm, 1, dstatus_rec, NULL) != 0) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1752 die("failed to get case status from fmd"); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1753 return (rt); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1754 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1755 |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1756 /* |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1757 * fmadm faulty command |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1758 * |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1759 * -a show hidden fault records |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1760 * -f show faulty fru's |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1761 * -g force grouping of similar faults on the same fru |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1762 * -n number of fault records to display |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1763 * -p pipe output through pager |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1764 * -r show faulty asru's |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1765 * -s print summary of first fault |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1766 * -u print listed uuid's only |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1767 * -v full output |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1768 */ |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1769 |
0 | 1770 int |
1771 cmd_faulty(fmd_adm_t *adm, int argc, char *argv[]) | |
1772 { | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1773 int opt_a = 0, opt_v = 0, opt_p = 0, opt_s = 0, opt_r = 0, opt_f = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1774 int opt_i = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1775 char *pager; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1776 FILE *fp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1777 int rt, c, stat; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1778 uurec_select_t *tp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1779 uurec_select_t *uurecp = NULL; |
0 | 1780 |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1781 while ((c = getopt(argc, argv, "afgin:prsu:v")) != EOF) { |
0 | 1782 switch (c) { |
1783 case 'a': | |
1784 opt_a++; | |
1785 break; | |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1786 case 'f': |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1787 opt_f++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1788 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1789 case 'g': |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1790 opt_g++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1791 break; |
0 | 1792 case 'i': |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1793 opt_i++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1794 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1795 case 'n': |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1796 max_fault = atoi(optarg); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1797 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1798 case 'p': |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1799 opt_p++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1800 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1801 case 'r': |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1802 opt_r++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1803 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1804 case 's': |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1805 opt_s++; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1806 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1807 case 'u': |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1808 tp = (uurec_select_t *)malloc(sizeof (uurec_select_t)); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1809 tp->uuid = optarg; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1810 tp->next = uurecp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1811 uurecp = tp; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1812 opt_a = 1; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1813 break; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1814 case 'v': |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1815 opt_v++; |
0 | 1816 break; |
1817 default: | |
1818 return (FMADM_EXIT_USAGE); | |
1819 } | |
1820 } | |
1821 if (optind < argc) | |
1822 return (FMADM_EXIT_USAGE); | |
1823 | |
9501
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
1824 if ((fmadm_msghdl = fmd_msg_init(NULL, FMD_MSG_VERSION)) == NULL) |
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
1825 return (FMADM_EXIT_ERROR); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1826 rt = get_cases_from_fmd(adm, uurecp, opt_i); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1827 if (opt_p) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1828 if ((pager = getenv("PAGER")) == NULL) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1829 pager = "/usr/bin/more"; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1830 fp = popen(pager, "w"); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1831 if (fp == NULL) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1832 rt = FMADM_EXIT_ERROR; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1833 opt_p = 0; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1834 } else { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1835 dup2(fileno(fp), 1); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1836 setbuf(stdout, NULL); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1837 (void) fclose(fp); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1838 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1839 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1840 max_display = max_fault; |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1841 if (opt_f) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1842 print_fru(opt_s, opt_a, opt_i, opt_p && !opt_s); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1843 if (opt_r) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1844 print_asru(opt_a); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1845 if (opt_f == 0 && opt_r == 0) |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1846 print_catalog(opt_s, opt_a, opt_v, opt_i, opt_p && !opt_s); |
9501
f84d3cc28d24
PSARC 2009/265 fmdump -m
Robert Johnston <Robert.Johnston@Sun.COM>
parents:
9120
diff
changeset
|
1847 fmd_msg_fini(fmadm_msghdl); |
5255
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1848 label_release_topo(); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1849 if (opt_p) { |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1850 (void) fclose(stdout); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1851 (void) wait(&stat); |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1852 } |
8dc347a9bd70
PSARC 2007/460 fmadm faulty command new output and arguments
stephh
parents:
0
diff
changeset
|
1853 return (rt); |
0 | 1854 } |
1855 | |
1856 int | |
1857 cmd_flush(fmd_adm_t *adm, int argc, char *argv[]) | |
1858 { | |
1859 int i, status = FMADM_EXIT_SUCCESS; | |
1860 | |
1861 if (argc < 2 || (i = getopt(argc, argv, "")) != EOF) | |
1862 return (FMADM_EXIT_USAGE); | |
1863 | |
1864 for (i = 1; i < argc; i++) { | |
1865 if (fmd_adm_rsrc_flush(adm, argv[i]) != 0) { | |
1866 warn("failed to flush %s", argv[i]); | |
1867 status = FMADM_EXIT_ERROR; | |
1868 } else | |
1869 note("flushed resource history for %s\n", argv[i]); | |
1870 } | |
1871 | |
1872 return (status); | |
1873 } | |
1874 | |
1875 int | |
1876 cmd_repair(fmd_adm_t *adm, int argc, char *argv[]) | |
1877 { | |
1878 int err; | |
1879 | |
1880 if (getopt(argc, argv, "") != EOF) | |
1881 return (FMADM_EXIT_USAGE); | |
1882 | |
1883 if (argc - optind != 1) | |
1884 return (FMADM_EXIT_USAGE); | |
1885 | |
1886 /* | |
7275 | 1887 * argument could be a uuid, an fmri (asru, fru or resource) |
6228
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1888 * or a label. Try uuid first, If that fails try the others. |
0 | 1889 */ |
6228
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1890 err = fmd_adm_case_repair(adm, argv[optind]); |
b8f7c3bfc29b
6372069 fmadm repair command should accept the FRU label as an argument
stephh
parents:
6002
diff
changeset
|
1891 if (err != 0) |
7275 | 1892 err = fmd_adm_rsrc_repaired(adm, argv[optind]); |
0 | 1893 |
1894 if (err != 0) | |
1895 die("failed to record repair to %s", argv[optind]); | |
1896 | |
1897 note("recorded repair to %s\n", argv[optind]); | |
1898 return (FMADM_EXIT_SUCCESS); | |
1899 } | |
7275 | 1900 |
1901 int | |
1902 cmd_repaired(fmd_adm_t *adm, int argc, char *argv[]) | |
1903 { | |
1904 int err; | |
1905 | |
1906 if (getopt(argc, argv, "") != EOF) | |
1907 return (FMADM_EXIT_USAGE); | |
1908 | |
1909 if (argc - optind != 1) | |
1910 return (FMADM_EXIT_USAGE); | |
1911 | |
1912 /* | |
1913 * argument could be an fmri (asru, fru or resource) or a label. | |
1914 */ | |
1915 err = fmd_adm_rsrc_repaired(adm, argv[optind]); | |
1916 if (err != 0) | |
1917 die("failed to record repair to %s", argv[optind]); | |
1918 | |
1919 note("recorded repair to of %s\n", argv[optind]); | |
1920 return (FMADM_EXIT_SUCCESS); | |
1921 } | |
1922 | |
1923 int | |
1924 cmd_replaced(fmd_adm_t *adm, int argc, char *argv[]) | |
1925 { | |
1926 int err; | |
1927 | |
1928 if (getopt(argc, argv, "") != EOF) | |
1929 return (FMADM_EXIT_USAGE); | |
1930 | |
1931 if (argc - optind != 1) | |
1932 return (FMADM_EXIT_USAGE); | |
1933 | |
1934 /* | |
1935 * argument could be an fmri (asru, fru or resource) or a label. | |
1936 */ | |
1937 err = fmd_adm_rsrc_replaced(adm, argv[optind]); | |
1938 if (err != 0) | |
1939 die("failed to record replacement of %s", argv[optind]); | |
1940 | |
1941 note("recorded replacement of %s\n", argv[optind]); | |
1942 return (FMADM_EXIT_SUCCESS); | |
1943 } | |
1944 | |
1945 int | |
1946 cmd_acquit(fmd_adm_t *adm, int argc, char *argv[]) | |
1947 { | |
1948 int err; | |
1949 | |
1950 if (getopt(argc, argv, "") != EOF) | |
1951 return (FMADM_EXIT_USAGE); | |
1952 | |
1953 if (argc - optind != 1 && argc - optind != 2) | |
1954 return (FMADM_EXIT_USAGE); | |
1955 | |
1956 /* | |
1957 * argument could be a uuid, an fmri (asru, fru or resource) | |
1958 * or a label. Or it could be a uuid and an fmri or label. | |
1959 */ | |
1960 if (argc - optind == 2) { | |
1961 err = fmd_adm_rsrc_acquit(adm, argv[optind], argv[optind + 1]); | |
1962 if (err != 0) | |
1963 err = fmd_adm_rsrc_acquit(adm, argv[optind + 1], | |
1964 argv[optind]); | |
1965 } else { | |
1966 err = fmd_adm_case_acquit(adm, argv[optind]); | |
1967 if (err != 0) | |
1968 err = fmd_adm_rsrc_acquit(adm, argv[optind], ""); | |
1969 } | |
1970 | |
1971 if (err != 0) | |
1972 die("failed to record acquital of %s", argv[optind]); | |
1973 | |
1974 note("recorded acquital of %s\n", argv[optind]); | |
1975 return (FMADM_EXIT_SUCCESS); | |
1976 } |