Commit 4cdc6890 authored by Benjamin Romer's avatar Benjamin Romer Committed by Greg Kroah-Hartman

staging: unisys: refactor DIAG_CHANNEL_EVENT

Get rid of the typedef on DIAG_CHANNEL_EVENT, and use struct diag_channel_event
instead. Update comments and fix CamelCase member names:

EventId => event_id
Severity => severity
ModuleName => module_name
LineNumber => line_number
Timestamp => timestamp
PartitionNumber => partition_number
VirtualProcessorNumber => vcpu_number
LogicalProcessorNumber => lcpu_number
ComponentType => component_type
Subsystem => subsystem
Reserved0 => reserved0
BlockNumber => block_no
BlockNumberHigh => block_no_high
EventNumber => event_no
EventNumberHigh => event_no_high
Reserved => reserved
AdditionalInfo => additional_info
Signed-off-by: default avatarBenjamin Romer <benjamin.romer@unisys.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent e91a008a
...@@ -147,7 +147,7 @@ enum spar_component_types { ...@@ -147,7 +147,7 @@ enum spar_component_types {
/* RESERVED 0x18 - 0x1F */ /* RESERVED 0x18 - 0x1F */
}; };
/* Structure: DIAG_CHANNEL_EVENT Purpose: Contains attributes that make up an /* Structure: diag_channel_event Purpose: Contains attributes that make up an
* event to be written to the DIAG_CHANNEL memory. Attributes: EventId: Id of * event to be written to the DIAG_CHANNEL memory. Attributes: EventId: Id of
* the diagnostic event to write to memory. Severity: Severity of the event * the diagnostic event to write to memory. Severity: Severity of the event
* (Error, Info, etc). ModuleName: Module/file name where event originated. * (Error, Info, etc). ModuleName: Module/file name where event originated.
...@@ -156,40 +156,40 @@ enum spar_component_types { ...@@ -156,40 +156,40 @@ enum spar_component_types {
* Reserved: Padding to align structure on a 64-byte cache line boundary. * Reserved: Padding to align structure on a 64-byte cache line boundary.
* AdditionalInfo: Array of characters for additional event info (may be * AdditionalInfo: Array of characters for additional event info (may be
* empty). */ * empty). */
typedef struct _DIAG_CHANNEL_EVENT { struct diag_channel_event {
u32 EventId; u32 event_id;
u32 Severity; u32 severity;
u8 ModuleName[MAX_MODULE_NAME_SIZE]; u8 module_name[MAX_MODULE_NAME_SIZE];
u32 LineNumber; u32 line_number;
struct diag_efi_time Timestamp; /* Size = 16 bytes */ struct diag_efi_time timestamp; /* Size = 16 bytes */
u32 PartitionNumber; /* Filled in by Diag Switch as pool blocks are u32 partition_number; /* Filled in by Diag Switch as pool blocks are
* filled */ * filled */
u16 VirtualProcessorNumber; u16 vcpu_number;
u16 LogicalProcessorNumber; u16 lcpu_number;
u8 ComponentType; /* ULTRA_COMPONENT_TYPES */ u8 component_type; /* ULTRA_COMPONENT_TYPES */
u8 Subsystem; u8 subsystem;
u16 Reserved0; /* pad to u64 alignment */ u16 reserved0; /* pad to u64 alignment */
u32 BlockNumber; /* filled in by DiagSwitch as pool blocks are u32 block_no; /* filled in by DiagSwitch as pool blocks are
* filled */ * filled */
u32 BlockNumberHigh; u32 block_no_high;
u32 EventNumber; /* filled in by DiagSwitch as pool blocks are u32 event_no; /* filled in by DiagSwitch as pool blocks are
* filled */ * filled */
u32 EventNumberHigh; u32 event_no_high;
/* The BlockNumber and EventNumber fields are set only by DiagSwitch /* The block_no and event_no fields are set only by DiagSwitch
* and referenced only by WinDiagDisplay formatting tool as * and referenced only by WinDiagDisplay formatting tool as
* additional diagnostic information. Other tools including * additional diagnostic information. Other tools including
* WinDiagDisplay currently ignore these 'Reserved' bytes. */ * WinDiagDisplay currently ignore these 'Reserved' bytes. */
u8 Reserved[8]; u8 reserved[8];
u8 AdditionalInfo[MAX_ADDITIONAL_INFO_SIZE]; u8 additional_info[MAX_ADDITIONAL_INFO_SIZE];
/* NOTE: Changesto DIAG_CHANNEL_EVENT generally need to be reflected in /* NOTE: Changes to diag_channel_event generally need to be reflected in
* existing copies * * existing copies *
* - for AppOS at * - for AppOS at
* GuestLinux/visordiag_early/supervisor_diagchannel.h * * GuestLinux/visordiag_early/supervisor_diagchannel.h *
* - for WinDiagDisplay at * - for WinDiagDisplay at
* EFI/Ultra/Tools/WinDiagDisplay/WinDiagDisplay/diagstruct.h */ * EFI/Ultra/Tools/WinDiagDisplay/WinDiagDisplay/diagstruct.h */
} DIAG_CHANNEL_EVENT; };
/* Levels of severity for diagnostic events, in order from lowest severity to /* Levels of severity for diagnostic events, in order from lowest severity to
* highest (i.e. fatal errors are the most severe, and should always be logged, * highest (i.e. fatal errors are the most severe, and should always be logged,
...@@ -240,14 +240,14 @@ typedef enum { DIAG_SEVERITY_ENUM_BEGIN = 0, ...@@ -240,14 +240,14 @@ typedef enum { DIAG_SEVERITY_ENUM_BEGIN = 0,
* "DIAG_SEVERITY_PRINT" (=4), is used for transferring text or binary file to * "DIAG_SEVERITY_PRINT" (=4), is used for transferring text or binary file to
* the Diag partition. This cause-severity combination will be used by Logger * the Diag partition. This cause-severity combination will be used by Logger
* DiagSwitch to segregate events into block types. The files are transferred in * DiagSwitch to segregate events into block types. The files are transferred in
* 256 byte chunks maximum, in the AdditionalInfo field of the DIAG_CHANNEL_EVENT * 256 byte chunks maximum, in the AdditionalInfo field of the diag_channel_event
* structure. In the file transfer mode, some event fields will have different * structure. In the file transfer mode, some event fields will have different
* meaning: EventId specifies the file offset, severity specifies the block type, * meaning: EventId specifies the file offset, severity specifies the block type,
* ModuleName specifies the filename, LineNumber specifies the number of valid * ModuleName specifies the filename, LineNumber specifies the number of valid
* data bytes in an event and AdditionalInfo contains up to 256 bytes of data. */ * data bytes in an event and AdditionalInfo contains up to 256 bytes of data. */
/* The Diag DiagWriter appends event blocks to events.raw as today, and for data /* The Diag DiagWriter appends event blocks to events.raw as today, and for data
* blocks uses DIAG_CHANNEL_EVENT * blocks uses diag_channel_event
* PartitionNumber to extract and append 'AdditionalInfo' to filename (specified * PartitionNumber to extract and append 'AdditionalInfo' to filename (specified
* by ModuleName). */ * by ModuleName). */
...@@ -378,7 +378,7 @@ typedef struct _DIAG_CHANNEL_PROTOCOL_HEADER { ...@@ -378,7 +378,7 @@ typedef struct _DIAG_CHANNEL_PROTOCOL_HEADER {
/* ----------------------- */ /* ----------------------- */
/* | DiagChannel Header | Defined by DIAG_CHANNEL_PROTOCOL_HEADER */ /* | DiagChannel Header | Defined by DIAG_CHANNEL_PROTOCOL_HEADER */
/* ----------------------- */ /* ----------------------- */
/* | Channel Event Info | Defined by (DIAG_CHANNEL_EVENT * MAX_EVENTS) */ /* | Channel Event Info | Defined by diag_channel_event*MAX_EVENTS */
/* ----------------------- */ /* ----------------------- */
/* | Reserved | Reserved (pad out to 4MB) */ /* | Reserved | Reserved (pad out to 4MB) */
/* ----------------------- */ /* ----------------------- */
...@@ -420,8 +420,8 @@ typedef struct _ULTRA_DIAG_CHANNEL_PROTOCOL { ...@@ -420,8 +420,8 @@ typedef struct _ULTRA_DIAG_CHANNEL_PROTOCOL {
struct channel_header CommonChannelHeader; struct channel_header CommonChannelHeader;
struct signal_queue_header QueueHeader; struct signal_queue_header QueueHeader;
DIAG_CHANNEL_PROTOCOL_HEADER DiagChannelHeader; DIAG_CHANNEL_PROTOCOL_HEADER DiagChannelHeader;
DIAG_CHANNEL_EVENT Events[(DIAG_CH_SIZE - DIAG_CH_EVENT_OFFSET) / struct diag_channel_event Events[(DIAG_CH_SIZE - DIAG_CH_EVENT_OFFSET) /
sizeof(DIAG_CHANNEL_EVENT)]; sizeof(struct diag_channel_event)];
} }
ULTRA_DIAG_CHANNEL_PROTOCOL; ULTRA_DIAG_CHANNEL_PROTOCOL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment