From b5a8e95c5ec45d5f417eb899a0704822b6d4339f Mon Sep 17 00:00:00 2001 From: mdkinney Date: Sat, 30 May 2009 23:54:11 +0000 Subject: This checkin addresses the compatibility issue of passing arguments of type VA_LIST between components. The type VA_LIST is mapped onto the compiler specific implementation of varargs. As a result, modules build with different compilers may not use the same VA_LIST structure. The solution to this issue is to define a new type called BASE_LIST that is a compiler independent method of passing varargs between modules. 1) Update all implementations of ReportStatusCodeExtractDebugInfo() to use an argument of type BASE_LIST instead of VA_LIST. 2) Update status code listeners to use the BASE_LIST based APIs in the PrintLib instead of the VA_LIST based APIs, since ReportStatusCodeExtractDebugInfo() was updated to return a parameter of type BASE_LIST. git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@8407 6f19259b-4bc3-4df7-8a09-765794883524 --- .../DxeCoreReportStatusCodeLibFromHob/ReportStatusCodeLib.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) (limited to 'DuetPkg/Library/DxeCoreReportStatusCodeLibFromHob') diff --git a/DuetPkg/Library/DxeCoreReportStatusCodeLibFromHob/ReportStatusCodeLib.c b/DuetPkg/Library/DxeCoreReportStatusCodeLibFromHob/ReportStatusCodeLib.c index 71606143f1..c8268c7de6 100644 --- a/DuetPkg/Library/DxeCoreReportStatusCodeLibFromHob/ReportStatusCodeLib.c +++ b/DuetPkg/Library/DxeCoreReportStatusCodeLibFromHob/ReportStatusCodeLib.c @@ -229,14 +229,14 @@ EFIAPI ReportStatusCodeExtractDebugInfo ( IN CONST EFI_STATUS_CODE_DATA *Data, OUT UINT32 *ErrorLevel, - OUT VA_LIST *Marker, + OUT BASE_LIST *Marker, OUT CHAR8 **Format ) { EFI_DEBUG_INFO *DebugInfo; - ASSERT (Data != NULL); - ASSERT (ErrorLevel != NULL); + ASSERT (Data != NULL); + ASSERT (ErrorLevel != NULL); ASSERT (Marker != NULL); ASSERT (Format != NULL); @@ -258,7 +258,7 @@ ReportStatusCodeExtractDebugInfo ( // The first 12 * UINTN bytes of the string are really an // argument stack to support varargs on the Format string. // - *Marker = (VA_LIST) (DebugInfo + 1); + *Marker = (BASE_LIST) (DebugInfo + 1); *Format = (CHAR8 *)(((UINT64 *)*Marker) + 12); return TRUE; -- cgit v1.2.3