Fixed EDKT318

git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@1611 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
qouyang 2006-09-25 14:29:57 +00:00
parent b7089db120
commit 4353d8e173
1 changed files with 131 additions and 94 deletions

View File

@ -41,6 +41,7 @@ import org.tianocore.build.id.ModuleIdentification;
import org.tianocore.build.id.PackageIdentification;
import org.tianocore.build.pcd.action.PCDAutoGenAction;
import org.tianocore.common.definitions.ToolDefinitions;
import org.tianocore.common.definitions.EdkDefinitions;
import org.tianocore.common.exception.EdkException;
import org.tianocore.common.logger.EdkLog;
@ -106,10 +107,11 @@ public class AutoGen {
///
/// For non library module, add its library instance's construct and destructor to
/// list.
/// list. String[0] recode LibConstructor name, String[1] recode Lib instance
/// module type.
///
private List<String> libConstructList = new ArrayList<String>();
private List<String> libDestructList = new ArrayList<String>();
private List<String[]> libConstructList = new ArrayList<String[]>();
private List<String[]> libDestructList = new ArrayList<String[]>();
///
/// List to store SetVirtalAddressMapCallBack, ExitBootServiceCallBack
@ -1398,7 +1400,7 @@ public class AutoGen {
String buffer for AutoGen.c
@throws Exception
**/
void LibConstructorToAutogenC(List<String> libInstanceList,
void LibConstructorToAutogenC(List<String[]> libInstanceList,
String moduleType, StringBuffer fileBuffer) throws EdkException {
boolean isFirst = true;
@ -1407,11 +1409,19 @@ public class AutoGen {
// module type.
//
for (int i = 0; i < libInstanceList.size(); i++) {
if (libInstanceList.get(i)[1].equalsIgnoreCase(EdkDefinitions.MODULE_TYPE_BASE)) {
fileBuffer.append("RETURN_STATUS\r\n");
fileBuffer.append("EFIAPI\r\n");
fileBuffer.append(libInstanceList.get(i)[0]);
fileBuffer.append(" (\r\n");
fileBuffer.append(" VOID\r\n");
fileBuffer.append(" );\r\n");
} else {
switch (CommonDefinition.getModuleType(moduleType)) {
case CommonDefinition.ModuleTypeBase:
fileBuffer.append("RETURN_STATUS\r\n");
fileBuffer.append("EFIAPI\r\n");
fileBuffer.append(libInstanceList.get(i));
fileBuffer.append(libInstanceList.get(i)[0]);
fileBuffer.append(" (\r\n");
fileBuffer.append(" VOID\r\n");
fileBuffer.append(" );\r\n");
@ -1421,7 +1431,7 @@ public class AutoGen {
case CommonDefinition.ModuleTypePeim:
fileBuffer.append("EFI_STATUS\r\n");
fileBuffer.append("EFIAPI\r\n");
fileBuffer.append(libInstanceList.get(i));
fileBuffer.append(libInstanceList.get(i)[0]);
fileBuffer.append(" (\r\n");
fileBuffer
.append(" IN EFI_FFS_FILE_HEADER *FfsHeader,\r\n");
@ -1439,12 +1449,14 @@ public class AutoGen {
case CommonDefinition.ModuleTypeUefiApplication:
fileBuffer.append("EFI_STATUS\r\n");
fileBuffer.append("EFIAPI\r\n");
fileBuffer.append(libInstanceList.get(i));
fileBuffer.append(libInstanceList.get(i)[0]);
fileBuffer.append(" (\r\n");
fileBuffer.append(" IN EFI_HANDLE ImageHandle,\r\n");
fileBuffer.append(" IN EFI_SYSTEM_TABLE *SystemTable\r\n");
fileBuffer.append(" );\r\n");
break;
}
}
}
@ -1493,17 +1505,23 @@ public class AutoGen {
fileBuffer.append("\r\n");
isFirst = false;
}
if (libInstanceList.get(i)[1].equalsIgnoreCase(EdkDefinitions.MODULE_TYPE_BASE)) {
fileBuffer.append(" Status = ");
fileBuffer.append(libInstanceList.get(i)[0]);
fileBuffer.append("();\r\n");
fileBuffer.append(" VOID\r\n");
} else {
switch (CommonDefinition.getModuleType(moduleType)) {
case CommonDefinition.ModuleTypeBase:
fileBuffer.append(" Status = ");
fileBuffer.append(libInstanceList.get(i));
fileBuffer.append(libInstanceList.get(i)[0]);
fileBuffer.append("();\r\n");
fileBuffer.append(" VOID\r\n");
break;
case CommonDefinition.ModuleTypePeiCore:
case CommonDefinition.ModuleTypePeim:
fileBuffer.append(" Status = ");
fileBuffer.append(libInstanceList.get(i));
fileBuffer.append(libInstanceList.get(i)[0]);
fileBuffer.append(" (FfsHeader, PeiServices);\r\n");
break;
case CommonDefinition.ModuleTypeDxeCore:
@ -1514,12 +1532,14 @@ public class AutoGen {
case CommonDefinition.ModuleTypeUefiDriver:
case CommonDefinition.ModuleTypeUefiApplication:
fileBuffer.append(" Status = ");
fileBuffer.append(libInstanceList.get(i));
fileBuffer.append(libInstanceList.get(i)[0]);
fileBuffer.append(" (ImageHandle, SystemTable);\r\n");
break;
default:
EdkLog.log(EdkLog.EDK_INFO,"Autogen doesn't know how to deal with module type - " + moduleType + "!");
}
}
fileBuffer.append(" ASSERT_EFI_ERROR (Status);\r\n");
}
fileBuffer.append("}\r\n");
@ -1539,15 +1559,23 @@ public class AutoGen {
String buffer for AutoGen.c
@throws Exception
**/
void LibDestructorToAutogenC(List<String> libInstanceList,
void LibDestructorToAutogenC(List<String[]> libInstanceList,
String moduleType, StringBuffer fileBuffer) throws EdkException {
boolean isFirst = true;
for (int i = 0; i < libInstanceList.size(); i++) {
if (libInstanceList.get(i)[1].equalsIgnoreCase(EdkDefinitions.MODULE_TYPE_BASE)) {
fileBuffer.append("RETURN_STATUS\r\n");
fileBuffer.append("EFIAPI\r\n");
fileBuffer.append(libInstanceList.get(i)[0]);
fileBuffer.append(" (\r\n");
fileBuffer.append(" VOID\r\n");
fileBuffer.append(" );\r\n");
} else {
switch (CommonDefinition.getModuleType(moduleType)) {
case CommonDefinition.ModuleTypeBase:
fileBuffer.append("RETURN_STATUS\r\n");
fileBuffer.append("EFIAPI\r\n");
fileBuffer.append(libInstanceList.get(i));
fileBuffer.append(libInstanceList.get(i)[0]);
fileBuffer.append(" (\r\n");
fileBuffer.append(" VOID\r\n");
fileBuffer.append(" );\r\n");
@ -1556,7 +1584,7 @@ public class AutoGen {
case CommonDefinition.ModuleTypePeim:
fileBuffer.append("EFI_STATUS\r\n");
fileBuffer.append("EFIAPI\r\n");
fileBuffer.append(libInstanceList.get(i));
fileBuffer.append(libInstanceList.get(i)[0]);
fileBuffer.append(" (\r\n");
fileBuffer
.append(" IN EFI_FFS_FILE_HEADER *FfsHeader,\r\n");
@ -1573,7 +1601,7 @@ public class AutoGen {
case CommonDefinition.ModuleTypeUefiApplication:
fileBuffer.append("EFI_STATUS\r\n");
fileBuffer.append("EFIAPI\r\n");
fileBuffer.append(libInstanceList.get(i));
fileBuffer.append(libInstanceList.get(i)[0]);
fileBuffer.append(" (\r\n");
fileBuffer.append(" IN EFI_HANDLE ImageHandle,\r\n");
fileBuffer.append(" IN EFI_SYSTEM_TABLE *SystemTable\r\n");
@ -1581,6 +1609,7 @@ public class AutoGen {
break;
}
}
}
//
// Write ProcessLibraryDestructor list to autogen.c
@ -1615,8 +1644,14 @@ public class AutoGen {
fileBuffer.append("\r\n");
isFirst = false;
}
if (libInstanceList.get(i)[1].equalsIgnoreCase(EdkDefinitions.MODULE_TYPE_BASE)) {
fileBuffer.append(" Status = ");
fileBuffer.append(libInstanceList.get(i));
fileBuffer.append(libInstanceList.get(i)[0]);
fileBuffer.append("();\r\n");
fileBuffer.append(" VOID\r\n");
}
fileBuffer.append(" Status = ");
fileBuffer.append(libInstanceList.get(i)[0]);
fileBuffer.append("(ImageHandle, SystemTable);\r\n");
fileBuffer.append(" ASSERT_EFI_ERROR (Status);\r\n");
}
@ -1880,6 +1915,7 @@ public class AutoGen {
String libConstructName = null;
String libDestructName = null;
String libModuleType = null;
String[] setVirtuals = null;
String[] exitBoots = null;
@ -1958,6 +1994,7 @@ public class AutoGen {
//
libConstructName = saq.getLibConstructorName();
libDestructName = saq.getLibDestructorName();
libModuleType = saq.getModuleType();
//
// Collect SetVirtualAddressMapCallBack and
@ -1980,13 +2017,13 @@ public class AutoGen {
// Add dependent library instance constructor function.
//
if (libConstructName != null) {
this.libConstructList.add(libConstructName);
this.libConstructList.add(new String[] {libConstructName, libModuleType});
}
//
// Add dependent library instance destructor fuction.
//
if (libDestructName != null) {
this.libDestructList.add(libDestructName);
this.libDestructList.add(new String[] {libDestructName, libModuleType});
}
}
}