X-Git-Url: https://git.proxmox.com/?p=mirror_edk2.git;a=blobdiff_plain;f=Tools%2FSource%2FGenBuild%2Forg%2Ftianocore%2Fbuild%2Fpcd%2Faction%2FPCDAutoGenAction.java;h=28bb81853e4a8eb2426e5b7026499fd939e52adf;hp=278e58ceaee0b76a734abe00b9237b7e03d126c5;hb=11eb278ae57cfc9ba415fcf91e61dea56d6082c0;hpb=6ff7a41cb8b4e16800f70fd72e7290a418d4329e diff --git a/Tools/Source/GenBuild/org/tianocore/build/pcd/action/PCDAutoGenAction.java b/Tools/Source/GenBuild/org/tianocore/build/pcd/action/PCDAutoGenAction.java index 278e58ceae..28bb81853e 100644 --- a/Tools/Source/GenBuild/org/tianocore/build/pcd/action/PCDAutoGenAction.java +++ b/Tools/Source/GenBuild/org/tianocore/build/pcd/action/PCDAutoGenAction.java @@ -3,13 +3,13 @@ This class is to manage how to generate the PCD information into Autogen.c and Autogen.h. - + Copyright (c) 2006, Intel Corporation All rights reserved. This program and the accompanying materials are licensed and made available under the terms and conditions of the BSD License which accompanies this distribution. The full text of the license may be found at http://opensource.org/licenses/bsd-license.php - + THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. @@ -17,190 +17,171 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. package org.tianocore.build.pcd.action; import java.io.File; +import java.util.ArrayList; import java.util.List; -import java.util.UUID; +import java.util.regex.Matcher; +import java.util.regex.Pattern; +import org.tianocore.build.autogen.CommonDefinition; +import org.tianocore.build.exception.PcdAutogenException; import org.tianocore.build.global.GlobalData; -import org.tianocore.build.pcd.entity.MemoryDatabaseManager; -import org.tianocore.build.pcd.entity.Token; -import org.tianocore.build.pcd.entity.UsageInstance; -import org.tianocore.build.pcd.exception.BuildActionException; -import org.tianocore.build.pcd.exception.EntityException; - -/** This class is to manage how to generate the PCD information into Autogen.c and - Autogen.h. +import org.tianocore.build.id.ModuleIdentification; +import org.tianocore.pcd.action.ActionMessage; +import org.tianocore.pcd.action.BuildAction; +import org.tianocore.pcd.entity.MemoryDatabaseManager; +import org.tianocore.pcd.entity.Token; +import org.tianocore.pcd.entity.UsageIdentification; +import org.tianocore.pcd.entity.UsageInstance; +import org.tianocore.pcd.exception.BuildActionException; + +/** + This class is to manage how to generate the PCD information into Autogen.c + and Autogen.h. **/ public class PCDAutoGenAction extends BuildAction { /// /// The reference of DBManager in GlobalData class. /// private MemoryDatabaseManager dbManager; + /// - /// The name of module which is analysised currently. - /// - private String moduleName; - /// - /// The Guid of module which is analyzed currently. - /// - private UUID moduleGuid; - /// - /// The name of package whose module is analysized currently. - /// - private String packageName; - /// - /// The Guid of package whose module is analyszed curretnly. - /// - private UUID packageGuid; - /// - /// The arch of current module - /// - private String arch; + /// The identification for a UsageInstance. /// - /// The version of current module - /// - private String version; + private UsageIdentification usageId; + /// - /// Wheter current module is PCD emulated driver. It is only for - /// emulated PCD driver and will be kept until PCD IMAGE tool ready. + /// Whether current autogen is for building library used by current module. /// - private boolean isEmulatedPCDDriver; + private boolean isBuildUsedLibrary; + /// - /// Whether current autogen is for building library used by current module. + /// One of PEI_PCD_DRIVER, DXE_PCD_DRIVER, NOT_PCD_DRIVER /// - private boolean isBuildUsedLibrary; + private CommonDefinition.PCD_DRIVER_TYPE pcdDriverType; + /// /// The generated string for header file. /// private String hAutoGenString; + /// /// The generated string for C code file. /// - private String cAutoGenString; + private String cAutoGenString; + + /// + /// The name array of in a module. + /// + private String[] pcdNameArrayInMsa; /** - Set parameter ModuleName - + Set parameter moduleId + @param moduleName the module name parameter. **/ - public void setModuleName(String moduleName) { - this.moduleName = moduleName; - } - - public void setModuleGuid(UUID moduleGuid) { - this.moduleGuid = moduleGuid; - } - - public void setPackageName(String packageName) { - this.packageName = packageName; - } - - public void setPackageGuid(UUID packageGuid) { - this.packageGuid = packageGuid; - } - - public void setArch(String arch) { - this.arch = arch; - } - - public void setVersion(String version) { - this.version = version; + public void setUsageId(UsageIdentification usageId) { + this.usageId = usageId; } /** - Set parameter isEmulatedPCDDriver - - @param isEmulatedPCDDriver whether this module is PeiEmulatedPCD driver + Set paramter pcdDriverType + + @param pcdDriverType the driver type for PCD **/ - public void setIsEmulatedPCDDriver(boolean isEmulatedPCDDriver) { - this.isEmulatedPCDDriver = isEmulatedPCDDriver; + public void setPcdDriverType(CommonDefinition.PCD_DRIVER_TYPE pcdDriverType) { + this.pcdDriverType = pcdDriverType; } + /** + set isBuildUsedLibrary parameter. + @param isBuildUsedLibrary + **/ public void setIsBuildUsedLibrary(boolean isBuildUsedLibrary) { this.isBuildUsedLibrary = isBuildUsedLibrary; } + /** + set pcdNameArrayInMsa parameter. + + @param pcdNameArrayInMsa + */ + public void setPcdNameArrayInMsa(String[] pcdNameArrayInMsa) { + this.pcdNameArrayInMsa = pcdNameArrayInMsa; + } + /** Get the output of generated string for header file. - + @return the string of header file for PCD **/ - public String OutputH() { + public String getHAutoGenString() { return hAutoGenString; } /** Get the output of generated string for C Code file. - + @return the string of C code file for PCD **/ - public String OutputC() { + public String getCAutoGenString() { return cAutoGenString; } + /** - Construct function - - This function mainly initialize some member variable. - - @param moduleName Parameter of this action class. - @param isEmulatedPCDDriver Parameter of this action class. + Construct function + + This function mainly initialize some member variable. + + @param moduleId the identification for module + @param arch the architecture for module + @param isBuildUsedLibary Is the current module library. + @param pcdNameArrayInMsa the pcd name array got from MSA file. + @param pcdDriverType one of PEI_PCD_DRIVER, DXE_PCD_DRIVER, + NOT_PCD_DRIVER **/ - public PCDAutoGenAction(String moduleName, - UUID moduleGuid, - String packageName, - UUID packageGuid, - String arch, - String version, - boolean isEmulatedPCDDriver, - boolean isBuildUsedLibrary) { + public PCDAutoGenAction(ModuleIdentification moduleId, + String arch, + boolean isBuildUsedLibrary, + String[] pcdNameArrayInMsa, + CommonDefinition.PCD_DRIVER_TYPE pcdDriverType) { dbManager = null; hAutoGenString = ""; cAutoGenString = ""; - setIsEmulatedPCDDriver(isEmulatedPCDDriver); - setModuleName(moduleName); - setModuleGuid(moduleGuid); - setPackageName(packageName); - setPackageGuid(packageGuid); - setArch(arch); - setVersion(version); + setUsageId(new UsageIdentification(moduleId.getName(), + moduleId.getGuid(), + moduleId.getPackage().getName(), + moduleId.getPackage().getGuid(), + arch, + moduleId.getVersion(), + moduleId.getModuleType())); setIsBuildUsedLibrary(isBuildUsedLibrary); + setPcdNameArrayInMsa(pcdNameArrayInMsa); + setPcdDriverType(pcdDriverType); } /** - check the parameter for action class. - + Override function: check the parameter for action class. + @throws BuildActionException Bad parameter. **/ - void checkParameter() throws BuildActionException { - if(!isEmulatedPCDDriver &&(moduleName == null)) { - throw new BuildActionException("Wrong module name parameter for PCDAutoGenAction tool!"); - } - - if(!isEmulatedPCDDriver && moduleName.length() == 0) { - throw new BuildActionException("Wrong module name parameter for PCDAutoGenAction tool!"); - } + public void checkParameter() { } /** Core execution function for this action class. - + All PCD information of this module comes from memory dabase. The collection work should be done before this action execution. - Currently, we should generated all PCD information(maybe all dynamic) as array - in Pei emulated driver for simulating PCD runtime database. - + Currently, we should generated all PCD information(maybe all dynamic) as array + in Pei emulated driver for simulating PCD runtime database. + @throws BuildActionException Failed to execute this aciton class. **/ - void performAction() throws BuildActionException { - ActionMessage.debug(this, + public void performAction() { + ActionMessage.debug(this, "Starting PCDAutoGenAction to generate autogen.h and autogen.c!..."); - // - // Check the PCD memory database manager is valid. - // - if(GlobalData.getPCDMemoryDBManager() == null) { - throw new BuildActionException("Memory database has not been initlizated!"); - } dbManager = GlobalData.getPCDMemoryDBManager(); @@ -209,136 +190,140 @@ public class PCDAutoGenAction extends BuildAction { } ActionMessage.debug(this, - "PCD memory database contains " + dbManager.getDBSize() + " PCD tokens"); - - + "PCD memory database contains " + dbManager.getDBSize() + " PCD tokens."); generateAutogenForModule(); } /** Generate the autogen string for a common module. - + All PCD information of this module comes from memory dabase. The collection work should be done before this action execution. **/ private void generateAutogenForModule() { - int index; - List usageInstanceArray; - + int index, index2; + List usageInstanceArray, usageContext; + String[] guidStringArray = null; + String guidStringCName = null; + String guidString = null; + String moduleName = usageId.moduleName; + UsageInstance usageInstance = null; + boolean found = false; + + usageInstanceArray = null; if (!isBuildUsedLibrary) { - usageInstanceArray = dbManager.getUsageInstanceArrayByModuleName(moduleName, - moduleGuid, - packageName, - packageGuid, - arch, - version); - dbManager.UsageInstanceContext = usageInstanceArray; - dbManager.CurrentModuleName = moduleName; - } else { - usageInstanceArray = dbManager.UsageInstanceContext; + usageInstanceArray = dbManager.getUsageInstanceArrayById(usageId); + MemoryDatabaseManager.UsageInstanceContext = usageInstanceArray; + MemoryDatabaseManager.CurrentModuleName = moduleName; + } else if ((pcdNameArrayInMsa != null) && (pcdNameArrayInMsa.length > 0)) { + usageContext = MemoryDatabaseManager.UsageInstanceContext; // - // For building MDE package, although all module are library, but PCD entries of + // For building library package, although all module are library, but PCD entries of // these library should be used to autogen. - // - if (usageInstanceArray == null) { - usageInstanceArray = dbManager.getUsageInstanceArrayByModuleName(moduleName, - moduleGuid, - packageName, - packageGuid, - arch, - version); + // + if (usageContext == null) { + usageInstanceArray = dbManager.getUsageInstanceArrayById(usageId); + } else { + usageInstanceArray = new ArrayList(); + + // + // Try to find all PCD defined in library's PCD in all in module's + // in FPD file. + // + for (index = 0; index < pcdNameArrayInMsa.length; index++) { + found = false; + for (index2 = 0; index2 < usageContext.size(); index2 ++) { + if (pcdNameArrayInMsa[index].equalsIgnoreCase(usageContext.get(index2).parentToken.cName)) { + usageInstanceArray.add(usageContext.get(index2)); + found = true; + break; + } + } + + if (!found) { + // + // All library's PCD should instanted in module's who + // use this library instance. If not, give errors. + // + throw new BuildActionException (String.format("Module %s using library instance %s; the PCD %s " + + "is required by this library instance, but can not be found " + + "in the %s's in the FPD file!", + MemoryDatabaseManager.CurrentModuleName, + moduleName, + pcdNameArrayInMsa[index], + MemoryDatabaseManager.CurrentModuleName + )); + } + } } } - if(usageInstanceArray.size() != 0) { - // - // Add "#include 'PcdLib.h'" for Header file - // - hAutoGenString = "#include \r\n"; + if (usageInstanceArray == null) { + return; } + // + // Generate all PCD entry for a module. + // for(index = 0; index < usageInstanceArray.size(); index ++) { - ActionMessage.debug(this, - "Module " + moduleName + "'s PCD [" + Integer.toHexString(index) + - "]: " + usageInstanceArray.get(index).parentToken.cName); - try { - usageInstanceArray.get(index).generateAutoGen(isBuildUsedLibrary); - hAutoGenString += usageInstanceArray.get(index).getHAutogenStr() + "\r\n"; - cAutoGenString += usageInstanceArray.get(index).getCAutogenStr() + "\r\n"; - } catch(EntityException exp) { - throw new BuildActionException(exp.getMessage()); + usageInstance = usageInstanceArray.get(index); + // + // Before generate any PCD information into autogen.h/autogen.c for a module, + // generate TokenSpaceGuid array variable firstly. For every dynamicEx type + // PCD in this module the token, they are all reference to TokenSpaceGuid + // array. + // + if (usageInstanceArray.get(index).modulePcdType == Token.PCD_TYPE.DYNAMIC_EX) { + guidStringArray = usageInstance.parentToken.tokenSpaceName.split("-"); + guidStringCName = "_gPcd_TokenSpaceGuid_" + + usageInstance.parentToken.tokenSpaceName.replaceAll("-", "_"); + guidString = String.format("{ 0x%s, 0x%s, 0x%s, {0x%s, 0x%s, 0x%s, 0x%s, 0x%s, 0x%s, 0x%s, 0x%s}}", + guidStringArray[0], + guidStringArray[1], + guidStringArray[2], + (guidStringArray[3].substring(0, 2)), + (guidStringArray[3].substring(2, 4)), + (guidStringArray[4].substring(0, 2)), + (guidStringArray[4].substring(2, 4)), + (guidStringArray[4].substring(4, 6)), + (guidStringArray[4].substring(6, 8)), + (guidStringArray[4].substring(8, 10)), + (guidStringArray[4].substring(10, 12))); + + Pattern pattern = Pattern.compile("(" + guidStringCName + ")+?"); + Matcher matcher = pattern.matcher(cAutoGenString + " "); + // + // Find whether this guid array variable has been generated into autogen.c + // For different DyanmicEx pcd token who use same token space guid, the token space + // guid array should be only generated once. + // + if (!matcher.find()) { + hAutoGenString += String.format("extern EFI_GUID %s;\r\n", guidStringCName); + if (!isBuildUsedLibrary) { + cAutoGenString += String.format("GLOBAL_REMOVE_IF_UNREFERENCED EFI_GUID %s = %s;\r\n", + guidStringCName, + guidString); + } + } } - } - // - // Work around code, In furture following code should be modified that get - // these information from Uplevel Autogen tools. - // - if (moduleName.equalsIgnoreCase("PcdPeim")) { - hAutoGenString += dbManager.PcdPeimHString; - cAutoGenString += dbManager.PcdPeimCString; - } else if (moduleName.equalsIgnoreCase("PcdDxe")) { - hAutoGenString += dbManager.PcdDxeHString; - cAutoGenString += dbManager.PcdDxeCString; + usageInstance.generateAutoGen(isBuildUsedLibrary); + // + // For every PCD entry for this module(usage instance), autogen string would + // be appand. + // + hAutoGenString += usageInstance.getHAutogenStr() + "\r\n"; + cAutoGenString += usageInstance.getCAutogenStr(); } - ActionMessage.debug(this, - "Module " + moduleName + "'s PCD header file:\r\n" + hAutoGenString + "\r\n" - ); - ActionMessage.debug(this, - "Module " + moduleName + "'s PCD C file:\r\n" + cAutoGenString + "\r\n" - ); - } - - /** - Test case function - - @param argv paramter from command line - **/ - public static void main(String argv[]) { - - String WorkSpace = "M:/ForPcd/edk2"; - String logFilePath = WorkSpace + "/MdePkg/MdePkg.fpd"; - - // - // At first, CollectPCDAction should be invoked to collect - // all PCD information from SPD, MSA, FPD. - // - CollectPCDAction collectionAction = new CollectPCDAction(); - GlobalData.initInfo("Tools" + File.separator + "Conf" + File.separator + "FrameworkDatabase.db", - WorkSpace); - - try { - collectionAction.perform(WorkSpace, - logFilePath, - ActionMessage.MAX_MESSAGE_LEVEL); - } catch(Exception e) { - e.printStackTrace(); + if (pcdDriverType == CommonDefinition.PCD_DRIVER_TYPE.PEI_PCD_DRIVER) { + hAutoGenString += MemoryDatabaseManager.PcdPeimHString; + cAutoGenString += MemoryDatabaseManager.PcdPeimCString; + } else if (pcdDriverType == CommonDefinition.PCD_DRIVER_TYPE.DXE_PCD_DRIVER) { + hAutoGenString += MemoryDatabaseManager.PcdDxeHString; + cAutoGenString += MemoryDatabaseManager.PcdDxeCString; } - - // - // Then execute the PCDAuotoGenAction to get generated Autogen.h and Autogen.c - // - PCDAutoGenAction autogenAction = new PCDAutoGenAction("BaseLib", - null, - null, - null, - null, - null, - false, - false - ); - autogenAction.execute(); - - System.out.println(autogenAction.OutputH()); - System.out.println("WQWQWQWQWQ"); - System.out.println(autogenAction.OutputC()); - - - System.out.println (autogenAction.hAutoGenString); - System.out.println (autogenAction.cAutoGenString); - } }