1/*
2 * cper.h - UEFI Common Platform Error Record
3 *
4 * Copyright (C) 2009, Intel Corp.
5 *     Author: Huang Ying <ying.huang@intel.com>
6 *
7 * This file is released under the GPLv2.
8 */
9
10#ifndef ACPI_CPER_H
11#define ACPI_CPER_H
12
13#include "uuid.h"
14
15#define CPER_SER_RECOVERABLE   0x0
16#define CPER_SER_FATAL         0x1
17#define CPER_SER_CORRECTED     0x2
18#define CPER_SER_INFORMATIONAL 0x3
19
20#define CPER_VALID_PLATFORM_ID 0x0001
21#define CPER_VALID_TIMESTAMP   0x0002
22#define CPER_VALID_PARTITION_ID        0x0004
23
24#define CPER_HW_ERROR_FLAGS_RECOVERED  0x1
25#define CPER_HW_ERROR_FLAGS_PREVERR    0x2
26#define CPER_HW_ERROR_FLAGS_SIMULATED  0x4
27
28#define CPER_SEC_VALID_FRU_ID          0x1
29#define CPER_SEC_VALID_FRU_STRING      0x2
30
31#define CPER_SEC_PRIMARY                       0x0001
32#define CPER_SEC_CONTAINMENT_WARNING           0x0002
33#define CPER_SEC_RESET                         0x0004
34#define CPER_SEC_ERROR_THRESHOLD_EXCEEDED      0x0008
35#define CPER_SEC_RESOURCE_NOT_ACCESSIBLE       0x0010
36#define CPER_SEC_LATENT_ERROR                  0x0020
37
38#define CPER_SIG_RECORD                "REPC"
39
40#define CPER_SIG_SIZE          4
41
42#define CPER_NOTIFY_CMC                                                        \
43       LGUID(0x2DCE8BB1, 0xBDD7, 0x450e, 0xB9, 0xAD, 0x9C, 0xF4,       \
44             0xEB, 0xD4, 0xF8, 0x90)
45#define CPER_NOTIFY_CPE                                                        \
46       LGUID(0x4E292F96, 0xD843, 0x4a55, 0xA8, 0xC2, 0xD4, 0x81,       \
47             0xF2, 0x7E, 0xBE, 0xEE)
48#define CPER_NOTIFY_MCE                                                        \
49       LGUID(0xE8F56FFE, 0x919C, 0x4cc5, 0xBA, 0x88, 0x65, 0xAB,       \
50             0xE1, 0x49, 0x13, 0xBB)
51#define CPER_NOTIFY_PCIE                                               \
52       LGUID(0xCF93C01F, 0x1A16, 0x4dfc, 0xB8, 0xBC, 0x9C, 0x4D,       \
53             0xAF, 0x67, 0xC1, 0x04)
54#define CPER_NOTIFY_INIT                                               \
55       LGUID(0xCC5263E8, 0x9308, 0x454a, 0x89, 0xD0, 0x34, 0x0B,       \
56             0xD3, 0x9B, 0xC9, 0x8E)
57#define CPER_NOTIFY_NMI                                                        \
58       LGUID(0x5BAD89FF, 0xB7E6, 0x42c9, 0x81, 0x4A, 0xCF, 0x24,       \
59             0x85, 0xD6, 0xE9, 0x8A)
60#define CPER_NOTIFY_BOOT                                               \
61       LGUID(0x3D61A466, 0xAB40, 0x409a, 0xA6, 0x98, 0xF3, 0x62,       \
62             0xD4, 0x64, 0xB3, 0x8F)
63#define CPER_NOTIFY_DMAR                                               \
64       LGUID(0x667DD791, 0xC6B3, 0x4c27, 0x8A, 0x6B, 0x0F, 0x8E,       \
65             0x72, 0x2D, 0xEB, 0x41)
66
67#define CPER_SEC_PROC_GENERIC                                          \
68       LGUID(0x9876CCAD, 0x47B4, 0x4bdb, 0xB6, 0x5E, 0x16, 0xF1,       \
69             0x93, 0xC4, 0xF3, 0xDB)
70#define CPER_SEC_PROC_IA                                               \
71       LGUID(0xDC3EA0B0, 0xA144, 0x4797, 0xB9, 0x5B, 0x53, 0xFA,       \
72             0x24, 0x2B, 0x6E, 0x1D)
73#define CPER_SEC_PROC_IPF                                              \
74       LGUID(0xE429FAF1, 0x3CB7, 0x11D4, 0x0B, 0xCA, 0x07, 0x00,       \
75             0x80, 0xC7, 0x3C, 0x88, 0x81)
76#define CPER_SEC_PLATFORM_MEM                                          \
77       LGUID(0xA5BC1114, 0x6F64, 0x4EDE, 0xB8, 0x63, 0x3E, 0x83,       \
78             0xED, 0x7C, 0x83, 0xB1)
79#define CPER_SEC_PCIE                                                  \
80       LGUID(0xD995E954, 0xBBC1, 0x430F, 0xAD, 0x91, 0xB4, 0x4D,       \
81             0xCB, 0x3C, 0x6F, 0x35)
82#define CPER_SEC_FW_ERR_REC_REF                                                \
83       LGUID(0x81212A96, 0x09ED, 0x4996, 0x94, 0x71, 0x8D, 0x72,       \
84             0x9C, 0x8E, 0x69, 0xED)
85#define CPER_SEC_PCI_X_BUS                                             \
86       LGUID(0xC5753963, 0x3B84, 0x4095, 0xBF, 0x78, 0xED, 0xDA,       \
87             0xD3, 0xF9, 0xC9, 0xDD)
88#define CPER_SEC_PCI_DEV                                               \
89       LGUID(0xEB5E4685, 0xCA66, 0x4769, 0xB6, 0xA2, 0x26, 0x06,       \
90             0x8B, 0x00, 0x13, 0x26)
91#define CPER_SEC_DMAR_GENERIC                                          \
92       LGUID(0x5B51FEF7, 0xC79D, 0x4434, 0x8F, 0x1B, 0xAA, 0x62,       \
93             0xDE, 0x3E, 0x2C, 0x64)
94#define CPER_SEC_DMAR_VT                                               \
95       LGUID(0x71761D37, 0x32B2, 0x45cd, 0xA7, 0xD0, 0xB0, 0xFE,       \
96             0xDD, 0x93, 0xE8, 0xCF)
97#define CPER_SEC_DMAR_IOMMU                                            \
98       LGUID(0x036F84E1, 0x7F37, 0x428c, 0xA7, 0x9E, 0x57, 0x5F,       \
99             0xDF, 0xAA, 0x84, 0xEC)
100
101/*
102 * All tables and structs must be byte-packed to match CPER
103 * specification, since the tables are provided by the system BIOS
104 */
105#pragma pack(1)
106
107struct cper_record_header
108{
109       char    signature[CPER_SIG_SIZE];       /* must be "REPC" */
110       __u16   revision;
111       __u32   signature_end;                  /* must be 0xffffffff */
112       __u16   section_count;
113       __u32   error_severity;
114       __u32   validation_bits;
115       __u32   record_length;
116       __u64   timestamp;
117       lguid_t platform_id;
118       lguid_t partition_id;
119       lguid_t creator_id;
120       lguid_t notification_type;
121       __u64   record_id;
122       __u32   flags;
123       __u64   persistence_information;
124       __u8    reserved[12];                   /* must be zero */
125};
126
127struct cper_section_descriptor
128{
129       __u32   section_offset;         /* Offset in bytes of the
130                                        *  section body from the base
131                                        *  of the record header */
132       __u32   section_length;
133       __u16   revision;
134       __u8    validation_bits;
135       __u8    reserved;               /* must be zero */
136       __u32   flags;
137       lguid_t section_type;
138       lguid_t fru_id;
139       __u32   section_severity;
140       __u8    fru_text[20];
141};
142
143struct cper_sec_proc_generic
144{
145       __u64   validation_bits;
146       __u8    proc_type;
147       __u8    proc_isa;
148       __u8    proc_error_type;
149       __u8    operation;
150       __u8    flags;
151       __u8    level;
152       __u16   reserved;
153       __u64   cpu_version;
154       char    cpu_brand[128];
155       __u64   proc_id;
156       __u64   target_addr;
157       __u64   requestor_id;
158       __u64   responder_id;
159       __u64   ip;
160};
161
162struct cper_sec_proc_ia
163{
164       __u64   validation_bits;
165       __u8    lapic_id;
166       __u8    cpuid[48];
167};
168
169struct cper_ia_err_info
170{
171       lguid_t err_type;
172       __u64   validation_bits;
173       __u64   check_info;
174       __u64   target_id;
175       __u64   requestor_id;
176       __u64   responder_id;
177       __u64   ip;
178};
179
180struct cper_ia_proc_ctx
181{
182       __u16   reg_ctx_type;
183       __u16   reg_arr_size;
184       __u32   msr_addr;
185       __u64   mm_reg_addr;
186};
187
188struct cper_sec_mem_err
189{
190       __u64   validation_bits;
191       __u64   error_status;
192       __u64   physical_addr;
193       __u64   physical_addr_mask;
194       __u16   node;
195       __u16   card;
196       __u16   module;
197       __u16   bank;
198       __u16   device;
199       __u16   row;
200       __u16   column;
201       __u16   bit_pos;
202       __u64   requestor_id;
203       __u64   responder_id;
204       __u64   target_id;
205       __u8    error_type;
206};
207
208/* Reset to default packing */
209#pragma pack()
210
211#endif
212