mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
119 lines
3.2 KiB
C
119 lines
3.2 KiB
C
|
/*
|
||
|
* linux/include/asm-alpha/err_common.h
|
||
|
*
|
||
|
* Copyright (C) 2000 Jeff Wiedemeier (Compaq Computer Corporation)
|
||
|
*
|
||
|
* Contains declarations and macros to support Alpha error handling
|
||
|
* implementations.
|
||
|
*/
|
||
|
|
||
|
#ifndef __ALPHA_ERR_COMMON_H
|
||
|
#define __ALPHA_ERR_COMMON_H 1
|
||
|
|
||
|
/*
|
||
|
* SCB Vector definitions
|
||
|
*/
|
||
|
#define SCB_Q_SYSERR 0x620
|
||
|
#define SCB_Q_PROCERR 0x630
|
||
|
#define SCB_Q_SYSMCHK 0x660
|
||
|
#define SCB_Q_PROCMCHK 0x670
|
||
|
#define SCB_Q_SYSEVENT 0x680
|
||
|
|
||
|
/*
|
||
|
* Disposition definitions for logout frame parser
|
||
|
*/
|
||
|
#define MCHK_DISPOSITION_UNKNOWN_ERROR 0x00
|
||
|
#define MCHK_DISPOSITION_REPORT 0x01
|
||
|
#define MCHK_DISPOSITION_DISMISS 0x02
|
||
|
|
||
|
/*
|
||
|
* Error Log definitions
|
||
|
*/
|
||
|
/*
|
||
|
* Types
|
||
|
*/
|
||
|
|
||
|
#define EL_CLASS__TERMINATION (0)
|
||
|
# define EL_TYPE__TERMINATION__TERMINATION (0)
|
||
|
#define EL_CLASS__HEADER (5)
|
||
|
# define EL_TYPE__HEADER__SYSTEM_ERROR_FRAME (1)
|
||
|
# define EL_TYPE__HEADER__SYSTEM_EVENT_FRAME (2)
|
||
|
# define EL_TYPE__HEADER__HALT_FRAME (3)
|
||
|
# define EL_TYPE__HEADER__LOGOUT_FRAME (19)
|
||
|
#define EL_CLASS__GENERAL_NOTIFICATION (9)
|
||
|
#define EL_CLASS__PCI_ERROR_FRAME (11)
|
||
|
#define EL_CLASS__REGATTA_FAMILY (12)
|
||
|
# define EL_TYPE__REGATTA__PROCESSOR_ERROR_FRAME (1)
|
||
|
# define EL_TYPE__REGATTA__SYSTEM_ERROR_FRAME (2)
|
||
|
# define EL_TYPE__REGATTA__ENVIRONMENTAL_FRAME (3)
|
||
|
# define EL_TYPE__REGATTA__TITAN_PCHIP0_EXTENDED (8)
|
||
|
# define EL_TYPE__REGATTA__TITAN_PCHIP1_EXTENDED (9)
|
||
|
# define EL_TYPE__REGATTA__TITAN_MEMORY_EXTENDED (10)
|
||
|
# define EL_TYPE__REGATTA__PROCESSOR_DBL_ERROR_HALT (11)
|
||
|
# define EL_TYPE__REGATTA__SYSTEM_DBL_ERROR_HALT (12)
|
||
|
#define EL_CLASS__PAL (14)
|
||
|
# define EL_TYPE__PAL__LOGOUT_FRAME (1)
|
||
|
# define EL_TYPE__PAL__EV7_PROCESSOR (4)
|
||
|
# define EL_TYPE__PAL__EV7_ZBOX (5)
|
||
|
# define EL_TYPE__PAL__EV7_RBOX (6)
|
||
|
# define EL_TYPE__PAL__EV7_IO (7)
|
||
|
# define EL_TYPE__PAL__ENV__AMBIENT_TEMPERATURE (10)
|
||
|
# define EL_TYPE__PAL__ENV__AIRMOVER_FAN (11)
|
||
|
# define EL_TYPE__PAL__ENV__VOLTAGE (12)
|
||
|
# define EL_TYPE__PAL__ENV__INTRUSION (13)
|
||
|
# define EL_TYPE__PAL__ENV__POWER_SUPPLY (14)
|
||
|
# define EL_TYPE__PAL__ENV__LAN (15)
|
||
|
# define EL_TYPE__PAL__ENV__HOT_PLUG (16)
|
||
|
|
||
|
union el_timestamp {
|
||
|
struct {
|
||
|
u8 second;
|
||
|
u8 minute;
|
||
|
u8 hour;
|
||
|
u8 day;
|
||
|
u8 month;
|
||
|
u8 year;
|
||
|
} b;
|
||
|
u64 as_int;
|
||
|
};
|
||
|
|
||
|
struct el_subpacket {
|
||
|
u16 length; /* length of header (in bytes) */
|
||
|
u16 class; /* header class and type... */
|
||
|
u16 type; /* ...determine content */
|
||
|
u16 revision; /* header revision */
|
||
|
union {
|
||
|
struct { /* Class 5, Type 1 - System Error */
|
||
|
u32 frame_length;
|
||
|
u32 frame_packet_count;
|
||
|
} sys_err;
|
||
|
struct { /* Class 5, Type 2 - System Event */
|
||
|
union el_timestamp timestamp;
|
||
|
u32 frame_length;
|
||
|
u32 frame_packet_count;
|
||
|
} sys_event;
|
||
|
struct { /* Class 5, Type 3 - Double Error Halt */
|
||
|
u16 halt_code;
|
||
|
u16 reserved;
|
||
|
union el_timestamp timestamp;
|
||
|
u32 frame_length;
|
||
|
u32 frame_packet_count;
|
||
|
} err_halt;
|
||
|
struct { /* Clasee 5, Type 19 - Logout Frame Header */
|
||
|
u32 frame_length;
|
||
|
u32 frame_flags;
|
||
|
u32 cpu_offset;
|
||
|
u32 system_offset;
|
||
|
} logout_header;
|
||
|
struct { /* Class 12 - Regatta */
|
||
|
u64 cpuid;
|
||
|
u64 data_start[1];
|
||
|
} regatta_frame;
|
||
|
struct { /* Raw */
|
||
|
u64 data_start[1];
|
||
|
} raw;
|
||
|
} by_type;
|
||
|
};
|
||
|
|
||
|
#endif /* __ALPHA_ERR_COMMON_H */
|