blob: c7c2c1c7356625f05be6292d504088846b4f50f3 [file] [log] [blame]
Lawrence Tangb98ec662022-07-06 16:50:21 +01001#ifndef CPER_SECTION_CXL_PROTOCOL_H
2#define CPER_SECTION_CXL_PROTOCOL_H
3
Lawrence Tang5202bbb2022-08-12 14:54:36 +01004#include <json.h>
Lawrence Tangb98ec662022-07-06 16:50:21 +01005#include "../edk/Cper.h"
6
7#define CXL_PROTOCOL_ERROR_VALID_BITFIELD_NAMES (const char*[]) {"cxlAgentTypeValid", "cxlAgentAddressValid", \
Lawrence Tangcef2a592022-07-11 17:00:48 +01008 "deviceIDValid", "deviceSerialValid", "capabilityStructureValid", "cxlDVSECValid", "cxlErrorLogValid"}
Lawrence Tangb98ec662022-07-06 16:50:21 +01009#define CXL_PROTOCOL_ERROR_AGENT_TYPES_KEYS (int []){0, 1}
10#define CXL_PROTOCOL_ERROR_AGENT_TYPES_VALUES (const char*[]){"CXL 1.1 Device", "CXL 1.1 Host Downstream Port"}
11#define CXL_PROTOCOL_ERROR_DEVICE_AGENT 0
12#define CXL_PROTOCOL_ERROR_HOST_DOWNSTREAM_PORT_AGENT 1
13
14///
15/// CXL Protocol Error Section
16///
17typedef struct {
18 UINT64 VendorId : 16;
19 UINT64 DeviceId : 16;
20 UINT64 SubsystemVendorId : 16;
21 UINT64 SubsystemDeviceId : 16;
22 UINT64 ClassCode : 16;
23 UINT64 Reserved1 : 3;
24 UINT64 SlotNumber : 13;
25 UINT64 Reserved2 : 32;
26} EFI_CXL_DEVICE_ID;
27
28typedef struct {
29 UINT64 FunctionNumber : 8;
30 UINT64 DeviceNumber : 8;
31 UINT64 BusNumber : 8;
32 UINT64 SegmentNumber : 16;
33 UINT64 Reserved : 24;
34} EFI_CXL_DEVICE_AGENT_ADDRESS;
35
36typedef union {
37 EFI_CXL_DEVICE_AGENT_ADDRESS DeviceAddress; //Active when the agent is a CXL1.1 device in CxlAgentType.
38 UINT64 PortRcrbBaseAddress; //Active when the agent is a CXL1.1 host downstream port in CxlAgentType.
39} EFI_CXL_AGENT_ADDRESS;
40
41typedef struct {
42 UINT64 ValidBits;
43 UINT64 CxlAgentType;
44 EFI_CXL_AGENT_ADDRESS CxlAgentAddress;
45 EFI_CXL_DEVICE_ID DeviceId;
46 UINT64 DeviceSerial;
47 EFI_PCIE_ERROR_DATA_CAPABILITY CapabilityStructure;
48 UINT16 CxlDvsecLength;
49 UINT16 CxlErrorLogLength;
50 UINT32 Reserved;
Lawrence Tang0a4b3f22022-07-21 10:40:10 +010051} __attribute__((packed, aligned(1))) EFI_CXL_PROTOCOL_ERROR_DATA;
Lawrence Tangb98ec662022-07-06 16:50:21 +010052
53json_object* cper_section_cxl_protocol_to_ir(void* section, EFI_ERROR_SECTION_DESCRIPTOR* descriptor);
Lawrence Tangaec83902022-07-18 09:41:08 +010054void ir_section_cxl_protocol_to_cper(json_object* section, FILE* out);
Lawrence Tangb98ec662022-07-06 16:50:21 +010055
56#endif