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 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@8410 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
mdkinney 2009-05-31 00:06:01 +00:00
parent 9c98c8e106
commit a776476a83
1 changed files with 2 additions and 2 deletions

View File

@ -438,7 +438,7 @@ Returns:
// TODO: Data - add argument and description to function comment // TODO: Data - add argument and description to function comment
{ {
CHAR8 *Format; CHAR8 *Format;
VA_LIST Marker; BASE_LIST Marker;
CHAR8 PrintBuffer[BYTES_PER_RECORD * 2]; CHAR8 PrintBuffer[BYTES_PER_RECORD * 2];
CHAR8 *Filename; CHAR8 *Filename;
CHAR8 *Description; CHAR8 *Description;
@ -457,7 +457,7 @@ Returns:
// //
// Process DEBUG () macro // Process DEBUG () macro
// //
AsciiVSPrint (PrintBuffer, BYTES_PER_RECORD, Format, Marker); AsciiBSPrint (PrintBuffer, BYTES_PER_RECORD, Format, Marker);
printf (PrintBuffer); printf (PrintBuffer);
} }