TianoCore EDK2 master
Loading...
Searching...
No Matches
SerialStatusCodeWorker.c
Go to the documentation of this file.
1
10
31EFIAPI
33 IN EFI_STATUS_CODE_TYPE CodeType,
35 IN UINT32 Instance,
36 IN EFI_GUID *CallerId,
37 IN EFI_STATUS_CODE_DATA *Data OPTIONAL
38 )
39{
40 CHAR8 *Filename;
41 CHAR8 *Description;
42 CHAR8 *Format;
43 CHAR8 Buffer[MAX_DEBUG_MESSAGE_LENGTH];
44 UINT32 ErrorLevel;
45 UINT32 LineNumber;
46 UINTN CharCount;
47 BASE_LIST Marker;
48
49 Buffer[0] = '\0';
50
51 if ((Data != NULL) &&
52 ReportStatusCodeExtractAssertInfo (CodeType, Value, Data, &Filename, &Description, &LineNumber))
53 {
54 //
55 // Print ASSERT() information into output buffer.
56 //
57 CharCount = AsciiSPrint (
58 Buffer,
59 sizeof (Buffer),
60 "\n\rDXE_ASSERT!: %a (%d): %a\n\r",
61 Filename,
62 LineNumber,
63 Description
64 );
65 } else if ((Data != NULL) &&
66 ReportStatusCodeExtractDebugInfo (Data, &ErrorLevel, &Marker, &Format))
67 {
68 //
69 // Print DEBUG() information into output buffer.
70 //
71 CharCount = AsciiBSPrint (
72 Buffer,
73 sizeof (Buffer),
74 Format,
75 Marker
76 );
77 } else if ((CodeType & EFI_STATUS_CODE_TYPE_MASK) == EFI_ERROR_CODE) {
78 //
79 // Print ERROR information into output buffer.
80 //
81 CharCount = AsciiSPrint (
82 Buffer,
83 sizeof (Buffer),
84 "ERROR: C%08x:V%08x I%x",
85 CodeType,
86 Value,
87 Instance
88 );
89 ASSERT (CharCount > 0);
90
91 if (CallerId != NULL) {
92 CharCount += AsciiSPrint (
93 &Buffer[CharCount],
94 (sizeof (Buffer) - (sizeof (Buffer[0]) * CharCount)),
95 " %g",
96 CallerId
97 );
98 }
99
100 if (Data != NULL) {
101 CharCount += AsciiSPrint (
102 &Buffer[CharCount],
103 (sizeof (Buffer) - (sizeof (Buffer[0]) * CharCount)),
104 " %x",
105 Data
106 );
107 }
108
109 CharCount += AsciiSPrint (
110 &Buffer[CharCount],
111 (sizeof (Buffer) - (sizeof (Buffer[0]) * CharCount)),
112 "\n\r"
113 );
114 } else if ((CodeType & EFI_STATUS_CODE_TYPE_MASK) == EFI_PROGRESS_CODE) {
115 //
116 // Print PROGRESS information into output buffer.
117 //
118 CharCount = AsciiSPrint (
119 Buffer,
120 sizeof (Buffer),
121 "PROGRESS CODE: V%08x I%x\n\r",
122 Value,
123 Instance
124 );
125 } else if ((Data != NULL) &&
126 CompareGuid (&Data->Type, &gEfiStatusCodeDataTypeStringGuid) &&
127 (((EFI_STATUS_CODE_STRING_DATA *)Data)->StringType == EfiStringAscii))
128 {
129 //
130 // EFI_STATUS_CODE_STRING_DATA
131 //
132 CharCount = AsciiSPrint (
133 Buffer,
134 sizeof (Buffer),
135 "%a",
136 ((EFI_STATUS_CODE_STRING_DATA *)Data)->String.Ascii
137 );
138 } else {
139 //
140 // Code type is not defined.
141 //
142 CharCount = AsciiSPrint (
143 Buffer,
144 sizeof (Buffer),
145 "Undefined: C%08x:V%08x I%x\n\r",
146 CodeType,
147 Value,
148 Instance
149 );
150 }
151
152 //
153 // Call SerialPort Lib function to do print.
154 //
155 SerialPortWrite ((UINT8 *)Buffer, CharCount);
156
157 return EFI_SUCCESS;
158}
UINT64 UINTN
UINTN EFIAPI SerialPortWrite(IN UINT8 *Buffer, IN UINTN NumberOfBytes)
Definition: SerialPortLib.c:52
BOOLEAN EFIAPI CompareGuid(IN CONST GUID *Guid1, IN CONST GUID *Guid2)
Definition: MemLibGuid.c:73
BOOLEAN EFIAPI ReportStatusCodeExtractDebugInfo(IN CONST EFI_STATUS_CODE_DATA *Data, OUT UINT32 *ErrorLevel, OUT BASE_LIST *Marker, OUT CHAR8 **Format)
BOOLEAN EFIAPI ReportStatusCodeExtractAssertInfo(IN EFI_STATUS_CODE_TYPE CodeType, IN EFI_STATUS_CODE_VALUE Value, IN CONST EFI_STATUS_CODE_DATA *Data, OUT CHAR8 **Filename, OUT CHAR8 **Description, OUT UINT32 *LineNumber)
UINTN EFIAPI AsciiBSPrint(OUT CHAR8 *StartOfBuffer, IN UINTN BufferSize, IN CONST CHAR8 *FormatString, IN BASE_LIST Marker)
Definition: PrintLib.c:763
UINTN EFIAPI AsciiSPrint(OUT CHAR8 *StartOfBuffer, IN UINTN BufferSize, IN CONST CHAR8 *FormatString,...)
Definition: PrintLib.c:813
#define NULL
Definition: Base.h:319
#define IN
Definition: Base.h:279
UINTN * BASE_LIST
Definition: Base.h:711
EFI_STATUS EFIAPI SerialStatusCodeReportWorker(IN CONST EFI_PEI_SERVICES **PeiServices, IN EFI_STATUS_CODE_TYPE CodeType, IN EFI_STATUS_CODE_VALUE Value, IN UINT32 Instance, IN CONST EFI_GUID *CallerId, IN CONST EFI_STATUS_CODE_DATA *Data OPTIONAL)
UINT32 EFI_STATUS_CODE_VALUE
Definition: PiStatusCode.h:67
#define EFI_PROGRESS_CODE
Definition: PiStatusCode.h:43
UINT32 EFI_STATUS_CODE_TYPE
Definition: PiStatusCode.h:24
#define EFI_STATUS_CODE_TYPE_MASK
Definition: PiStatusCode.h:32
@ EfiStringAscii
RETURN_STATUS EFI_STATUS
Definition: UefiBaseType.h:29
#define EFI_SUCCESS
Definition: UefiBaseType.h:112
Definition: Base.h:213