blob: e9757b0490b479139506d184a28602db3ad0d2d3 [file] [log] [blame]
Lawrence Tang4795d4a2022-07-06 15:19:31 +01001#ifndef CPER_SECTION_DMAR_GENERIC_H
2#define CPER_SECTION_DMAR_GENERIC_H
3
Lawrence Tang5202bbb2022-08-12 14:54:36 +01004#include <json.h>
Lawrence Tang4795d4a2022-07-06 15:19:31 +01005#include "../edk/Cper.h"
6
7#define DMAR_GENERIC_ERROR_FAULT_REASON_TYPES_KEYS (int []){0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, 0xA, 0xB}
8#define DMAR_GENERIC_ERROR_FAULT_REASON_TYPES_VALUES (const char*[]){"DMT Entry Missing", "DMT Entry Invalid", \
9 "DMT Access Error", "DMT Reserved Bit Invalid", "DMA Address Out of Bounds", "Invalid Read/Write", \
10 "Invalid Device Request", "ATT Access Error", "ATT Reserved Bit Invalid", "Illegal Command", "Command Buffer Access Error"}
11#define DMAR_GENERIC_ERROR_FAULT_REASON_TYPES_DESCRIPTIONS (const char*[]){ \
12 "Domain mapping table entry is not present.", \
Lawrence Tang01e3a442022-07-20 15:14:50 +010013 "Invalid domain mapping table entry.", \
14 "DMAr unit's attempt to access the domain mapping table resulted in an error.", \
Lawrence Tang4795d4a2022-07-06 15:19:31 +010015 "Reserved bit set to non-zero value in the domain mapping table.", \
16 "DMA request to access an address beyond the device address width.", \
17 "Invalid read or write access.", \
18 "Invalid device request.", \
19 "DMAr unit's attempt to access the address translation table resulted in an error.", \
20 "Reserved bit set to non-zero value in the address translation table.", \
21 "Illegal command error.", \
22 "DMAr unit's attempt to access the command buffer resulted in an error."}
23#define DMAR_GENERIC_ERROR_ACCESS_TYPES_KEYS (int []){0x0, 0x1}
24#define DMAR_GENERIC_ERROR_ACCESS_TYPES_VALUES (const char*[]){"DMA Write", "DMA Read"}
25#define DMAR_GENERIC_ERROR_ADDRESS_TYPES_KEYS (int []){0x0, 0x1}
26#define DMAR_GENERIC_ERROR_ADDRESS_TYPES_VALUES (const char*[]){"Untranslated Request", "Translation Request"}
27#define DMAR_GENERIC_ERROR_ARCH_TYPES_KEYS (int []){0x0, 0x1}
28#define DMAR_GENERIC_ERROR_ARCH_TYPES_VALUES (const char*[]){"VT-d", "IOMMU"}
29
30json_object* cper_section_dmar_generic_to_ir(void* section, EFI_ERROR_SECTION_DESCRIPTOR* descriptor);
Lawrence Tang205dd1d2022-07-14 16:23:38 +010031void ir_section_dmar_generic_to_cper(json_object* section, FILE* out);
32
Lawrence Tang4795d4a2022-07-06 15:19:31 +010033
34#endif