1 /* SPDX-License-Identifier: GPL-2.0-only */ 2 /* 3 * include/asm-parisc/pdc_chassis.h 4 * 5 * Copyright (C) 2002 Laurent Canet <canetl@esiee.fr> 6 * Copyright (C) 2002 Thibaut Varene <varenet@parisc-linux.org> 7 * 8 * TODO: - handle processor number on SMP systems (Reporting Entity ID) 9 * - handle message ID 10 * - handle timestamps 11 */ 12 13 14 #ifndef _PARISC_PDC_CHASSIS_H 15 #define _PARISC_PDC_CHASSIS_H 16 17 /* 18 * ---------- 19 * Prototypes 20 * ---------- 21 */ 22 23 int pdc_chassis_send_status(int message); 24 void parisc_pdc_chassis_init(void); 25 26 27 /* 28 * ----------------- 29 * Direct call names 30 * ----------------- 31 * They setup everything for you, the Log message and the corresponding LED state 32 */ 33 34 #define PDC_CHASSIS_DIRECT_BSTART 0 35 #define PDC_CHASSIS_DIRECT_BCOMPLETE 1 36 #define PDC_CHASSIS_DIRECT_SHUTDOWN 2 37 #define PDC_CHASSIS_DIRECT_PANIC 3 38 #define PDC_CHASSIS_DIRECT_HPMC 4 39 #define PDC_CHASSIS_DIRECT_LPMC 5 40 #define PDC_CHASSIS_DIRECT_DUMP 6 /* not yet implemented */ 41 #define PDC_CHASSIS_DIRECT_OOPS 7 /* not yet implemented */ 42 43 44 /* 45 * ------------ 46 * LEDs control 47 * ------------ 48 * Set the three LEDs -- Run, Attn, and Fault. 49 */ 50 51 /* Old PDC LED control */ 52 #define PDC_CHASSIS_DISP_DATA(v) ((unsigned long)(v) << 17) 53 54 /* 55 * Available PDC PAT LED states 56 */ 57 58 #define PDC_CHASSIS_LED_RUN_OFF (0ULL << 4) 59 #define PDC_CHASSIS_LED_RUN_FLASH (1ULL << 4) 60 #define PDC_CHASSIS_LED_RUN_ON (2ULL << 4) 61 #define PDC_CHASSIS_LED_RUN_NC (3ULL << 4) 62 #define PDC_CHASSIS_LED_ATTN_OFF (0ULL << 6) 63 #define PDC_CHASSIS_LED_ATTN_FLASH (1ULL << 6) 64 #define PDC_CHASSIS_LED_ATTN_NC (3ULL << 6) /* ATTN ON is invalid */ 65 #define PDC_CHASSIS_LED_FAULT_OFF (0ULL << 8) 66 #define PDC_CHASSIS_LED_FAULT_FLASH (1ULL << 8) 67 #define PDC_CHASSIS_LED_FAULT_ON (2ULL << 8) 68 #define PDC_CHASSIS_LED_FAULT_NC (3ULL << 8) 69 #define PDC_CHASSIS_LED_VALID (1ULL << 10) 70 71 /* 72 * Valid PDC PAT LED states combinations 73 */ 74 75 /* System running normally */ 76 #define PDC_CHASSIS_LSTATE_RUN_NORMAL (PDC_CHASSIS_LED_RUN_ON | \ 77 PDC_CHASSIS_LED_ATTN_OFF | \ 78 PDC_CHASSIS_LED_FAULT_OFF | \ 79 PDC_CHASSIS_LED_VALID ) 80 /* System crashed and rebooted itself successfully */ 81 #define PDC_CHASSIS_LSTATE_RUN_CRASHREC (PDC_CHASSIS_LED_RUN_ON | \ 82 PDC_CHASSIS_LED_ATTN_OFF | \ 83 PDC_CHASSIS_LED_FAULT_FLASH | \ 84 PDC_CHASSIS_LED_VALID ) 85 /* There was a system interruption that did not take the system down */ 86 #define PDC_CHASSIS_LSTATE_RUN_SYSINT (PDC_CHASSIS_LED_RUN_ON | \ 87 PDC_CHASSIS_LED_ATTN_FLASH | \ 88 PDC_CHASSIS_LED_FAULT_OFF | \ 89 PDC_CHASSIS_LED_VALID ) 90 /* System running and unexpected reboot or non-critical error detected */ 91 #define PDC_CHASSIS_LSTATE_RUN_NCRIT (PDC_CHASSIS_LED_RUN_ON | \ 92 PDC_CHASSIS_LED_ATTN_FLASH | \ 93 PDC_CHASSIS_LED_FAULT_FLASH | \ 94 PDC_CHASSIS_LED_VALID ) 95 /* Executing non-OS code */ 96 #define PDC_CHASSIS_LSTATE_NONOS (PDC_CHASSIS_LED_RUN_FLASH | \ 97 PDC_CHASSIS_LED_ATTN_OFF | \ 98 PDC_CHASSIS_LED_FAULT_OFF | \ 99 PDC_CHASSIS_LED_VALID ) 100 /* Boot failed - Executing non-OS code */ 101 #define PDC_CHASSIS_LSTATE_NONOS_BFAIL (PDC_CHASSIS_LED_RUN_FLASH | \ 102 PDC_CHASSIS_LED_ATTN_OFF | \ 103 PDC_CHASSIS_LED_FAULT_ON | \ 104 PDC_CHASSIS_LED_VALID ) 105 /* Unexpected reboot occurred - Executing non-OS code */ 106 #define PDC_CHASSIS_LSTATE_NONOS_UNEXP (PDC_CHASSIS_LED_RUN_FLASH | \ 107 PDC_CHASSIS_LED_ATTN_OFF | \ 108 PDC_CHASSIS_LED_FAULT_FLASH | \ 109 PDC_CHASSIS_LED_VALID ) 110 /* Executing non-OS code - Non-critical error detected */ 111 #define PDC_CHASSIS_LSTATE_NONOS_NCRIT (PDC_CHASSIS_LED_RUN_FLASH | \ 112 PDC_CHASSIS_LED_ATTN_FLASH | \ 113 PDC_CHASSIS_LED_FAULT_OFF | \ 114 PDC_CHASSIS_LED_VALID ) 115 /* Boot failed - Executing non-OS code - Non-critical error detected */ 116 #define PDC_CHASSIS_LSTATE_BFAIL_NCRIT (PDC_CHASSIS_LED_RUN_FLASH | \ 117 PDC_CHASSIS_LED_ATTN_FLASH | \ 118 PDC_CHASSIS_LED_FAULT_ON | \ 119 PDC_CHASSIS_LED_VALID ) 120 /* Unexpected reboot/recovering - Executing non-OS code - Non-critical error detected */ 121 #define PDC_CHASSIS_LSTATE_UNEXP_NCRIT (PDC_CHASSIS_LED_RUN_FLASH | \ 122 PDC_CHASSIS_LED_ATTN_FLASH | \ 123 PDC_CHASSIS_LED_FAULT_FLASH | \ 124 PDC_CHASSIS_LED_VALID ) 125 /* Cannot execute PDC */ 126 #define PDC_CHASSIS_LSTATE_CANNOT_PDC (PDC_CHASSIS_LED_RUN_OFF | \ 127 PDC_CHASSIS_LED_ATTN_OFF | \ 128 PDC_CHASSIS_LED_FAULT_OFF | \ 129 PDC_CHASSIS_LED_VALID ) 130 /* Boot failed - OS not up - PDC has detected a failure that prevents boot */ 131 #define PDC_CHASSIS_LSTATE_FATAL_BFAIL (PDC_CHASSIS_LED_RUN_OFF | \ 132 PDC_CHASSIS_LED_ATTN_OFF | \ 133 PDC_CHASSIS_LED_FAULT_ON | \ 134 PDC_CHASSIS_LED_VALID ) 135 /* No code running - Non-critical error detected (double fault situation) */ 136 #define PDC_CHASSIS_LSTATE_NOCODE_NCRIT (PDC_CHASSIS_LED_RUN_OFF | \ 137 PDC_CHASSIS_LED_ATTN_FLASH | \ 138 PDC_CHASSIS_LED_FAULT_OFF | \ 139 PDC_CHASSIS_LED_VALID ) 140 /* Boot failed - OS not up - Fatal failure detected - Non-critical error detected */ 141 #define PDC_CHASSIS_LSTATE_FATAL_NCRIT (PDC_CHASSIS_LED_RUN_OFF | \ 142 PDC_CHASSIS_LED_ATTN_FLASH | \ 143 PDC_CHASSIS_LED_FAULT_ON | \ 144 PDC_CHASSIS_LED_VALID ) 145 /* All other states are invalid */ 146 147 148 /* 149 * -------------- 150 * PDC Log events 151 * -------------- 152 * Here follows bits needed to fill up the log event sent to PDC_CHASSIS 153 * The log message contains: Alert level, Source, Source detail, 154 * Source ID, Problem detail, Caller activity, Activity status, 155 * Caller subactivity, Reporting entity type, Reporting entity ID, 156 * Data type, Unique message ID and EOM. 157 */ 158 159 /* Alert level */ 160 #define PDC_CHASSIS_ALERT_FORWARD (0ULL << 36) /* no failure detected */ 161 #define PDC_CHASSIS_ALERT_SERPROC (1ULL << 36) /* service proc - no failure */ 162 #define PDC_CHASSIS_ALERT_NURGENT (2ULL << 36) /* non-urgent operator attn */ 163 #define PDC_CHASSIS_ALERT_BLOCKED (3ULL << 36) /* system blocked */ 164 #define PDC_CHASSIS_ALERT_CONF_CHG (4ULL << 36) /* unexpected configuration change */ 165 #define PDC_CHASSIS_ALERT_ENV_PB (5ULL << 36) /* boot possible, environmental pb */ 166 #define PDC_CHASSIS_ALERT_PENDING (6ULL << 36) /* boot possible, pending failure */ 167 #define PDC_CHASSIS_ALERT_PERF_IMP (8ULL << 36) /* boot possible, performance impaired */ 168 #define PDC_CHASSIS_ALERT_FUNC_IMP (10ULL << 36) /* boot possible, functionality impaired */ 169 #define PDC_CHASSIS_ALERT_SOFT_FAIL (12ULL << 36) /* software failure */ 170 #define PDC_CHASSIS_ALERT_HANG (13ULL << 36) /* system hang */ 171 #define PDC_CHASSIS_ALERT_ENV_FATAL (14ULL << 36) /* fatal power or environmental pb */ 172 #define PDC_CHASSIS_ALERT_HW_FATAL (15ULL << 36) /* fatal hardware problem */ 173 174 /* Source */ 175 #define PDC_CHASSIS_SRC_NONE (0ULL << 28) /* unknown, no source stated */ 176 #define PDC_CHASSIS_SRC_PROC (1ULL << 28) /* processor */ 177 /* For later use ? */ 178 #define PDC_CHASSIS_SRC_PROC_CACHE (2ULL << 28) /* processor cache*/ 179 #define PDC_CHASSIS_SRC_PDH (3ULL << 28) /* processor dependent hardware */ 180 #define PDC_CHASSIS_SRC_PWR (4ULL << 28) /* power */ 181 #define PDC_CHASSIS_SRC_FAB (5ULL << 28) /* fabric connector */ 182 #define PDC_CHASSIS_SRC_PLATi (6ULL << 28) /* platform */ 183 #define PDC_CHASSIS_SRC_MEM (7ULL << 28) /* memory */ 184 #define PDC_CHASSIS_SRC_IO (8ULL << 28) /* I/O */ 185 #define PDC_CHASSIS_SRC_CELL (9ULL << 28) /* cell */ 186 #define PDC_CHASSIS_SRC_PD (10ULL << 28) /* protected domain */ 187 188 /* Source detail field */ 189 #define PDC_CHASSIS_SRC_D_PROC (1ULL << 24) /* processor general */ 190 191 /* Source ID - platform dependent */ 192 #define PDC_CHASSIS_SRC_ID_UNSPEC (0ULL << 16) 193 194 /* Problem detail - problem source dependent */ 195 #define PDC_CHASSIS_PB_D_PROC_NONE (0ULL << 32) /* no problem detail */ 196 #define PDC_CHASSIS_PB_D_PROC_TIMEOUT (4ULL << 32) /* timeout */ 197 198 /* Caller activity */ 199 #define PDC_CHASSIS_CALL_ACT_HPUX_BL (7ULL << 12) /* Boot Loader */ 200 #define PDC_CHASSIS_CALL_ACT_HPUX_PD (8ULL << 12) /* SAL_PD activities */ 201 #define PDC_CHASSIS_CALL_ACT_HPUX_EVENT (9ULL << 12) /* SAL_EVENTS activities */ 202 #define PDC_CHASSIS_CALL_ACT_HPUX_IO (10ULL << 12) /* SAL_IO activities */ 203 #define PDC_CHASSIS_CALL_ACT_HPUX_PANIC (11ULL << 12) /* System panic */ 204 #define PDC_CHASSIS_CALL_ACT_HPUX_INIT (12ULL << 12) /* System initialization */ 205 #define PDC_CHASSIS_CALL_ACT_HPUX_SHUT (13ULL << 12) /* System shutdown */ 206 #define PDC_CHASSIS_CALL_ACT_HPUX_WARN (14ULL << 12) /* System warning */ 207 #define PDC_CHASSIS_CALL_ACT_HPUX_DU (15ULL << 12) /* Display_Activity() update */ 208 209 /* Activity status - implementation dependent */ 210 #define PDC_CHASSIS_ACT_STATUS_UNSPEC (0ULL << 0) 211 212 /* Caller subactivity - implementation dependent */ 213 /* FIXME: other subactivities ? */ 214 #define PDC_CHASSIS_CALL_SACT_UNSPEC (0ULL << 4) /* implementation dependent */ 215 216 /* Reporting entity type */ 217 #define PDC_CHASSIS_RET_GENERICOS (12ULL << 52) /* generic OSes */ 218 #define PDC_CHASSIS_RET_IA64_NT (13ULL << 52) /* IA-64 NT */ 219 #define PDC_CHASSIS_RET_HPUX (14ULL << 52) /* HP-UX */ 220 #define PDC_CHASSIS_RET_DIAG (15ULL << 52) /* offline diagnostics & utilities */ 221 222 /* Reporting entity ID */ 223 #define PDC_CHASSIS_REID_UNSPEC (0ULL << 44) 224 225 /* Data type */ 226 #define PDC_CHASSIS_DT_NONE (0ULL << 59) /* data field unused */ 227 /* For later use ? Do we need these ? */ 228 #define PDC_CHASSIS_DT_PHYS_ADDR (1ULL << 59) /* physical address */ 229 #define PDC_CHASSIS_DT_DATA_EXPECT (2ULL << 59) /* expected data */ 230 #define PDC_CHASSIS_DT_ACTUAL (3ULL << 59) /* actual data */ 231 #define PDC_CHASSIS_DT_PHYS_LOC (4ULL << 59) /* physical location */ 232 #define PDC_CHASSIS_DT_PHYS_LOC_EXT (5ULL << 59) /* physical location extension */ 233 #define PDC_CHASSIS_DT_TAG (6ULL << 59) /* tag */ 234 #define PDC_CHASSIS_DT_SYNDROME (7ULL << 59) /* syndrome */ 235 #define PDC_CHASSIS_DT_CODE_ADDR (8ULL << 59) /* code address */ 236 #define PDC_CHASSIS_DT_ASCII_MSG (9ULL << 59) /* ascii message */ 237 #define PDC_CHASSIS_DT_POST (10ULL << 59) /* POST code */ 238 #define PDC_CHASSIS_DT_TIMESTAMP (11ULL << 59) /* timestamp */ 239 #define PDC_CHASSIS_DT_DEV_STAT (12ULL << 59) /* device status */ 240 #define PDC_CHASSIS_DT_DEV_TYPE (13ULL << 59) /* device type */ 241 #define PDC_CHASSIS_DT_PB_DET (14ULL << 59) /* problem detail */ 242 #define PDC_CHASSIS_DT_ACT_LEV (15ULL << 59) /* activity level/timeout */ 243 #define PDC_CHASSIS_DT_SER_NUM (16ULL << 59) /* serial number */ 244 #define PDC_CHASSIS_DT_REV_NUM (17ULL << 59) /* revision number */ 245 #define PDC_CHASSIS_DT_INTERRUPT (18ULL << 59) /* interruption information */ 246 #define PDC_CHASSIS_DT_TEST_NUM (19ULL << 59) /* test number */ 247 #define PDC_CHASSIS_DT_STATE_CHG (20ULL << 59) /* major changes in system state */ 248 #define PDC_CHASSIS_DT_PROC_DEALLOC (21ULL << 59) /* processor deallocate */ 249 #define PDC_CHASSIS_DT_RESET (30ULL << 59) /* reset type and cause */ 250 #define PDC_CHASSIS_DT_PA_LEGACY (31ULL << 59) /* legacy PA hex chassis code */ 251 252 /* System states - part of major changes in system state data field */ 253 #define PDC_CHASSIS_SYSTATE_BSTART (0ULL << 0) /* boot start */ 254 #define PDC_CHASSIS_SYSTATE_BCOMP (1ULL << 0) /* boot complete */ 255 #define PDC_CHASSIS_SYSTATE_CHANGE (2ULL << 0) /* major change */ 256 #define PDC_CHASSIS_SYSTATE_LED (3ULL << 0) /* LED change */ 257 #define PDC_CHASSIS_SYSTATE_PANIC (9ULL << 0) /* OS Panic */ 258 #define PDC_CHASSIS_SYSTATE_DUMP (10ULL << 0) /* memory dump */ 259 #define PDC_CHASSIS_SYSTATE_HPMC (11ULL << 0) /* processing HPMC */ 260 #define PDC_CHASSIS_SYSTATE_HALT (15ULL << 0) /* system halted */ 261 262 /* Message ID */ 263 #define PDC_CHASSIS_MSG_ID (0ULL << 40) /* we do not handle msg IDs atm */ 264 265 /* EOM - separates log entries */ 266 #define PDC_CHASSIS_EOM_CLEAR (0ULL << 43) 267 #define PDC_CHASSIS_EOM_SET (1ULL << 43) 268 269 /* 270 * Preformated well known messages 271 */ 272 273 /* Boot started */ 274 #define PDC_CHASSIS_PMSG_BSTART (PDC_CHASSIS_ALERT_SERPROC | \ 275 PDC_CHASSIS_SRC_PROC | \ 276 PDC_CHASSIS_SRC_D_PROC | \ 277 PDC_CHASSIS_SRC_ID_UNSPEC | \ 278 PDC_CHASSIS_PB_D_PROC_NONE | \ 279 PDC_CHASSIS_CALL_ACT_HPUX_INIT | \ 280 PDC_CHASSIS_ACT_STATUS_UNSPEC | \ 281 PDC_CHASSIS_CALL_SACT_UNSPEC | \ 282 PDC_CHASSIS_RET_HPUX | \ 283 PDC_CHASSIS_REID_UNSPEC | \ 284 PDC_CHASSIS_DT_STATE_CHG | \ 285 PDC_CHASSIS_SYSTATE_BSTART | \ 286 PDC_CHASSIS_MSG_ID | \ 287 PDC_CHASSIS_EOM_SET ) 288 289 /* Boot complete */ 290 #define PDC_CHASSIS_PMSG_BCOMPLETE (PDC_CHASSIS_ALERT_SERPROC | \ 291 PDC_CHASSIS_SRC_PROC | \ 292 PDC_CHASSIS_SRC_D_PROC | \ 293 PDC_CHASSIS_SRC_ID_UNSPEC | \ 294 PDC_CHASSIS_PB_D_PROC_NONE | \ 295 PDC_CHASSIS_CALL_ACT_HPUX_INIT | \ 296 PDC_CHASSIS_ACT_STATUS_UNSPEC | \ 297 PDC_CHASSIS_CALL_SACT_UNSPEC | \ 298 PDC_CHASSIS_RET_HPUX | \ 299 PDC_CHASSIS_REID_UNSPEC | \ 300 PDC_CHASSIS_DT_STATE_CHG | \ 301 PDC_CHASSIS_SYSTATE_BCOMP | \ 302 PDC_CHASSIS_MSG_ID | \ 303 PDC_CHASSIS_EOM_SET ) 304 305 /* Shutdown */ 306 #define PDC_CHASSIS_PMSG_SHUTDOWN (PDC_CHASSIS_ALERT_SERPROC | \ 307 PDC_CHASSIS_SRC_PROC | \ 308 PDC_CHASSIS_SRC_D_PROC | \ 309 PDC_CHASSIS_SRC_ID_UNSPEC | \ 310 PDC_CHASSIS_PB_D_PROC_NONE | \ 311 PDC_CHASSIS_CALL_ACT_HPUX_SHUT | \ 312 PDC_CHASSIS_ACT_STATUS_UNSPEC | \ 313 PDC_CHASSIS_CALL_SACT_UNSPEC | \ 314 PDC_CHASSIS_RET_HPUX | \ 315 PDC_CHASSIS_REID_UNSPEC | \ 316 PDC_CHASSIS_DT_STATE_CHG | \ 317 PDC_CHASSIS_SYSTATE_HALT | \ 318 PDC_CHASSIS_MSG_ID | \ 319 PDC_CHASSIS_EOM_SET ) 320 321 /* Panic */ 322 #define PDC_CHASSIS_PMSG_PANIC (PDC_CHASSIS_ALERT_SOFT_FAIL | \ 323 PDC_CHASSIS_SRC_PROC | \ 324 PDC_CHASSIS_SRC_D_PROC | \ 325 PDC_CHASSIS_SRC_ID_UNSPEC | \ 326 PDC_CHASSIS_PB_D_PROC_NONE | \ 327 PDC_CHASSIS_CALL_ACT_HPUX_PANIC| \ 328 PDC_CHASSIS_ACT_STATUS_UNSPEC | \ 329 PDC_CHASSIS_CALL_SACT_UNSPEC | \ 330 PDC_CHASSIS_RET_HPUX | \ 331 PDC_CHASSIS_REID_UNSPEC | \ 332 PDC_CHASSIS_DT_STATE_CHG | \ 333 PDC_CHASSIS_SYSTATE_PANIC | \ 334 PDC_CHASSIS_MSG_ID | \ 335 PDC_CHASSIS_EOM_SET ) 336 337 // FIXME: extrapolated data 338 /* HPMC */ 339 #define PDC_CHASSIS_PMSG_HPMC (PDC_CHASSIS_ALERT_CONF_CHG /*?*/ | \ 340 PDC_CHASSIS_SRC_PROC | \ 341 PDC_CHASSIS_SRC_D_PROC | \ 342 PDC_CHASSIS_SRC_ID_UNSPEC | \ 343 PDC_CHASSIS_PB_D_PROC_NONE | \ 344 PDC_CHASSIS_CALL_ACT_HPUX_WARN | \ 345 PDC_CHASSIS_RET_HPUX | \ 346 PDC_CHASSIS_DT_STATE_CHG | \ 347 PDC_CHASSIS_SYSTATE_HPMC | \ 348 PDC_CHASSIS_MSG_ID | \ 349 PDC_CHASSIS_EOM_SET ) 350 351 /* LPMC */ 352 #define PDC_CHASSIS_PMSG_LPMC (PDC_CHASSIS_ALERT_BLOCKED /*?*/| \ 353 PDC_CHASSIS_SRC_PROC | \ 354 PDC_CHASSIS_SRC_D_PROC | \ 355 PDC_CHASSIS_SRC_ID_UNSPEC | \ 356 PDC_CHASSIS_PB_D_PROC_NONE | \ 357 PDC_CHASSIS_CALL_ACT_HPUX_WARN | \ 358 PDC_CHASSIS_ACT_STATUS_UNSPEC | \ 359 PDC_CHASSIS_CALL_SACT_UNSPEC | \ 360 PDC_CHASSIS_RET_HPUX | \ 361 PDC_CHASSIS_REID_UNSPEC | \ 362 PDC_CHASSIS_DT_STATE_CHG | \ 363 PDC_CHASSIS_SYSTATE_CHANGE | \ 364 PDC_CHASSIS_MSG_ID | \ 365 PDC_CHASSIS_EOM_SET ) 366 367 #endif /* _PARISC_PDC_CHASSIS_H */ 368 /* vim: set ts=8 */ 369