diff options
5 files changed, 965 insertions, 1813 deletions
diff --git a/Tools/Source/GenBuild/org/tianocore/build/fpd/FpdParserTask.java b/Tools/Source/GenBuild/org/tianocore/build/fpd/FpdParserTask.java index bd87b6e0f2..ea287817ee 100644 --- a/Tools/Source/GenBuild/org/tianocore/build/fpd/FpdParserTask.java +++ b/Tools/Source/GenBuild/org/tianocore/build/fpd/FpdParserTask.java @@ -40,7 +40,7 @@ import org.tianocore.build.id.FpdModuleIdentification; import org.tianocore.build.id.ModuleIdentification;
import org.tianocore.build.id.PlatformIdentification;
import org.tianocore.pcd.action.ActionMessage;
-import org.tianocore.build.pcd.action.CollectPCDAction;
+import org.tianocore.build.pcd.action.PlatformPcdPreprocessActionForBuilding;
import org.tianocore.build.toolchain.ToolChainAttribute;
import org.tianocore.build.toolchain.ToolChainElement;
import org.tianocore.build.toolchain.ToolChainMap;
@@ -386,7 +386,7 @@ public class FpdParserTask extends Task { // Pcd Collection. Call CollectPCDAction to collect pcd info.
//
try {
- CollectPCDAction ca = new CollectPCDAction();
+ PlatformPcdPreprocessActionForBuilding ca = new PlatformPcdPreprocessActionForBuilding();
ca.perform(GlobalData.getWorkspacePath(),platformId.getFpdFile().getPath(),ActionMessage.NULL_MESSAGE_LEVEL);
} catch (Exception e){
throw new BuildException(e.getMessage());
diff --git a/Tools/Source/GenBuild/org/tianocore/build/pcd/action/CollectPCDAction.java b/Tools/Source/GenBuild/org/tianocore/build/pcd/action/CollectPCDAction.java deleted file mode 100644 index 39372a2d07..0000000000 --- a/Tools/Source/GenBuild/org/tianocore/build/pcd/action/CollectPCDAction.java +++ /dev/null @@ -1,1535 +0,0 @@ -/** @file
- CollectPCDAction class.
-
- This action class is to collect PCD information from MSA, SPD, FPD xml file.
- This class will be used for wizard and build tools, So it can *not* inherit
- from buildAction or wizardAction.
-
-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.
-
-**/
-package org.tianocore.build.pcd.action;
-
-import java.io.File;
-import java.io.IOException;
-import java.math.BigInteger;
-import java.util.ArrayList;
-import java.util.Comparator;
-import java.util.HashMap;
-import java.util.Iterator;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.UUID;
-import java.util.regex.Matcher;
-import java.util.regex.Pattern;
-
-import org.apache.xmlbeans.XmlException;
-import org.apache.xmlbeans.XmlObject;
-import org.tianocore.DynamicPcdBuildDefinitionsDocument.DynamicPcdBuildDefinitions;
-import org.tianocore.FrameworkModulesDocument;
-import org.tianocore.ModuleSADocument;
-import org.tianocore.PcdBuildDefinitionDocument;
-import org.tianocore.PcdBuildDefinitionDocument.PcdBuildDefinition;
-import org.tianocore.PlatformSurfaceAreaDocument;
-import org.tianocore.build.fpd.FpdParserTask;
-import org.tianocore.build.global.GlobalData;
-import org.tianocore.build.id.FpdModuleIdentification;
-import org.tianocore.build.id.ModuleIdentification;
-import org.tianocore.pcd.action.ActionMessage;
-import org.tianocore.pcd.entity.CommonDefinition;
-import org.tianocore.pcd.entity.DynamicTokenValue;
-import org.tianocore.pcd.entity.MemoryDatabaseManager;
-import org.tianocore.pcd.entity.SkuInstance;
-import org.tianocore.pcd.entity.Token;
-import org.tianocore.pcd.entity.UsageIdentification;
-import org.tianocore.pcd.entity.UsageInstance;
-import org.tianocore.pcd.exception.EntityException;
-
-/** Module Info class is the data structure to hold information got from GlobalData.
-*/
-class ModuleInfo {
- ///
- /// Module's ID for a <ModuleSA>
- ///
- private FpdModuleIdentification moduleId;
- ///
- /// <PcdBuildDefinition> xmlobject in FPD file for a <ModuleSA>
- ///
- private PcdBuildDefinitionDocument.PcdBuildDefinition pcdBuildDef;
-
- public ModuleInfo (FpdModuleIdentification moduleId, XmlObject pcdDef) {
- this.moduleId = moduleId;
- this.pcdBuildDef = ((PcdBuildDefinitionDocument)pcdDef).getPcdBuildDefinition();
- }
-
- public FpdModuleIdentification getModuleId (){
- return moduleId;
- }
-
- public PcdBuildDefinitionDocument.PcdBuildDefinition getPcdBuildDef(){
- return pcdBuildDef;
- }
-}
-
-/** This action class is to collect PCD information from MSA, SPD, FPD xml file.
- This class will be used for wizard and build tools, So it can *not* inherit
- from buildAction or UIAction.
-**/
-public class CollectPCDAction {
- ///
- /// memoryDatabase hold all PCD information collected from SPD, MSA, FPD.
- ///
- private MemoryDatabaseManager dbManager;
- ///
- /// Workspacepath hold the workspace information.
- ///
- private String workspacePath;
- ///
- /// FPD file is the root file.
- ///
- private String fpdFilePath;
- ///
- /// Message level for CollectPCDAction.
- ///
- private int originalMessageLevel;
- ///
- /// Cache the fpd docment instance for private usage.
- ///
- private PlatformSurfaceAreaDocument fpdDocInstance;
- ///
- /// xmlObject name
- ///
- private static String xmlObjectName = "PcdBuildDefinition";
-
- /**
- Set WorkspacePath parameter for this action class.
-
- @param workspacePath parameter for this action
- **/
- public void setWorkspacePath(String workspacePath) {
- this.workspacePath = workspacePath;
- }
-
- /**
- Set action message level for CollectPcdAction tool.
-
- The message should be restored when this action exit.
-
- @param actionMessageLevel parameter for this action
- **/
- public void setActionMessageLevel(int actionMessageLevel) {
- originalMessageLevel = ActionMessage.messageLevel;
- ActionMessage.messageLevel = actionMessageLevel;
- }
-
- /**
- Set FPDFileName parameter for this action class.
-
- @param fpdFilePath fpd file path
- **/
- public void setFPDFilePath(String fpdFilePath) {
- this.fpdFilePath = fpdFilePath;
- }
-
- /**
- Common function interface for outer.
-
- @param workspacePath The path of workspace of current build or analysis.
- @param fpdFilePath The fpd file path of current build or analysis.
- @param messageLevel The message level for this Action.
-
- @throws Exception The exception of this function. Because it can *not* be predict
- where the action class will be used. So only Exception can be throw.
-
- **/
- public void perform(String workspacePath, String fpdFilePath,
- int messageLevel) throws Exception {
- setWorkspacePath(workspacePath);
- setFPDFilePath(fpdFilePath);
- setActionMessageLevel(messageLevel);
- checkParameter();
- execute();
- ActionMessage.messageLevel = originalMessageLevel;
- }
-
- /**
- Core execution function for this action class.
-
- This function work flows will be:
- 1) Collect and prepocess PCD information from FPD file, all PCD
- information will be stored into memory database.
- 2) Generate 3 strings for
- a) All modules using Dynamic(Ex) PCD entry.(Token Number)
- b) PEI PCDDatabase (C Structure) for PCD Service PEIM.
- c) DXE PCD Database (C structure) for PCD Service DXE.
-
-
- @throws EntityException Exception indicate failed to execute this action.
-
- **/
- public void execute() throws EntityException {
- //
- // Get memoryDatabaseManager instance from GlobalData.
- // The memoryDatabaseManager should be initialized for whatever build
- // tools or wizard tools
- //
- if((dbManager = GlobalData.getPCDMemoryDBManager()) == null) {
- throw new EntityException("The instance of PCD memory database manager is null");
- }
-
- //
- // Collect all PCD information defined in FPD file.
- // Evenry token defind in FPD will be created as an token into
- // memory database.
- //
- createTokenInDBFromFPD();
-
- //
- // Generate for PEI, DXE PCD DATABASE's definition and initialization.
- //
- genPcdDatabaseSourceCode ();
-
- }
-
- /**
- This function generates source code for PCD Database.
-
- @param void
- @throws EntityException If the token does *not* exist in memory database.
-
- **/
- private void genPcdDatabaseSourceCode()
- throws EntityException {
- String PcdCommonHeaderString = PcdDatabase.getPcdDatabaseCommonDefinitions();
-
- ArrayList<Token> alPei = new ArrayList<Token> ();
- ArrayList<Token> alDxe = new ArrayList<Token> ();
-
- dbManager.getTwoPhaseDynamicRecordArray(alPei, alDxe);
- PcdDatabase pcdPeiDatabase = new PcdDatabase (alPei, "PEI", 0);
- pcdPeiDatabase.genCode();
- MemoryDatabaseManager.PcdPeimHString = PcdCommonHeaderString + pcdPeiDatabase.getHString() +
- PcdDatabase.getPcdPeiDatabaseDefinitions();
- MemoryDatabaseManager.PcdPeimCString = pcdPeiDatabase.getCString();
-
- PcdDatabase pcdDxeDatabase = new PcdDatabase(alDxe, "DXE", alPei.size());
- pcdDxeDatabase.genCode();
- MemoryDatabaseManager.PcdDxeHString = MemoryDatabaseManager.PcdPeimHString + pcdDxeDatabase.getHString() +
- PcdDatabase.getPcdDxeDatabaseDefinitions();
- MemoryDatabaseManager.PcdDxeCString = pcdDxeDatabase.getCString();
- }
-
- /**
- Get component array from FPD.
-
- This function maybe provided by some Global class.
-
- @return List<ModuleInfo> the component array.
-
- */
- private List<ModuleInfo> getComponentsFromFPD()
- throws EntityException {
- List<ModuleInfo> allModules = new ArrayList<ModuleInfo>();
- FrameworkModulesDocument.FrameworkModules fModules = null;
- ModuleSADocument.ModuleSA[] modules = null;
- Map<FpdModuleIdentification, XmlObject> pcdBuildDefinitions = null;
-
- pcdBuildDefinitions = GlobalData.getFpdPcdBuildDefinitions();
- if (pcdBuildDefinitions == null) {
- return null;
- }
-
- //
- // Loop map to retrieve all PCD build definition and Module id
- //
- Iterator item = pcdBuildDefinitions.keySet().iterator();
- while (item.hasNext()){
- FpdModuleIdentification id = (FpdModuleIdentification) item.next();
- allModules.add(new ModuleInfo(id, pcdBuildDefinitions.get(id)));
- }
-
- return allModules;
- }
-
- /**
- Create token instance object into memory database, the token information
- comes for FPD file. Normally, FPD file will contain all token platform
- informations.
-
- @return FrameworkPlatformDescriptionDocument The FPD document instance for furture usage.
-
- @throws EntityException Failed to parse FPD xml file.
-
- **/
- private void createTokenInDBFromFPD()
- throws EntityException {
- int index = 0;
- int index2 = 0;
- int pcdIndex = 0;
- List<PcdBuildDefinition.PcdData> pcdBuildDataArray = new ArrayList<PcdBuildDefinition.PcdData>();
- PcdBuildDefinition.PcdData pcdBuildData = null;
- Token token = null;
- List<ModuleInfo> modules = null;
- String primaryKey = null;
- String exceptionString = null;
- UsageInstance usageInstance = null;
- String primaryKey1 = null;
- String primaryKey2 = null;
- boolean isDuplicate = false;
- Token.PCD_TYPE pcdType = Token.PCD_TYPE.UNKNOWN;
- Token.DATUM_TYPE datumType = Token.DATUM_TYPE.UNKNOWN;
- long tokenNumber = 0;
- String moduleName = null;
- String datum = null;
- int maxDatumSize = 0;
- String[] tokenSpaceStrRet = null;
- UsageIdentification usageId = null;
- ModuleIdentification moduleId = null;
-
- //
- // ----------------------------------------------
- // 1), Get all <ModuleSA> from FPD file.
- // ----------------------------------------------
- //
- modules = getComponentsFromFPD();
-
- if (modules == null) {
- throw new EntityException("[FPD file error] No modules in FPD file, Please check whether there are elements in <FrameworkModules> in FPD file!");
- }
-
- //
- // -------------------------------------------------------------------
- // 2), Loop all modules to process <PcdBuildDeclarations> for each module.
- // -------------------------------------------------------------------
- //
- for (index = 0; index < modules.size(); index ++) {
- //
- // It is legal for a module does not contains ANY pcd build definitions.
- //
- if (modules.get(index).getPcdBuildDef() == null) {
- continue;
- }
-
- pcdBuildDataArray = modules.get(index).getPcdBuildDef().getPcdDataList();
-
- moduleName = modules.get(index).getModuleId().getModule().getName();
-
- //
- // ----------------------------------------------------------------------
- // 2.1), Loop all Pcd entry for a module and add it into memory database.
- // ----------------------------------------------------------------------
- //
- for (pcdIndex = 0; pcdIndex < pcdBuildDataArray.size(); pcdIndex ++) {
- pcdBuildData = pcdBuildDataArray.get(pcdIndex);
-
- try {
- tokenSpaceStrRet = GlobalData.getGuidInfoFromCname(pcdBuildData.getTokenSpaceGuidCName());
- } catch ( Exception e ) {
- throw new EntityException ("Faile get Guid for token " + pcdBuildData.getCName() + ":" + e.getMessage());
- }
-
- if (tokenSpaceStrRet == null) {
- throw new EntityException ("Fail to get Token space guid for token" + pcdBuildData.getCName());
- }
-
- primaryKey = Token.getPrimaryKeyString(pcdBuildData.getCName(), tokenSpaceStrRet[1]);
- pcdType = Token.getpcdTypeFromString(pcdBuildData.getItemType().toString());
- datumType = Token.getdatumTypeFromString(pcdBuildData.getDatumType().toString());
- tokenNumber = Long.decode(pcdBuildData.getToken().toString());
- if (pcdBuildData.getValue() != null) {
- datum = pcdBuildData.getValue().toString();
- } else {
- datum = null;
- }
- maxDatumSize = pcdBuildData.getMaxDatumSize();
-
- if ((pcdType == Token.PCD_TYPE.FEATURE_FLAG) &&
- (datumType != Token.DATUM_TYPE.BOOLEAN)){
- exceptionString = String.format("[FPD file error] For PCD %s in module %s, the PCD type is FEATRUE_FLAG but "+
- "datum type of this PCD entry is not BOOLEAN!",
- pcdBuildData.getCName(),
- moduleName);
- throw new EntityException(exceptionString);
- }
-
- //
- // -------------------------------------------------------------------------------------------
- // 2.1.1), Do some necessary checking work for FixedAtBuild, FeatureFlag and PatchableInModule
- // -------------------------------------------------------------------------------------------
- //
- if (!Token.isDynamic(pcdType)) {
- //
- // Value is required.
- //
- if (datum == null) {
- exceptionString = String.format("[FPD file error] There is no value for PCD entry %s in module %s!",
- pcdBuildData.getCName(),
- moduleName);
- throw new EntityException(exceptionString);
- }
-
- //
- // Check whether the datum size is matched datum type.
- //
- if ((exceptionString = verifyDatum(pcdBuildData.getCName(),
- moduleName,
- datum,
- datumType,
- maxDatumSize)) != null) {
- throw new EntityException(exceptionString);
- }
- }
-
- //
- // ---------------------------------------------------------------------------------
- // 2.1.2), Create token or update token information for current anaylized PCD data.
- // ---------------------------------------------------------------------------------
- //
- if (dbManager.isTokenInDatabase(primaryKey)) {
- //
- // If the token is already exist in database, do some necessary checking
- // and add a usage instance into this token in database
- //
- token = dbManager.getTokenByKey(primaryKey);
-
- //
- // checking for DatumType, DatumType should be unique for one PCD used in different
- // modules.
- //
- if (token.datumType != datumType) {
- exceptionString = String.format("[FPD file error] The datum type of PCD entry %s is %s, which is different with %s defined in before!",
- pcdBuildData.getCName(),
- pcdBuildData.getDatumType().toString(),
- Token.getStringOfdatumType(token.datumType));
- throw new EntityException(exceptionString);
- }
-
- //
- // Check token number is valid
- //
- if (tokenNumber != token.tokenNumber) {
- exceptionString = String.format("[FPD file error] The token number of PCD entry %s in module %s is different with same PCD entry in other modules!",
- pcdBuildData.getCName(),
- moduleName);
- throw new EntityException(exceptionString);
- }
-
- //
- // For same PCD used in different modules, the PCD type should all be dynamic or non-dynamic.
- //
- if (token.isDynamicPCD != Token.isDynamic(pcdType)) {
- exceptionString = String.format("[FPD file error] For PCD entry %s in module %s, you define dynamic or non-dynamic PCD type which"+
- "is different with others module's",
- token.cName,
- moduleName);
- throw new EntityException(exceptionString);
- }
-
- if (token.isDynamicPCD) {
- //
- // Check datum is equal the datum in dynamic information.
- // For dynamic PCD, you can do not write <Value> in sperated every <PcdBuildDefinition> in different <ModuleSA>,
- // But if you write, the <Value> must be same as the value in <DynamicPcdBuildDefinitions>.
- //
- if (!token.isSkuEnable() &&
- (token.getDefaultSku().type == DynamicTokenValue.VALUE_TYPE.DEFAULT_TYPE) &&
- (datum != null)) {
- if (!datum.equalsIgnoreCase(token.getDefaultSku().value)) {
- exceptionString = String.format("[FPD file error] For dynamic PCD %s in module %s, the datum in <ModuleSA> is "+
- "not equal to the datum in <DynamicPcdBuildDefinitions>, it is "+
- "illega! You could no set <Value> in <ModuleSA> for a dynamic PCD!",
- token.cName,
- moduleName);
- throw new EntityException(exceptionString);
- }
- }
-
- if ((maxDatumSize != 0) &&
- (maxDatumSize != token.datumSize)){
- exceptionString = String.format("[FPD file error] For dynamic PCD %s in module %s, the max datum size is %d which "+
- "is different with <MaxDatumSize> %d defined in <DynamicPcdBuildDefinitions>!",
- token.cName,
- moduleName,
- maxDatumSize,
- token.datumSize);
- throw new EntityException(exceptionString);
- }
- }
-
- } else {
- //
- // If the token is not in database, create a new token instance and add
- // a usage instance into this token in database.
- //
- try {
- tokenSpaceStrRet = GlobalData.getGuidInfoFromCname(pcdBuildData.getTokenSpaceGuidCName());
- } catch (Exception e) {
- throw new EntityException("Fail to get token space guid for token " + token.cName);
- }
-
- if (tokenSpaceStrRet == null) {
- throw new EntityException("Fail to get token space guid for token " + token.cName);
- }
-
- token = new Token(pcdBuildData.getCName(), tokenSpaceStrRet[1]);
-
- token.datumType = datumType;
- token.tokenNumber = tokenNumber;
- token.isDynamicPCD = Token.isDynamic(pcdType);
- token.datumSize = maxDatumSize;
-
- if (token.isDynamicPCD) {
- //
- // For Dynamic and Dynamic Ex type, need find the dynamic information
- // in <DynamicPcdBuildDefinition> section in FPD file.
- //
- updateDynamicInformation(moduleName,
- token,
- datum,
- maxDatumSize);
- }
-
- dbManager.addTokenToDatabase(primaryKey, token);
- }
-
- //
- // -----------------------------------------------------------------------------------
- // 2.1.3), Add the PcdType in current module into this Pcd token's supported PCD type.
- // -----------------------------------------------------------------------------------
- //
- token.updateSupportPcdType(pcdType);
-
- //
- // ------------------------------------------------
- // 2.1.4), Create an usage instance for this token.
- // ------------------------------------------------
- //
- moduleId = modules.get(index).getModuleId().getModule();
- usageId = new UsageIdentification (moduleId.getName(),
- moduleId.getGuid(),
- moduleId.getPackage().getName(),
- moduleId.getPackage().getGuid(),
- modules.get(index).getModuleId().getArch(),
- moduleId.getVersion(),
- moduleId.getModuleType());
- usageInstance = new UsageInstance(token,
- usageId,
- pcdType,
- datum,
- maxDatumSize);
- token.addUsageInstance(usageInstance);
- }
- }
-
- //
- // ------------------------------------------------
- // 3), Add unreference dynamic_Ex pcd token into Pcd database.
- // ------------------------------------------------
- //
- List<Token> tokenArray = getUnreferencedDynamicPcd();
- if (tokenArray != null) {
- for (index = 0; index < tokenArray.size(); index ++) {
- dbManager.addTokenToDatabase(tokenArray.get(index).getPrimaryKeyString(),
- tokenArray.get(index));
- }
- }
- }
-
- private List<Token> getUnreferencedDynamicPcd () throws EntityException {
- List<Token> tokenArray = new ArrayList<Token>();
- Token token = null;
- DynamicPcdBuildDefinitions dynamicPcdBuildDefinitions = null;
- List<DynamicPcdBuildDefinitions.PcdBuildData> dynamicPcdBuildDataArray = null;
- DynamicPcdBuildDefinitions.PcdBuildData pcdBuildData = null;
- List<DynamicPcdBuildDefinitions.PcdBuildData.SkuInfo> skuInfoList = null;
- Token.PCD_TYPE pcdType;
- SkuInstance skuInstance = null;
- String primaryKey = null;
- boolean hasSkuId0 = false;
- int index, offset, index2;
- String temp;
- String exceptionString;
- String hiiDefaultValue;
- String tokenSpaceStrRet[];
- String variableGuidString[];
-
- //
- // Open fpd document to get <DynamicPcdBuildDefinition> Section.
- // BUGBUG: the function should be move GlobalData in furture.
- //
- if (fpdDocInstance == null) {
- try {
- fpdDocInstance = (PlatformSurfaceAreaDocument)XmlObject.Factory.parse(new File(fpdFilePath));
- } catch(IOException ioE) {
- throw new EntityException("File IO error for xml file:" + fpdFilePath + "\n" + ioE.getMessage());
- } catch(XmlException xmlE) {
- throw new EntityException("Can't parse the FPD xml fle:" + fpdFilePath + "\n" + xmlE.getMessage());
- }
- }
-
- dynamicPcdBuildDefinitions = fpdDocInstance.getPlatformSurfaceArea().getDynamicPcdBuildDefinitions();
- if (dynamicPcdBuildDefinitions == null) {
- return null;
- }
-
- dynamicPcdBuildDataArray = dynamicPcdBuildDefinitions.getPcdBuildDataList();
- for (index2 = 0; index2 < dynamicPcdBuildDataArray.size(); index2 ++) {
- pcdBuildData = dynamicPcdBuildDataArray.get(index2);
- try {
- tokenSpaceStrRet = GlobalData.getGuidInfoFromCname(pcdBuildData.getTokenSpaceGuidCName());
- } catch ( Exception e ) {
- throw new EntityException ("Faile get Guid for token " + pcdBuildData.getCName() + ":" + e.getMessage());
- }
-
- if (tokenSpaceStrRet == null) {
- throw new EntityException ("Fail to get Token space guid for token" + pcdBuildData.getCName());
- }
-
- primaryKey = Token.getPrimaryKeyString(pcdBuildData.getCName(),
- tokenSpaceStrRet[1]);
-
- if (dbManager.isTokenInDatabase(primaryKey)) {
- continue;
- }
-
- pcdType = Token.getpcdTypeFromString(pcdBuildData.getItemType().toString());
- if (pcdType != Token.PCD_TYPE.DYNAMIC_EX) {
- throw new EntityException (String.format("[FPD file error] It not allowed for DYNAMIC PCD %s who is no used by any module",
- pcdBuildData.getCName()));
- }
-
- //
- // Create new token for unreference dynamic PCD token
- //
- token = new Token(pcdBuildData.getCName(), tokenSpaceStrRet[1]);
- token.datumSize = pcdBuildData.getMaxDatumSize();
-
-
- token.datumType = Token.getdatumTypeFromString(pcdBuildData.getDatumType().toString());
- token.tokenNumber = Long.decode(pcdBuildData.getToken().toString());
- token.dynamicExTokenNumber = token.tokenNumber;
- token.isDynamicPCD = true;
- token.updateSupportPcdType(pcdType);
-
- exceptionString = verifyDatum(token.cName,
- null,
- null,
- token.datumType,
- token.datumSize);
- if (exceptionString != null) {
- throw new EntityException(exceptionString);
- }
-
- skuInfoList = pcdBuildData.getSkuInfoList();
-
- //
- // Loop all sku data
- //
- for (index = 0; index < skuInfoList.size(); index ++) {
- skuInstance = new SkuInstance();
- //
- // Although SkuId in schema is BigInteger, but in fact, sku id is 32 bit value.
- //
- temp = skuInfoList.get(index).getSkuId().toString();
- skuInstance.id = Integer.decode(temp);
- if (skuInstance.id == 0) {
- hasSkuId0 = true;
- }
- //
- // Judge whether is DefaultGroup at first, because most case is DefautlGroup.
- //
- if (skuInfoList.get(index).getValue() != null) {
- skuInstance.value.setValue(skuInfoList.get(index).getValue().toString());
- if ((exceptionString = verifyDatum(token.cName,
- null,
- skuInfoList.get(index).getValue().toString(),
- token.datumType,
- token.datumSize)) != null) {
- throw new EntityException(exceptionString);
- }
-
- token.skuData.add(skuInstance);
-
- continue;
- }
-
- //
- // Judge whether is HII group case.
- //
- if (skuInfoList.get(index).getVariableName() != null) {
- exceptionString = null;
- if (skuInfoList.get(index).getVariableGuid() == null) {
- exceptionString = String.format("[FPD file error] For dynamic PCD %s in <DynamicPcdBuildDefinitions> section in FPD "+
- "file, who use HII, but there is no <VariableGuid> defined for Sku %d data!",
- token.cName,
- index);
- if (exceptionString != null) {
- throw new EntityException(exceptionString);
- }
- }
-
- if (skuInfoList.get(index).getVariableOffset() == null) {
- exceptionString = String.format("[FPD file error] For dynamic PCD %s in <DynamicPcdBuildDefinitions> section in FPD "+
- "file, who use HII, but there is no <VariableOffset> defined for Sku %d data!",
- token.cName,
- index);
- if (exceptionString != null) {
- throw new EntityException(exceptionString);
- }
- }
-
- if (skuInfoList.get(index).getHiiDefaultValue() == null) {
- exceptionString = String.format("[FPD file error] For dynamic PCD %s in <DynamicPcdBuildDefinitions> section in FPD "+
- "file, who use HII, but there is no <HiiDefaultValue> defined for Sku %d data!",
- token.cName,
- index);
- if (exceptionString != null) {
- throw new EntityException(exceptionString);
- }
- }
-
- if (skuInfoList.get(index).getHiiDefaultValue() != null) {
- hiiDefaultValue = skuInfoList.get(index).getHiiDefaultValue().toString();
- } else {
- hiiDefaultValue = null;
- }
-
- if ((exceptionString = verifyDatum(token.cName,
- null,
- hiiDefaultValue,
- token.datumType,
- token.datumSize)) != null) {
- throw new EntityException(exceptionString);
- }
-
- offset = Integer.decode(skuInfoList.get(index).getVariableOffset());
- if (offset > 0xFFFF) {
- throw new EntityException(String.format("[FPD file error] For dynamic PCD %s , the variable offset defined in sku %d data "+
- "exceed 64K, it is not allowed!",
- token.cName,
- index));
- }
-
- //
- // Get variable guid string according to the name of guid which will be mapped into a GUID in SPD file.
- //
- variableGuidString = GlobalData.getGuidInfoFromCname(skuInfoList.get(index).getVariableGuid().toString());
- if (variableGuidString == null) {
- throw new EntityException(String.format("[GUID Error] For dynamic PCD %s, the variable guid %s can be found in all SPD file!",
- token.cName,
- skuInfoList.get(index).getVariableGuid().toString()));
- }
- String variableStr = skuInfoList.get(index).getVariableName();
- Pattern pattern = Pattern.compile("0x([a-fA-F0-9]){4}");
- Matcher matcher = pattern.matcher(variableStr);
- List<String> varNameList = new ArrayList<String>();
- while (matcher.find()){
- String str = variableStr.substring(matcher.start(),matcher.end());
- varNameList.add(str);
- }
-
- skuInstance.value.setHiiData(varNameList,
- translateSchemaStringToUUID(variableGuidString[1]),
- skuInfoList.get(index).getVariableOffset(),
- skuInfoList.get(index).getHiiDefaultValue().toString());
- token.skuData.add(skuInstance);
- continue;
- }
-
- if (skuInfoList.get(index).getVpdOffset() != null) {
- skuInstance.value.setVpdData(skuInfoList.get(index).getVpdOffset());
- token.skuData.add(skuInstance);
- continue;
- }
-
- exceptionString = String.format("[FPD file error] For dynamic PCD %s, the dynamic info must "+
- "be one of 'DefaultGroup', 'HIIGroup', 'VpdGroup'.",
- token.cName);
- throw new EntityException(exceptionString);
- }
-
- if (!hasSkuId0) {
- exceptionString = String.format("[FPD file error] For dynamic PCD %s in <DynamicPcdBuildDefinitions>, there are "+
- "no sku id = 0 data, which is required for every dynamic PCD",
- token.cName);
- throw new EntityException(exceptionString);
- }
-
- tokenArray.add(token);
- }
-
- return tokenArray;
- }
-
- /**
- Verify the datum value according its datum size and datum type, this
- function maybe moved to FPD verification tools in future.
-
- @param cName
- @param moduleName
- @param datum
- @param datumType
- @param maxDatumSize
-
- @return String
- */
- /***/
- public String verifyDatum(String cName,
- String moduleName,
- String datum,
- Token.DATUM_TYPE datumType,
- int maxDatumSize) {
- String exceptionString = null;
- int value;
- BigInteger value64;
- String subStr;
- int index;
-
- if (moduleName == null) {
- moduleName = "section <DynamicPcdBuildDefinitions>";
- } else {
- moduleName = "module " + moduleName;
- }
-
- if (maxDatumSize == 0) {
- exceptionString = String.format("[FPD file error] You maybe miss <MaxDatumSize> for PCD %s in %s",
- cName,
- moduleName);
- return exceptionString;
- }
-
- switch (datumType) {
- case UINT8:
- if (maxDatumSize != 1) {
- exceptionString = String.format("[FPD file error] The datum type of PCD data %s in %s "+
- "is UINT8, but datum size is %d, they are not matched!",
- cName,
- moduleName,
- maxDatumSize);
- return exceptionString;
- }
-
- if (datum != null) {
- try {
- value = Integer.decode(datum);
- } catch (NumberFormatException nfeExp) {
- exceptionString = String.format("[FPD file error] The datum for PCD %s in %s is not valid "+
- "digital format of UINT8",
- cName,
- moduleName);
- return exceptionString;
- }
- if (value > 0xFF) {
- exceptionString = String.format("[FPD file error] The datum for PCD %s in %s is %s exceed"+
- " the max size of UINT8 - 0xFF",
- cName,
- moduleName,
- datum);
- return exceptionString;
- }
- }
- break;
- case UINT16:
- if (maxDatumSize != 2) {
- exceptionString = String.format("[FPD file error] The datum type of PCD data %s in %s "+
- "is UINT16, but datum size is %d, they are not matched!",
- cName,
- moduleName,
- maxDatumSize);
- return exceptionString;
- }
- if (datum != null) {
- try {
- value = Integer.decode(datum);
- } catch (NumberFormatException nfeExp) {
- exceptionString = String.format("[FPD file error] The datum for PCD %s in %s is "+
- "not valid digital of UINT16",
- cName,
- moduleName);
- return exceptionString;
- }
- if (value > 0xFFFF) {
- exceptionString = String.format("[FPD file error] The datum for PCD %s in %s is %s "+
- "which exceed the range of UINT16 - 0xFFFF",
- cName,
- moduleName,
- datum);
- return exceptionString;
- }
- }
- break;
- case UINT32:
- if (maxDatumSize != 4) {
- exceptionString = String.format("[FPD file error] The datum type of PCD data %s in %s "+
- "is UINT32, but datum size is %d, they are not matched!",
- cName,
- moduleName,
- maxDatumSize);
- return exceptionString;
- }
-
- if (datum != null) {
- try {
- if (datum.length() > 2) {
- if ((datum.charAt(0) == '0') &&
- ((datum.charAt(1) == 'x') || (datum.charAt(1) == 'X'))){
- subStr = datum.substring(2, datum.length());
- value64 = new BigInteger(subStr, 16);
- } else {
- value64 = new BigInteger(datum);
- }
- } else {
- value64 = new BigInteger(datum);
- }
- } catch (NumberFormatException nfeExp) {
- exceptionString = String.format("[FPD file error] The datum for PCD %s in %s is not "+
- "valid digital of UINT32",
- cName,
- moduleName);
- return exceptionString;
- }
-
- if (value64.bitLength() > 32) {
- exceptionString = String.format("[FPD file error] The datum for PCD %s in %s is %s which "+
- "exceed the range of UINT32 - 0xFFFFFFFF",
- cName,
- moduleName,
- datum);
- return exceptionString;
- }
- }
- break;
- case UINT64:
- if (maxDatumSize != 8) {
- exceptionString = String.format("[FPD file error] The datum type of PCD data %s in %s "+
- "is UINT64, but datum size is %d, they are not matched!",
- cName,
- moduleName,
- maxDatumSize);
- return exceptionString;
- }
-
- if (datum != null) {
- try {
- if (datum.length() > 2) {
- if ((datum.charAt(0) == '0') &&
- ((datum.charAt(1) == 'x') || (datum.charAt(1) == 'X'))){
- subStr = datum.substring(2, datum.length());
- value64 = new BigInteger(subStr, 16);
- } else {
- value64 = new BigInteger(datum);
- }
- } else {
- value64 = new BigInteger(datum);
- }
- } catch (NumberFormatException nfeExp) {
- exceptionString = String.format("[FPD file error] The datum for PCD %s in %s is not valid"+
- " digital of UINT64",
- cName,
- moduleName);
- return exceptionString;
- }
-
- if (value64.bitLength() > 64) {
- exceptionString = String.format("[FPD file error] The datum for PCD %s in %s is %s "+
- "exceed the range of UINT64 - 0xFFFFFFFFFFFFFFFF",
- cName,
- moduleName,
- datum);
- return exceptionString;
- }
- }
- break;
- case BOOLEAN:
- if (maxDatumSize != 1) {
- exceptionString = String.format("[FPD file error] The datum type of PCD data %s in %s "+
- "is BOOLEAN, but datum size is %d, they are not matched!",
- cName,
- moduleName,
- maxDatumSize);
- return exceptionString;
- }
-
- if (datum != null) {
- if (!(datum.equalsIgnoreCase("TRUE") ||
- datum.equalsIgnoreCase("FALSE"))) {
- exceptionString = String.format("[FPD file error] The datum type of PCD data %s in %s "+
- "is BOOELAN, but value is not 'true'/'TRUE' or 'FALSE'/'false'",
- cName,
- moduleName);
- return exceptionString;
- }
-
- }
- break;
- case POINTER:
- if (datum == null) {
- break;
- }
-
- char ch = datum.charAt(0);
- int start, end;
- String strValue;
- //
- // For void* type PCD, only three datum is support:
- // 1) Unicode: string with start char is "L"
- // 2) Ansci: String start char is ""
- // 3) byte array: String start char "{"
- //
- if (ch == 'L') {
- start = datum.indexOf('\"');
- end = datum.lastIndexOf('\"');
- if ((start > end) ||
- (end > datum.length())||
- ((start == end) && (datum.length() > 0))) {
- exceptionString = String.format("[FPD file error] The datum type of PCD %s in %s is VOID* and datum is "+
- "a UNICODE string because start with L\", but format maybe"+
- "is not right, correct UNICODE string is L\"...\"!",
- cName,
- moduleName);
- return exceptionString;
- }
-
- strValue = datum.substring(start + 1, end);
- if ((strValue.length() * 2) > maxDatumSize) {
- exceptionString = String.format("[FPD file error] The datum type of PCD %s in %s is VOID*, and datum is "+
- "a UNICODE string, but the datum size is %d exceed to <MaxDatumSize> : %d",
- cName,
- moduleName,
- strValue.length() * 2,
- maxDatumSize);
- return exceptionString;
- }
- } else if (ch == '\"'){
- start = datum.indexOf('\"');
- end = datum.lastIndexOf('\"');
- if ((start > end) ||
- (end > datum.length())||
- ((start == end) && (datum.length() > 0))) {
- exceptionString = String.format("[FPD file error] The datum type of PCD %s in %s is VOID* and datum is "+
- "a ANSCII string because start with \", but format maybe"+
- "is not right, correct ANSIC string is \"...\"!",
- cName,
- moduleName);
- return exceptionString;
- }
- strValue = datum.substring(start + 1, end);
- if ((strValue.length()) > maxDatumSize) {
- exceptionString = String.format("[FPD file error] The datum type of PCD %s in %s is VOID*, and datum is "+
- "a ANSCI string, but the datum size is %d which exceed to <MaxDatumSize> : %d",
- cName,
- moduleName,
- strValue.length(),
- maxDatumSize);
- return exceptionString;
- }
- } else if (ch =='{') {
- String[] strValueArray;
-
- start = datum.indexOf('{');
- end = datum.lastIndexOf('}');
- strValue = datum.substring(start + 1, end);
- strValue = strValue.trim();
- if (strValue.length() == 0) {
- exceptionString = String.format ("[FPD file error] The datum type of PCD %s in %s is VOID*, and "+
- "it is byte array in fact, but '{}' is not valid for NULL datam but"+
- " need use '{0}'",
- cName,
- moduleName);
- return exceptionString;
- }
- strValueArray = strValue.split(",");
- for (index = 0; index < strValueArray.length; index ++) {
- try{
- value = Integer.decode(strValueArray[index].trim());
- } catch (NumberFormatException nfeEx) {
- exceptionString = String.format("[FPD file error] The datum type of PCD %s in %s is VOID*, and "+
- "it is byte array in fact. For every byte in array should be a valid"+
- "byte digital, but element %s is not a valid byte digital!",
- cName,
- moduleName,
- strValueArray[index]);
- return exceptionString;
- }
- if (value > 0xFF) {
- exceptionString = String.format("[FPD file error] The datum type of PCD %s in %s is VOID*, "+
- "it is byte array in fact. But the element of %s exceed the byte range",
- cName,
- moduleName,
- strValueArray[index]);
- return exceptionString;
- }
- }
-
- if (strValueArray.length > maxDatumSize) {
- exceptionString = String.format("[FPD file error] The datum type of PCD %s in %s is VOID*, and datum is byte"+
- "array, but the number of bytes is %d which exceed to <MaxDatumSzie> : %d!",
- cName,
- moduleName,
- strValueArray.length,
- maxDatumSize);
- return exceptionString;
- }
- } else {
- exceptionString = String.format("[FPD file error] The datum type of PCD %s in %s is VOID*. For VOID* type, you have three format choise:\n "+
- "1) UNICODE string: like L\"xxxx\";\r\n"+
- "2) ANSIC string: like \"xxx\";\r\n"+
- "3) Byte array: like {0x2, 0x45, 0x23}\r\n"+
- "But the datum in seems does not following above format!",
- cName,
- moduleName);
- return exceptionString;
- }
- break;
- default:
- exceptionString = String.format("[FPD file error] For PCD entry %s in %s, datum type is unknown, it should be one of "+
- "UINT8, UINT16, UINT32, UINT64, VOID*, BOOLEAN",
- cName,
- moduleName);
- return exceptionString;
- }
- return null;
- }
-
- /**
- Get dynamic information for a dynamic PCD from <DynamicPcdBuildDefinition> seciton in FPD file.
-
- This function should be implemented in GlobalData in future.
-
- @param token The token instance which has hold module's PCD information
- @param moduleName The name of module who will use this Dynamic PCD.
-
- @return DynamicPcdBuildDefinitions.PcdBuildData
- */
- /***/
- private DynamicPcdBuildDefinitions.PcdBuildData getDynamicInfoFromFPD(Token token,
- String moduleName)
- throws EntityException {
- int index = 0;
- String exceptionString = null;
- String dynamicPrimaryKey = null;
- DynamicPcdBuildDefinitions dynamicPcdBuildDefinitions = null;
- List<DynamicPcdBuildDefinitions.PcdBuildData> dynamicPcdBuildDataArray = null;
- String[] tokenSpaceStrRet = null;
-
- //
- // If FPD document is not be opened, open and initialize it.
- // BUGBUG: The code should be moved into GlobalData in future.
- //
- if (fpdDocInstance == null) {
- try {
- fpdDocInstance = (PlatformSurfaceAreaDocument)XmlObject.Factory.parse(new File(fpdFilePath));
- } catch(IOException ioE) {
- throw new EntityException("File IO error for xml file:" + fpdFilePath + "\n" + ioE.getMessage());
- } catch(XmlException xmlE) {
- throw new EntityException("Can't parse the FPD xml fle:" + fpdFilePath + "\n" + xmlE.getMessage());
- }
- }
-
- dynamicPcdBuildDefinitions = fpdDocInstance.getPlatformSurfaceArea().getDynamicPcdBuildDefinitions();
- if (dynamicPcdBuildDefinitions == null) {
- exceptionString = String.format("[FPD file error] There are no <PcdDynamicBuildDescriptions> in FPD file but contains Dynamic type "+
- "PCD entry %s in module %s!",
- token.cName,
- moduleName);
- throw new EntityException(exceptionString);
- }
-
- dynamicPcdBuildDataArray = dynamicPcdBuildDefinitions.getPcdBuildDataList();
- for (index = 0; index < dynamicPcdBuildDataArray.size(); index ++) {
- //String tokenSpaceGuidString = GlobalData.getGuidInfoFromCname(dynamicPcdBuildDataArray.get(index).getTokenSpaceGuidCName())[1];
- String tokenSpaceGuidString = null;
- try {
- tokenSpaceStrRet = GlobalData.getGuidInfoFromCname(dynamicPcdBuildDataArray.get(index).getTokenSpaceGuidCName());
- } catch (Exception e) {
- throw new EntityException ("Fail to get token space guid for token " + dynamicPcdBuildDataArray.get(index).getCName());
- }
-
- if (tokenSpaceStrRet == null) {
- throw new EntityException ("Fail to get token space guid for token " + dynamicPcdBuildDataArray.get(index).getCName());
- }
-
- dynamicPrimaryKey = Token.getPrimaryKeyString(dynamicPcdBuildDataArray.get(index).getCName(),
- tokenSpaceStrRet[1]);
- if (dynamicPrimaryKey.equalsIgnoreCase(token.getPrimaryKeyString())) {
- return dynamicPcdBuildDataArray.get(index);
- }
- }
-
- return null;
- }
-
- /**
- Update dynamic information for PCD entry.
-
- Dynamic information is retrieved from <PcdDynamicBuildDeclarations> in
- FPD file.
-
- @param moduleName The name of the module who use this PCD
- @param token The token instance
- @param datum The <datum> in module's PCD information
- @param maxDatumSize The <maxDatumSize> in module's PCD information
-
- @return Token
- */
- private Token updateDynamicInformation(String moduleName,
- Token token,
- String datum,
- int maxDatumSize)
- throws EntityException {
- int index = 0;
- int offset;
- String exceptionString = null;
- DynamicTokenValue dynamicValue;
- SkuInstance skuInstance = null;
- String temp;
- boolean hasSkuId0 = false;
- Token.PCD_TYPE pcdType = Token.PCD_TYPE.UNKNOWN;
- long tokenNumber = 0;
- String hiiDefaultValue = null;
- String[] variableGuidString = null;
-
- List<DynamicPcdBuildDefinitions.PcdBuildData.SkuInfo> skuInfoList = null;
- DynamicPcdBuildDefinitions.PcdBuildData dynamicInfo = null;
-
- dynamicInfo = getDynamicInfoFromFPD(token, moduleName);
- if (dynamicInfo == null) {
- exceptionString = String.format("[FPD file error] For Dynamic PCD %s used by module %s, "+
- "there is no dynamic information in <DynamicPcdBuildDefinitions> "+
- "in FPD file, but it is required!",
- token.cName,
- moduleName);
- throw new EntityException(exceptionString);
- }
-
- token.datumSize = dynamicInfo.getMaxDatumSize();
-
- exceptionString = verifyDatum(token.cName,
- moduleName,
- null,
- token.datumType,
- token.datumSize);
- if (exceptionString != null) {
- throw new EntityException(exceptionString);
- }
-
- if ((maxDatumSize != 0) &&
- (maxDatumSize != token.datumSize)) {
- exceptionString = String.format("FPD file error] For dynamic PCD %s, the datum size in module %s is %d, but "+
- "the datum size in <DynamicPcdBuildDefinitions> is %d, they are not match!",
- token.cName,
- moduleName,
- maxDatumSize,
- dynamicInfo.getMaxDatumSize());
- throw new EntityException(exceptionString);
- }
- tokenNumber = Long.decode(dynamicInfo.getToken().toString());
- if (tokenNumber != token.tokenNumber) {
- exceptionString = String.format("[FPD file error] For dynamic PCD %s, the token number in module %s is 0x%x, but"+
- "in <DynamicPcdBuildDefinictions>, the token number is 0x%x, they are not match!",
- token.cName,
- moduleName,
- token.tokenNumber,
- tokenNumber);
- throw new EntityException(exceptionString);
- }
-
- pcdType = Token.getpcdTypeFromString(dynamicInfo.getItemType().toString());
- token.dynamicExTokenNumber = tokenNumber;
-
- skuInfoList = dynamicInfo.getSkuInfoList();
-
- //
- // Loop all sku data
- //
- for (index = 0; index < skuInfoList.size(); index ++) {
- skuInstance = new SkuInstance();
- //
- // Although SkuId in schema is BigInteger, but in fact, sku id is 32 bit value.
- //
- temp = skuInfoList.get(index).getSkuId().toString();
- skuInstance.id = Integer.decode(temp);
- if (skuInstance.id == 0) {
- hasSkuId0 = true;
- }
- //
- // Judge whether is DefaultGroup at first, because most case is DefautlGroup.
- //
- if (skuInfoList.get(index).getValue() != null) {
- skuInstance.value.setValue(skuInfoList.get(index).getValue().toString());
- if ((exceptionString = verifyDatum(token.cName,
- null,
- skuInfoList.get(index).getValue().toString(),
- token.datumType,
- token.datumSize)) != null) {
- throw new EntityException(exceptionString);
- }
-
- token.skuData.add(skuInstance);
-
- //
- // Judege wether is same of datum between module's information
- // and dynamic information.
- //
- if (datum != null) {
- if ((skuInstance.id == 0) &&
- !datum.toString().equalsIgnoreCase(skuInfoList.get(index).getValue().toString())) {
- exceptionString = "[FPD file error] For dynamic PCD " + token.cName + ", the value in module " + moduleName + " is " + datum.toString() + " but the "+
- "value of sku 0 data in <DynamicPcdBuildDefinition> is " + skuInstance.value.value + ". They are must be same!"+
- " or you could not define value for a dynamic PCD in every <ModuleSA>!";
- throw new EntityException(exceptionString);
- }
- }
- continue;
- }
-
- //
- // Judge whether is HII group case.
- //
- if (skuInfoList.get(index).getVariableName() != null) {
- exceptionString = null;
- if (skuInfoList.get(index).getVariableGuid() == null) {
- exceptionString = String.format("[FPD file error] For dynamic PCD %s in <DynamicPcdBuildDefinitions> section in FPD "+
- "file, who use HII, but there is no <VariableGuid> defined for Sku %d data!",
- token.cName,
- index);
- if (exceptionString != null) {
- throw new EntityException(exceptionString);
- }
- }
-
- if (skuInfoList.get(index).getVariableOffset() == null) {
- exceptionString = String.format("[FPD file error] For dynamic PCD %s in <DynamicPcdBuildDefinitions> section in FPD "+
- "file, who use HII, but there is no <VariableOffset> defined for Sku %d data!",
- token.cName,
- index);
- if (exceptionString != null) {
- throw new EntityException(exceptionString);
- }
- }
-
- if (skuInfoList.get(index).getHiiDefaultValue() == null) {
- exceptionString = String.format("[FPD file error] For dynamic PCD %s in <DynamicPcdBuildDefinitions> section in FPD "+
- "file, who use HII, but there is no <HiiDefaultValue> defined for Sku %d data!",
- token.cName,
- index);
- if (exceptionString != null) {
- throw new EntityException(exceptionString);
- }
- }
-
- if (skuInfoList.get(index).getHiiDefaultValue() != null) {
- hiiDefaultValue = skuInfoList.get(index).getHiiDefaultValue().toString();
- } else {
- hiiDefaultValue = null;
- }
-
- if ((exceptionString = verifyDatum(token.cName,
- null,
- hiiDefaultValue,
- token.datumType,
- token.datumSize)) != null) {
- throw new EntityException(exceptionString);
- }
-
- offset = Integer.decode(skuInfoList.get(index).getVariableOffset());
- if (offset > 0xFFFF) {
- throw new EntityException(String.format("[FPD file error] For dynamic PCD %s , the variable offset defined in sku %d data "+
- "exceed 64K, it is not allowed!",
- token.cName,
- index));
- }
-
- //
- // Get variable guid string according to the name of guid which will be mapped into a GUID in SPD file.
- //
- variableGuidString = GlobalData.getGuidInfoFromCname(skuInfoList.get(index).getVariableGuid().toString());
- if (variableGuidString == null) {
- throw new EntityException(String.format("[GUID Error] For dynamic PCD %s, the variable guid %s can be found in all SPD file!",
- token.cName,
- skuInfoList.get(index).getVariableGuid().toString()));
- }
- String variableStr = skuInfoList.get(index).getVariableName();
- Pattern pattern = Pattern.compile("0x([a-fA-F0-9]){4}");
- Matcher matcher = pattern.matcher(variableStr);
- List<String> varNameList = new ArrayList<String>();
- while (matcher.find()){
- String str = variableStr.substring(matcher.start(),matcher.end());
- varNameList.add(str);
- }
-
- skuInstance.value.setHiiData(varNameList,
- translateSchemaStringToUUID(variableGuidString[1]),
- skuInfoList.get(index).getVariableOffset(),
- skuInfoList.get(index).getHiiDefaultValue().toString());
- token.skuData.add(skuInstance);
- continue;
- }
-
- if (skuInfoList.get(index).getVpdOffset() != null) {
- skuInstance.value.setVpdData(skuInfoList.get(index).getVpdOffset());
- token.skuData.add(skuInstance);
- continue;
- }
-
- exceptionString = String.format("[FPD file error] For dynamic PCD %s, the dynamic info must "+
- "be one of 'DefaultGroup', 'HIIGroup', 'VpdGroup'.",
- token.cName);
- throw new EntityException(exceptionString);
- }
-
- if (!hasSkuId0) {
- exceptionString = String.format("[FPD file error] For dynamic PCD %s in <DynamicPcdBuildDefinitions>, there are "+
- "no sku id = 0 data, which is required for every dynamic PCD",
- token.cName);
- throw new EntityException(exceptionString);
- }
-
- return token;
- }
-
- /**
- Translate the schema string to UUID instance.
-
- In schema, the string of UUID is defined as following two types string:
- 1) GuidArrayType: pattern = 0x[a-fA-F0-9]{1,8},( )*0x[a-fA-F0-9]{1,4},(
- )*0x[a-fA-F0-9]{1,4}(,( )*\{)?(,?( )*0x[a-fA-F0-9]{1,2}){8}( )*(\})?
-
- 2) GuidNamingConvention: pattern =
- [a-fA-F0-9]{8}-[a-fA-F0-9]{4}-[a-fA-F0-9]{4}-[a-fA-F0-9]{4}-[a-fA-F0-9]{12}
-
- This function will convert string and create uuid instance.
-
- @param uuidString UUID string in XML file
-
- @return UUID UUID instance
- **/
- private UUID translateSchemaStringToUUID(String uuidString)
- throws EntityException {
- String temp;
- String[] splitStringArray;
- int index;
- int chIndex;
- int chLen;
-
- if (uuidString == null) {
- return null;
- }
-
- if (uuidString.length() == 0) {
- return null;
- }
-
- if (uuidString.equals("0") ||
- uuidString.equalsIgnoreCase("0x0")) {
- return new UUID(0, 0);
- }
-
- uuidString = uuidString.replaceAll("\\{", "");
- uuidString = uuidString.replaceAll("\\}", "");
-
- //
- // If the UUID schema string is GuidArrayType type then need translate
- // to GuidNamingConvention type at first.
- //
- if ((uuidString.charAt(0) == '0') && ((uuidString.charAt(1) == 'x') || (uuidString.charAt(1) == 'X'))) {
- splitStringArray = uuidString.split("," );
- if (splitStringArray.length != 11) {
- throw new EntityException ("[FPD file error] Wrong format for UUID string: " + uuidString);
- }
-
- //
- // Remove blank space from these string and remove header string "0x"
- //
- for (index = 0; index < 11; index ++) {
- splitStringArray[index] = splitStringArray[index].trim();
- splitStringArray[index] = splitStringArray[index].substring(2, splitStringArray[index].length());
- }
-
- //
- // Add heading '0' to normalize the string length
- //
- for (index = 3; index < 11; index ++) {
- chLen = splitStringArray[index].length();
- for (chIndex = 0; chIndex < 2 - chLen; chIndex ++) {
- splitStringArray[index] = "0" + splitStringArray[index];
- }
- }
-
- //
- // construct the final GuidNamingConvention string
- //
- temp = String.format("%s-%s-%s-%s%s-%s%s%s%s%s%s",
- splitStringArray[0],
- splitStringArray[1],
- splitStringArray[2],
- splitStringArray[3],
- splitStringArray[4],
- splitStringArray[5],
- splitStringArray[6],
- splitStringArray[7],
- splitStringArray[8],
- splitStringArray[9],
- splitStringArray[10]);
- uuidString = temp;
- }
-
- return UUID.fromString(uuidString);
- }
-
- /**
- check parameter for this action.
-
- @throws EntityException Bad parameter.
- **/
- private void checkParameter() throws EntityException {
- File file = null;
-
- if((fpdFilePath == null) ||(workspacePath == null)) {
- throw new EntityException("WorkspacePath and FPDFileName should be blank for CollectPCDAtion!");
- }
-
- if(fpdFilePath.length() == 0 || workspacePath.length() == 0) {
- throw new EntityException("WorkspacePath and FPDFileName should be blank for CollectPCDAtion!");
- }
-
- file = new File(workspacePath);
- if(!file.exists()) {
- throw new EntityException("WorkpacePath " + workspacePath + " does not exist!");
- }
-
- file = new File(fpdFilePath);
-
- if(!file.exists()) {
- throw new EntityException("FPD File " + fpdFilePath + " does not exist!");
- }
- }
-
- /**
- Test case function
-
- @param argv parameter from command line
- **/
- public static void main(String argv[]) throws EntityException {
- CollectPCDAction ca = new CollectPCDAction();
- String projectDir = "x:/edk2";
- ca.setWorkspacePath(projectDir);
- ca.setFPDFilePath(projectDir + "/EdkNt32Pkg/Nt32.fpd");
- ca.setActionMessageLevel(ActionMessage.MAX_MESSAGE_LEVEL);
- GlobalData.initInfo("Tools" + File.separator + "Conf" + File.separator + "FrameworkDatabase.db",
- projectDir,
- "tools_def.txt");
- System.out.println("After initInfo!");
- FpdParserTask fpt = new FpdParserTask();
- fpt.parseFpdFile(new File(projectDir + "/EdkNt32Pkg/Nt32.fpd"));
- ca.execute();
- }
-}
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 40d2b32a9b..5a429e4117 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.
@@ -19,21 +19,15 @@ package org.tianocore.build.pcd.action; import java.io.File;
import java.util.ArrayList;
import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.UUID;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
-import org.apache.xmlbeans.XmlObject;
import org.tianocore.build.global.GlobalData;
-import org.tianocore.build.global.SurfaceAreaQuery;
import org.tianocore.build.id.ModuleIdentification;
import org.tianocore.pcd.entity.MemoryDatabaseManager;
import org.tianocore.pcd.entity.Token;
import org.tianocore.pcd.entity.UsageInstance;
import org.tianocore.pcd.exception.BuildActionException;
-import org.tianocore.pcd.exception.EntityException;
import org.tianocore.pcd.entity.UsageIdentification;
import org.tianocore.pcd.action.BuildAction;
import org.tianocore.pcd.action.ActionMessage;
@@ -46,33 +40,35 @@ public class PCDAutoGenAction extends BuildAction { /// The reference of DBManager in GlobalData class.
///
private MemoryDatabaseManager dbManager;
+
///
/// The identification for a UsageInstance.
- ///
- private UsageIdentification usageId;
///
- /// The arch of current module
- ///
- private String arch;
+ private UsageIdentification usageId;
+
///
/// Whether current autogen is for building library used by current module.
- ///
+ ///
private boolean isBuildUsedLibrary;
+
///
/// The generated string for header file.
///
private String hAutoGenString;
+
///
/// The generated string for C code file.
///
private String cAutoGenString;
+
///
/// The name array of <PcdCoded> in a module.
- ///
+ ///
private String[] pcdNameArrayInMsa;
+
/**
Set parameter moduleId
-
+
@param moduleName the module name parameter.
**/
public void setUsageId(UsageIdentification usageId) {
@@ -81,7 +77,7 @@ public class PCDAutoGenAction extends BuildAction { /**
set isBuildUsedLibrary parameter.
-
+
@param isBuildUsedLibrary
**/
public void setIsBuildUsedLibrary(boolean isBuildUsedLibrary) {
@@ -90,7 +86,7 @@ public class PCDAutoGenAction extends BuildAction { /**
set pcdNameArrayInMsa parameter.
-
+
@param pcdNameArrayInMsa
*/
public void setPcdNameArrayInMsa(String[] pcdNameArrayInMsa) {
@@ -99,7 +95,7 @@ public class PCDAutoGenAction extends BuildAction { /**
Get the output of generated string for header file.
-
+
@return the string of header file for PCD
**/
public String OutputH() {
@@ -108,65 +104,63 @@ public class PCDAutoGenAction extends BuildAction { /**
Get the output of generated string for C Code file.
-
+
@return the string of C code file for PCD
**/
public String OutputC() {
return cAutoGenString;
}
-
+
/**
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.
**/
- public PCDAutoGenAction(ModuleIdentification moduleId,
+ public PCDAutoGenAction(ModuleIdentification moduleId,
String arch,
boolean isBuildUsedLibrary,
String[] pcdNameArrayInMsa) {
- UsageIdentification usageId = new UsageIdentification(moduleId.getName(),
- moduleId.getGuid(),
- moduleId.getPackage().getName(),
- moduleId.getPackage().getGuid(),
- arch,
- moduleId.getVersion(),
- moduleId.getModuleType());
dbManager = null;
hAutoGenString = "";
cAutoGenString = "";
- setUsageId(usageId);
+ setUsageId(new UsageIdentification(moduleId.getName(),
+ moduleId.getGuid(),
+ moduleId.getPackage().getName(),
+ moduleId.getPackage().getGuid(),
+ arch,
+ moduleId.getVersion(),
+ moduleId.getModuleType()));
setIsBuildUsedLibrary(isBuildUsedLibrary);
setPcdNameArrayInMsa(pcdNameArrayInMsa);
}
/**
check the parameter for action class.
-
+
@throws BuildActionException Bad parameter.
**/
- public void checkParameter() throws BuildActionException {
-
+ 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.
**/
- public 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.
@@ -189,7 +183,7 @@ public class PCDAutoGenAction extends BuildAction { /**
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.
**/
@@ -207,23 +201,23 @@ public class PCDAutoGenAction extends BuildAction { usageInstanceArray = null;
if (!isBuildUsedLibrary) {
usageInstanceArray = dbManager.getUsageInstanceArrayByModuleName(usageId);
- dbManager.UsageInstanceContext = usageInstanceArray;
- dbManager.CurrentModuleName = moduleName;
+ MemoryDatabaseManager.UsageInstanceContext = usageInstanceArray;
+ MemoryDatabaseManager.CurrentModuleName = moduleName;
} else if ((pcdNameArrayInMsa != null) && (pcdNameArrayInMsa.length > 0)) {
- usageContext = dbManager.UsageInstanceContext;
+ usageContext = MemoryDatabaseManager.UsageInstanceContext;
//
- // For building library 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 (usageContext == null) {
usageInstanceArray = dbManager.getUsageInstanceArrayByModuleName(usageId);
} else {
usageInstanceArray = new ArrayList<UsageInstance>();
//
- // Try to find all PCD defined in library's PCD in all <PcdEntry> in module's
+ // Try to find all PCD defined in library's PCD in all <PcdEntry> in module's
// <ModuleSA> in FPD file.
- //
+ //
for (index = 0; index < pcdNameArrayInMsa.length; index++) {
found = false;
for (index2 = 0; index2 < usageContext.size(); index2 ++) {
@@ -238,14 +232,14 @@ public class PCDAutoGenAction extends BuildAction { //
// All library's PCD should instanted in module's <ModuleSA> who
// use this library instance. If not, give errors.
- //
+ //
throw new BuildActionException (String.format("[PCD Autogen Error] Module %s use library instance %s, the PCD %s " +
"is required by this library instance, but can not find " +
"it in the %s's <ModuleSA> in FPD file!",
- dbManager.CurrentModuleName,
+ MemoryDatabaseManager.CurrentModuleName,
moduleName,
pcdNameArrayInMsa[index],
- dbManager.CurrentModuleName
+ MemoryDatabaseManager.CurrentModuleName
));
}
}
@@ -258,18 +252,18 @@ public class PCDAutoGenAction extends BuildAction { //
// Generate all PCD entry for a module.
- //
+ //
for(index = 0; index < usageInstanceArray.size(); index ++) {
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
+ // 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_" +
+ 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],
@@ -283,22 +277,21 @@ public class PCDAutoGenAction extends BuildAction { (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);
+ 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);
- }
+ }
}
}
@@ -306,21 +299,21 @@ public class PCDAutoGenAction extends BuildAction { //
// For every PCD entry for this module(usage instance), autogen string would
// be appand.
- //
+ //
hAutoGenString += usageInstance.getHAutogenStr() + "\r\n";
cAutoGenString += usageInstance.getCAutogenStr();
}
//
- // Work around code, In furture following code should be modified that get
+ // 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;
+ hAutoGenString += MemoryDatabaseManager.PcdPeimHString;
+ cAutoGenString += MemoryDatabaseManager.PcdPeimCString;
} else if (moduleName.equalsIgnoreCase("PcdDxe")) {
- hAutoGenString += dbManager.PcdDxeHString;
- cAutoGenString += dbManager.PcdDxeCString;
+ hAutoGenString += MemoryDatabaseManager.PcdDxeHString;
+ cAutoGenString += MemoryDatabaseManager.PcdDxeCString;
}
}
@@ -333,18 +326,17 @@ public class PCDAutoGenAction extends BuildAction { String WorkSpace = "X:/edk2";
String logFilePath = WorkSpace + "/EdkNt32Pkg/Nt32.fpd";
- String[] nameArray = null;
//
// At first, CollectPCDAction should be invoked to collect
// all PCD information from SPD, MSA, FPD.
//
- CollectPCDAction collectionAction = new CollectPCDAction();
+ PlatformPcdPreprocessActionForBuilding collectionAction = new PlatformPcdPreprocessActionForBuilding();
GlobalData.initInfo("Tools" + File.separator + "Conf" + File.separator + "FrameworkDatabase.db",
WorkSpace,null);
try {
- collectionAction.perform(WorkSpace,
+ collectionAction.perform(WorkSpace,
logFilePath,
ActionMessage.MAX_MESSAGE_LEVEL);
} catch(Exception e) {
diff --git a/Tools/Source/GenBuild/org/tianocore/build/pcd/action/PcdDatabase.java b/Tools/Source/GenBuild/org/tianocore/build/pcd/action/PcdDatabase.java index 9a8699cfe4..a42ef927ad 100644 --- a/Tools/Source/GenBuild/org/tianocore/build/pcd/action/PcdDatabase.java +++ b/Tools/Source/GenBuild/org/tianocore/build/pcd/action/PcdDatabase.java @@ -6,56 +6,32 @@ 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.
**/
package org.tianocore.build.pcd.action;
-import java.io.BufferedReader;
+import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
-import java.io.IOException;
-import java.math.BigInteger;
import java.util.ArrayList;
import java.util.Comparator;
import java.util.HashMap;
-import java.util.Iterator;
import java.util.List;
import java.util.Map;
-import java.util.Set;
import java.util.UUID;
-import java.util.regex.Matcher;
-import java.util.regex.Pattern;
-
-import org.apache.xmlbeans.XmlException;
-import org.apache.xmlbeans.XmlObject;
-import org.tianocore.DynamicPcdBuildDefinitionsDocument.DynamicPcdBuildDefinitions;
-import org.tianocore.FrameworkModulesDocument;
-import org.tianocore.ModuleSADocument;
-import org.tianocore.PcdBuildDefinitionDocument;
-import org.tianocore.PcdBuildDefinitionDocument.PcdBuildDefinition;
-import org.tianocore.PlatformSurfaceAreaDocument;
-import org.tianocore.build.fpd.FpdParserTask;
import org.tianocore.build.global.GlobalData;
-import org.tianocore.build.id.FpdModuleIdentification;
-import org.tianocore.build.id.ModuleIdentification;
-import org.tianocore.pcd.action.ActionMessage;
-import org.tianocore.pcd.entity.CommonDefinition;
import org.tianocore.pcd.entity.DynamicTokenValue;
-import org.tianocore.pcd.entity.MemoryDatabaseManager;
-import org.tianocore.pcd.entity.SkuInstance;
import org.tianocore.pcd.entity.Token;
-import org.tianocore.pcd.entity.UsageIdentification;
-import org.tianocore.pcd.entity.UsageInstance;
import org.tianocore.pcd.exception.EntityException;
/**
- CStructTypeDeclaration
-
+ CStructTypeDeclaration
+
This class is used to store the declaration string, such as
- "UINT32 PcdPlatformFlashBaseAddress", of
+ "UINT32 PcdPlatformFlashBaseAddress", of
each memember in the C structure, which is a standard C language
feature used to implement a simple and efficient database for
dynamic(ex) type PCD entry.
@@ -65,7 +41,7 @@ class CStructTypeDeclaration { int alignmentSize;
String cCode;
boolean initTable;
-
+
public CStructTypeDeclaration (String key, int alignmentSize, String cCode, boolean initTable) {
this.key = key;
this.alignmentSize = alignmentSize;
@@ -75,16 +51,16 @@ class CStructTypeDeclaration { }
/**
- StringTable
-
+ StringTable
+
This class is used to store the String in a PCD database.
-
+
**/
class StringTable {
- private ArrayList<String> al;
+ private ArrayList<String> al;
private ArrayList<String> alComments;
private String phase;
- int len;
+ int len;
public StringTable (String phase) {
this.phase = phase;
@@ -107,13 +83,13 @@ class StringTable { public String getExistanceMacro () {
return String.format(PcdDatabase.StringTableExistenceMacro, phase, (al.size() == 0)? "TRUE":"FALSE");
}
-
+
public void genCode (ArrayList<CStructTypeDeclaration> declaList, HashMap<String, String> instTable) {
final String stringTable = "StringTable";
final String tab = "\t";
final String newLine = "\r\n";
final String commaNewLine = ",\r\n";
-
+
CStructTypeDeclaration decl;
String cDeclCode = "";
@@ -123,13 +99,13 @@ class StringTable { // If we have a empty StringTable
//
if (al.size() == 0) {
- cDeclCode += String.format("%-20s%s[1]; /* StringTable is empty */", "UINT16", stringTable) + newLine;
+ cDeclCode += String.format("%-20s%s[1]; /* StringTable is empty */", "UINT16", stringTable) + newLine;
decl = new CStructTypeDeclaration (
stringTable,
2,
cDeclCode,
true
- );
+ );
declaList.add(decl);
cInstCode = String.format("/* %s */", stringTable) + newLine + tab + "{ 0 }";
@@ -142,40 +118,40 @@ class StringTable { for (int i = 0; i < al.size(); i++) {
String str = al.get(i);
String stringTableName;
-
+
if (i == 0) {
//
// StringTable is a well-known name in the PCD DXE driver
//
stringTableName = stringTable;
-
+
} else {
stringTableName = String.format("%s_%d", stringTable, i);
cDeclCode += tab;
}
- cDeclCode += String.format("%-20s%s[%d]; /* %s */", "UINT16",
- stringTableName, str.length() + 1,
- alComments.get(i))
+ cDeclCode += String.format("%-20s%s[%d]; /* %s */", "UINT16",
+ stringTableName, str.length() + 1,
+ alComments.get(i))
+ newLine;
-
+
if (i == 0) {
cInstCode = "/* StringTable */" + newLine;
}
-
+
cInstCode += tab + String.format("L\"%s\" /* %s */", al.get(i), alComments.get(i));
if (i != al.size() - 1) {
cInstCode += commaNewLine;
}
}
-
+
decl = new CStructTypeDeclaration (
stringTable,
2,
cDeclCode,
true
- );
+ );
declaList.add(decl);
-
+
instTable.put(stringTable, cInstCode);
}
}
@@ -185,11 +161,11 @@ class StringTable { int pos;
String str = inputStr;
-
+
//
// The input can be two types:
- // "L\"Bootmode\"" or "Bootmode".
- // We drop the L\" and \" for the first type.
+ // "L\"Bootmode\"" or "Bootmode".
+ // We drop the L\" and \" for the first type.
if (str.startsWith("L\"") && str.endsWith("\"")) {
str = str.substring(2, str.length() - 1);
}
@@ -205,12 +181,12 @@ class StringTable { }
pos = s.length() + 1;
}
-
+
i = len;
//
// Include the NULL character at the end of String
//
- len += str.length() + 1;
+ len += str.length() + 1;
al.add(str);
alComments.add(token.getPrimaryKeyString());
@@ -219,8 +195,8 @@ class StringTable { }
/**
- SizeTable
-
+ SizeTable
+
This class is used to store the Size information for
POINTER TYPE PCD entry in a PCD database.
@@ -230,7 +206,7 @@ class SizeTable { private ArrayList<String> alComments;
private int len;
private String phase;
-
+
public SizeTable (String phase) {
al = new ArrayList<ArrayList<Integer>>();
alComments = new ArrayList<String>();
@@ -241,24 +217,24 @@ class SizeTable { public String getSizeMacro () {
return String.format(PcdDatabase.SizeTableSizeMacro, phase, getSize());
}
-
+
private int getSize() {
return len == 0 ? 1 : len;
}
public void genCode (ArrayList<CStructTypeDeclaration> declaList, HashMap<String, String> instTable, String phase) {
final String name = "SizeTable";
-
+
CStructTypeDeclaration decl;
String cCode;
- cCode = String.format(PcdDatabase.SizeTableDeclaration, phase);
+ cCode = String.format(PcdDatabase.SizeTableDeclaration, phase);
decl = new CStructTypeDeclaration (
name,
2,
cCode,
true
- );
+ );
declaList.add(decl);
@@ -277,9 +253,9 @@ class SizeTable { } else {
for (int index = 0; index < al.size(); index++) {
ArrayList<Integer> ial = al.get(index);
-
+
String str = "\t";
-
+
for (int index2 = 0; index2 < ial.size(); index2++) {
str += " " + ial.get(index2).toString();
if (index2 != ial.size() - 1) {
@@ -287,14 +263,14 @@ class SizeTable { }
}
- str += " /* " + alComments.get(index) + " */";
-
+ str += " /* " + alComments.get(index) + " */";
+
if (index != (al.size() - 1)) {
str += comma;
}
Output.add(str);
-
+
}
}
Output.add("}");
@@ -310,22 +286,22 @@ class SizeTable { if (token.datumType != Token.DATUM_TYPE.POINTER) {
return;
}
-
+
ArrayList<Integer> ial = token.getPointerTypeSize();
-
- len+= ial.size();
+
+ len+= ial.size();
al.add(ial);
alComments.add(token.getPrimaryKeyString());
return;
}
-
+
}
/**
- GuidTable
-
+ GuidTable
+
This class is used to store the GUIDs in a PCD database.
**/
class GuidTable {
@@ -357,17 +333,17 @@ class GuidTable { public void genCode (ArrayList<CStructTypeDeclaration> declaList, HashMap<String, String> instTable, String phase) {
final String name = "GuidTable";
-
+
CStructTypeDeclaration decl;
String cCode = "";
- cCode += String.format(PcdDatabase.GuidTableDeclaration, phase);
+ cCode += String.format(PcdDatabase.GuidTableDeclaration, phase);
decl = new CStructTypeDeclaration (
name,
4,
cCode,
true
- );
+ );
declaList.add(decl);
@@ -404,7 +380,7 @@ class GuidTable { if (al.size() == 0) {
Output.add("\t" + getUuidCString(new UUID(0, 0)));
}
-
+
for (int i = 0; i < al.size(); i++) {
String str = "\t" + getUuidCString(al.get(i));
@@ -431,8 +407,8 @@ class GuidTable { return i;
}
}
-
- len++;
+
+ len++;
al.add(uuid);
alComments.add(name);
@@ -445,8 +421,8 @@ class GuidTable { }
/**
- SkuIdTable
-
+ SkuIdTable
+
This class is used to store the SKU IDs in a PCD database.
**/
@@ -477,17 +453,17 @@ class SkuIdTable { public void genCode (ArrayList<CStructTypeDeclaration> declaList, HashMap<String, String> instTable, String phase) {
final String name = "SkuIdTable";
-
+
CStructTypeDeclaration decl;
String cCode = "";
- cCode += String.format(PcdDatabase.SkuIdTableDeclaration, phase);
+ cCode += String.format(PcdDatabase.SkuIdTableDeclaration, phase);
decl = new CStructTypeDeclaration (
name,
1,
cCode,
true
- );
+ );
declaList.add(decl);
@@ -505,7 +481,7 @@ class SkuIdTable { true
);
declaList.add(decl);
-
+
instTable.put("SystemSkuId", "0");
}
@@ -520,7 +496,7 @@ class SkuIdTable { if (al.size() == 0) {
Output.add("\t0");
}
-
+
for (int index = 0; index < al.size(); index++) {
String str;
@@ -551,7 +527,7 @@ class SkuIdTable { int index;
int pos;
-
+
//
// Check if this SKU_ID Array is already in the table
//
@@ -584,7 +560,7 @@ class SkuIdTable { index = len;
- len += skuIds.length;
+ len += skuIds.length;
al.add(skuIds);
alComment.add(token.getPrimaryKeyString());
@@ -622,17 +598,17 @@ class LocalTokenNumberTable { public void genCode (ArrayList<CStructTypeDeclaration> declaList, HashMap<String, String> instTable, String phase) {
final String name = "LocalTokenNumberTable";
-
+
CStructTypeDeclaration decl;
String cCode = "";
- cCode += String.format(PcdDatabase.LocalTokenNumberTableDeclaration, phase);
+ cCode += String.format(PcdDatabase.LocalTokenNumberTableDeclaration, phase);
decl = new CStructTypeDeclaration (
name,
4,
cCode,
true
- );
+ );
declaList.add(decl);
cCode = PcdDatabase.genInstantiationStr(getInstantiation());
@@ -648,7 +624,7 @@ class LocalTokenNumberTable { if (al.size() == 0) {
output.add("\t0");
}
-
+
for (int index = 0; index < al.size(); index++) {
String str;
@@ -674,7 +650,7 @@ class LocalTokenNumberTable { int index = len;
String str;
- len++;
+ len++;
str = String.format(PcdDatabase.offsetOfStrTemplate, phase, token.hasDefaultValue() ? "Init" : "Uninit", token.getPrimaryKeyString());
@@ -693,7 +669,7 @@ class LocalTokenNumberTable { if (token.getDefaultSku().type == DynamicTokenValue.VALUE_TYPE.VPD_TYPE) {
str += " | PCD_TYPE_VPD";
}
-
+
switch (token.datumType) {
case UINT8:
case BOOLEAN:
@@ -712,7 +688,7 @@ class LocalTokenNumberTable { str += " | PCD_DATUM_TYPE_POINTER";
break;
}
-
+
al.add(str);
alComment.add(token.getPrimaryKeyString());
@@ -721,8 +697,8 @@ class LocalTokenNumberTable { }
/**
- ExMapTable
-
+ ExMapTable
+
This class is used to store the table of mapping information
between DynamicEX ID pair(Guid, TokenNumber) and
the local token number assigned by PcdDatabase class.
@@ -730,8 +706,8 @@ class LocalTokenNumberTable { class ExMapTable {
/**
- ExTriplet
-
+ ExTriplet
+
This class is used to store the mapping information
between DynamicEX ID pair(Guid, TokenNumber) and
the local token number assigned by PcdDatabase class.
@@ -740,7 +716,7 @@ class ExMapTable { public Integer guidTableIdx;
public Long exTokenNumber;
public Long localTokenIdx;
-
+
public ExTriplet (int guidTableIdx, long exTokenNumber, long localTokenIdx) {
this.guidTableIdx = new Integer(guidTableIdx);
this.exTokenNumber = new Long(exTokenNumber);
@@ -753,7 +729,7 @@ class ExMapTable { private String phase;
private int len;
private int bodyLineNum;
-
+
public ExMapTable (String phase) {
this.phase = phase;
al = new ArrayList<ExTriplet>();
@@ -773,26 +749,26 @@ class ExMapTable { public void genCode (ArrayList<CStructTypeDeclaration> declaList, HashMap<String, String> instTable, String phase) {
final String exMapTableName = "ExMapTable";
-
+
sortTable();
-
+
CStructTypeDeclaration decl;
String cCode = "";
- cCode += String.format(PcdDatabase.ExMapTableDeclaration, phase);
+ cCode += String.format(PcdDatabase.ExMapTableDeclaration, phase);
decl = new CStructTypeDeclaration (
exMapTableName,
4,
cCode,
true
- );
+ );
declaList.add(decl);
cCode = PcdDatabase.genInstantiationStr(getInstantiation());
instTable.put(exMapTableName, cCode);
}
-
+
private ArrayList<String> getInstantiation () {
ArrayList<String> Output = new ArrayList<String>();
@@ -801,7 +777,7 @@ class ExMapTable { if (al.size() == 0) {
Output.add("\t{0, 0, 0}");
}
-
+
int index;
for (index = 0; index < al.size(); index++) {
String str;
@@ -832,7 +808,7 @@ class ExMapTable { int index = len;
len++;
- ExTriplet et = new ExTriplet(guidTableIdx, exTokenNum, localTokenIdx);
+ ExTriplet et = new ExTriplet(guidTableIdx, exTokenNum, localTokenIdx);
al.add(et);
alComment.put(et, name);
@@ -850,7 +826,7 @@ class ExMapTable { // following order:
// 1) ExGuid
// 2) ExTokenNumber
- //
+ //
class ExTripletComp implements Comparator<ExTriplet> {
public int compare (ExTriplet a, ExTriplet b) {
if (a.guidTableIdx == b.guidTableIdx ) {
@@ -865,7 +841,7 @@ class ExMapTable { return -1;
}
}
-
+
return a.guidTableIdx - b.guidTableIdx;
}
}
@@ -877,8 +853,8 @@ class ExMapTable { }
/**
- PcdDatabase
-
+ PcdDatabase
+
This class is used to generate C code for Autogen.h and Autogen.c of
a PCD service DXE driver and PCD service PEIM.
**/
@@ -898,7 +874,7 @@ public class PcdDatabase { public final static String ExMapTableSizeMacro = "#define %s_EXMAPPING_TABLE_SIZE %d\r\n";
public final static String ExTokenNumber = "#define %s_EX_TOKEN_NUMBER %d\r\n";
- public final static String GuidTableSizeMacro = "#define %s_GUID_TABLE_SIZE %d\r\n";
+ public final static String GuidTableSizeMacro = "#define %s_GUID_TABLE_SIZE %d\r\n";
public final static String LocalTokenNumberTableSizeMacro = "#define %s_LOCAL_TOKEN_NUMBER_TABLE_SIZE %d\r\n";
public final static String LocalTokenNumberSizeMacro = "#define %s_LOCAL_TOKEN_NUMBER %d\r\n";
public final static String SizeTableSizeMacro = "#define %s_SIZE_TABLE_SIZE %d\r\n";
@@ -906,7 +882,7 @@ public class PcdDatabase { public final static String SkuIdTableSizeMacro = "#define %s_SKUID_TABLE_SIZE %d\r\n";
- public final static String ExMapTableExistenceMacro = "#define %s_EXMAP_TABLE_EMPTY %s\r\n";
+ public final static String ExMapTableExistenceMacro = "#define %s_EXMAP_TABLE_EMPTY %s\r\n";
public final static String GuidTableExistenceMacro = "#define %s_GUID_TABLE_EMPTY %s\r\n";
public final static String DatabaseExistenceMacro = "#define %s_DATABASE_EMPTY %s\r\n";
public final static String StringTableExistenceMacro = "#define %s_STRING_TABLE_EMPTY %s\r\n";
@@ -915,7 +891,7 @@ public class PcdDatabase { public final static String offsetOfSkuHeadStrTemplate = "offsetof(%s_PCD_DATABASE, %s.%s_SkuDataTable)";
public final static String offsetOfVariableEnabledDefault = "offsetof(%s_PCD_DATABASE, %s.%s_VariableDefault_%d)";
public final static String offsetOfStrTemplate = "offsetof(%s_PCD_DATABASE, %s.%s)";
-
+
private final static String skuDataTableTemplate = "SkuDataTable";
@@ -929,10 +905,10 @@ public class PcdDatabase { private ArrayList<Token> alTokens;
private String phase;
private int assignedTokenNumber;
-
+
//
// Use two class global variable to store
- // temperary
+ // temperary
//
private String privateGlobalName;
private String privateGlobalCCode;
@@ -949,11 +925,11 @@ public class PcdDatabase { private String cString;
/**
- Constructor for PcdDatabase class.
-
+ Constructor for PcdDatabase class.
+
<p>We have two PCD dynamic(ex) database for the Framework implementation. One
for PEI phase and the other for DXE phase. </p>
-
+
@param alTokens A ArrayList of Dynamic(EX) PCD entry.
@param exePhase The phase to generate PCD database for: valid input
is "PEI" or "DXE".
@@ -971,11 +947,11 @@ public class PcdDatabase { localTokenNumberTable = new LocalTokenNumberTable(phase);
skuIdTable = new SkuIdTable(phase);
sizeTable = new SizeTable(phase);
- exMapTable = new ExMapTable(phase);
+ exMapTable = new ExMapTable(phase);
//
// Local token number 0 is reserved for INVALID_TOKEN_NUMBER.
- // So we will increment 1 for the startLen passed from the
+ // So we will increment 1 for the startLen passed from the
// constructor.
//
assignedTokenNumber = startLen + 1;
@@ -1013,7 +989,7 @@ public class PcdDatabase { return 1;
}
}
-
+
private int getHiiPtrTypeAlignmentSize(Token token) {
switch (token.datumType) {
case UINT8:
@@ -1037,7 +1013,7 @@ public class PcdDatabase { return 1;
}
}
-
+
private int getAlignmentSize (Token token) {
if (token.getDefaultSku().type == DynamicTokenValue.VALUE_TYPE.HII_TYPE) {
return 2;
@@ -1050,7 +1026,7 @@ public class PcdDatabase { if (token.isUnicodeStringType()) {
return 2;
}
-
+
return getDataTypeAlignmentSize(token);
}
@@ -1061,7 +1037,7 @@ public class PcdDatabase { public String getHString () {
return hString;
}
-
+
private void genCodeWorker(Token t,
ArrayList<CStructTypeDeclaration> declaList,
HashMap<String, String> instTable, String phase)
@@ -1092,48 +1068,48 @@ public class PcdDatabase { declaList.add(decl);
if (t.hasDefaultValue()) {
- instTable.put(privateGlobalName,
+ instTable.put(privateGlobalName,
getTypeInstantiation(t, declaList, instTable, phase)
);
}
}
- private void ProcessTokens (List<Token> tokens,
+ private void ProcessTokens (List<Token> tokens,
ArrayList<CStructTypeDeclaration> cStructDeclList,
HashMap<String, String> cStructInstTable,
String phase
- )
+ )
throws EntityException {
-
+
for (int idx = 0; idx < tokens.size(); idx++) {
Token t = tokens.get(idx);
-
+
genCodeWorker (t, cStructDeclList, cStructInstTable, phase);
-
+
sizeTable.add(t);
localTokenNumberTable.add(t);
t.tokenNumber = assignedTokenNumber++;
-
+
//
// Add a mapping if this dynamic PCD entry is a EX type
//
if (t.isDynamicEx()) {
- exMapTable.add((int)t.tokenNumber,
- t.dynamicExTokenNumber,
- guidTable.add(translateSchemaStringToUUID(t.tokenSpaceName), t.getPrimaryKeyString()),
+ exMapTable.add((int)t.tokenNumber,
+ t.dynamicExTokenNumber,
+ guidTable.add(translateSchemaStringToUUID(t.tokenSpaceName), t.getPrimaryKeyString()),
t.getPrimaryKeyString()
);
}
}
}
-
+
public void genCode () throws EntityException {
-
+
ArrayList<CStructTypeDeclaration> cStructDeclList = new ArrayList<CStructTypeDeclaration>();
HashMap<String, String> cStructInstTable = new HashMap<String, String>();
-
+
List<Token> nexTokens = new ArrayList<Token> ();
List<Token> exTokens = new ArrayList<Token> ();
@@ -1141,40 +1117,40 @@ public class PcdDatabase { //
// We have to process Non-Ex type PCD entry first. The reason is
- // that our optimization assumes that the Token Number of Non-Ex
+ // that our optimization assumes that the Token Number of Non-Ex
// PCD entry start from 1 (for PEI phase) and grows continously upwards.
- //
+ //
// EX type token number starts from the last Non-EX PCD entry and
// grows continously upwards.
//
ProcessTokens (nexTokens, cStructDeclList, cStructInstTable, phase);
ProcessTokens (exTokens, cStructDeclList, cStructInstTable, phase);
-
+
stringTable.genCode(cStructDeclList, cStructInstTable);
skuIdTable.genCode(cStructDeclList, cStructInstTable, phase);
exMapTable.genCode(cStructDeclList, cStructInstTable, phase);
localTokenNumberTable.genCode(cStructDeclList, cStructInstTable, phase);
sizeTable.genCode(cStructDeclList, cStructInstTable, phase);
guidTable.genCode(cStructDeclList, cStructInstTable, phase);
-
+
hString = genCMacroCode ();
-
+
HashMap <String, String> result;
-
- result = genCStructCode(cStructDeclList,
- cStructInstTable,
+
+ result = genCStructCode(cStructDeclList,
+ cStructInstTable,
phase
);
-
+
hString += result.get("initDeclStr");
hString += result.get("uninitDeclStr");
-
+
hString += String.format("#define PCD_%s_SERVICE_DRIVER_VERSION %d", phase, version);
-
+
cString = newLine + newLine + result.get("initInstStr");
-
+
}
-
+
private String genCMacroCode () {
String macroStr = "";
@@ -1198,22 +1174,22 @@ public class PcdDatabase { macroStr += exMapTable.getExistanceMacro();
macroStr += newLine;
-
+
return macroStr;
}
-
+
private HashMap <String, String> genCStructCode(
- ArrayList<CStructTypeDeclaration> declaList,
- HashMap<String, String> instTable,
+ ArrayList<CStructTypeDeclaration> declaList,
+ HashMap<String, String> instTable,
String phase
) {
-
+
int i;
HashMap <String, String> result = new HashMap<String, String>();
HashMap <Integer, ArrayList<String>> alignmentInitDecl = new HashMap<Integer, ArrayList<String>>();
HashMap <Integer, ArrayList<String>> alignmentUninitDecl = new HashMap<Integer, ArrayList<String>>();
HashMap <Integer, ArrayList<String>> alignmentInitInst = new HashMap<Integer, ArrayList<String>>();
-
+
//
// Initialize the storage for each alignment
//
@@ -1222,17 +1198,17 @@ public class PcdDatabase { alignmentInitInst.put(new Integer(i), new ArrayList<String>());
alignmentUninitDecl.put(new Integer(i), new ArrayList<String>());
}
-
+
String initDeclStr = "typedef struct {" + newLine;
String initInstStr = String.format("%s_PCD_DATABASE_INIT g%sPcdDbInit = { ", phase.toUpperCase(), phase.toUpperCase()) + newLine;
String uninitDeclStr = "typedef struct {" + newLine;
//
- // Sort all C declaration and instantiation base on Alignment Size
+ // Sort all C declaration and instantiation base on Alignment Size
//
for (Object d : declaList) {
CStructTypeDeclaration decl = (CStructTypeDeclaration) d;
-
+
if (decl.initTable) {
alignmentInitDecl.get(new Integer(decl.alignmentSize)).add(decl.cCode);
alignmentInitInst.get(new Integer(decl.alignmentSize)).add(instTable.get(decl.key));
@@ -1251,7 +1227,7 @@ public class PcdDatabase { for (i = 0; i < declaListBasedOnAlignment.size(); i++) {
initDeclStr += tab + declaListBasedOnAlignment.get(i);
initInstStr += tab + instListBasedOnAlignment.get(i);
-
+
//
// We made a assumption that both PEI_PCD_DATABASE and DXE_PCD_DATABASE
// has a least one data memember with alignment size of 1. So we can
@@ -1264,27 +1240,27 @@ public class PcdDatabase { initInstStr += commaNewLine;
}
}
-
+
declaListBasedOnAlignment = alignmentUninitDecl.get(new Integer(align));
-
+
if (declaListBasedOnAlignment.size() != 0) {
uinitDatabaseEmpty = false;
}
-
+
for (Object d : declaListBasedOnAlignment) {
String s = (String)d;
uninitDeclStr += tab + s;
}
}
-
+
if (uinitDatabaseEmpty) {
uninitDeclStr += tab + String.format("%-20sdummy; /* PCD_DATABASE_UNINIT is emptry */\r\n", "UINT8");
}
-
+
initDeclStr += String.format("} %s_PCD_DATABASE_INIT;", phase) + newLine + newLine;
initInstStr += "};" + newLine;
uninitDeclStr += String.format("} %s_PCD_DATABASE_UNINIT;", phase) + newLine + newLine;
-
+
result.put("initDeclStr", initDeclStr);
result.put("initInstStr", initInstStr);
result.put("uninitDeclStr", uninitDeclStr);
@@ -1321,21 +1297,21 @@ public class PcdDatabase { return String.format("%s /* %s */", token.skuData.get(skuId).value.hiiDefaultValue, cName);
}
- private String getCType (Token t)
+ private String getCType (Token t)
throws EntityException {
-
+
if (t.isHiiEnable()) {
return "VARIABLE_HEAD";
}
-
+
if (t.isVpdEnable()) {
return "VPD_HEAD";
}
-
+
if (t.isUnicodeStringType()) {
return "STRING_HEAD";
}
-
+
switch (t.datumType) {
case UINT64:
return "UINT64";
@@ -1353,13 +1329,13 @@ public class PcdDatabase { throw new EntityException("Unknown type in getDataTypeCDeclaration");
}
}
-
+
//
// privateGlobalName and privateGlobalCCode is used to pass output to caller of getCDeclarationString
//
- private void getCDeclarationString(Token t)
+ private void getCDeclarationString(Token t)
throws EntityException {
-
+
if (t.isSkuEnable()) {
privateGlobalName = String.format("%s_%s", t.getPrimaryKeyString(), skuDataTableTemplate);
} else {
@@ -1382,8 +1358,8 @@ public class PcdDatabase { privateGlobalCCode = String.format("%-20s%s[%d];\r\n", type, privateGlobalName, t.getSkuIdCount());
}
}
-
- private String getDataTypeDeclarationForVariableDefault (Token token, String cName, int skuId)
+
+ private String getDataTypeDeclarationForVariableDefault (Token token, String cName, int skuId)
throws EntityException {
String typeStr;
@@ -1424,9 +1400,9 @@ public class PcdDatabase { return String.format("%-20s%s;\r\n", typeStr, cName);
}
-
+
private String getTypeInstantiation (Token t, ArrayList<CStructTypeDeclaration> declaList, HashMap<String, String> instTable, String phase) throws EntityException {
-
+
int i;
String s;
@@ -1445,8 +1421,8 @@ public class PcdDatabase { UINT16 DefaultValueOffset; // Offset of the Default Value
} VARIABLE_HEAD ;
*/
- String variableDefaultName = String.format("%s_VariableDefault_%d", t.getPrimaryKeyString(), i);
-
+ String variableDefaultName = String.format("%s_VariableDefault_%d", t.getPrimaryKeyString(), i);
+
s += tab + tab + String.format("{ %d, %d, %s, %s }", guidTable.add(t.skuData.get(i).value.variableGuid, t.getPrimaryKeyString()),
stringTable.add(t.skuData.get(i).value.getStringOfVariableName(), t),
t.skuData.get(i).value.variableOffset,
@@ -1460,7 +1436,7 @@ public class PcdDatabase { getHiiPtrTypeAlignmentSize(t),
getDataTypeDeclarationForVariableDefault(t, variableDefaultName, i),
true
- );
+ );
declaList.add(decl);
instTable.put(variableDefaultName, getDataTypeInstantiationForVariableDefault (t, variableDefaultName, i));
} else if (t.isVpdEnable()) {
@@ -1479,7 +1455,7 @@ public class PcdDatabase { s += tab + tab + String.format("{ %s }", t.skuData.get(i).value.value);
}
}
-
+
if (i != t.skuData.size() - 1) {
s += commaNewLine;
} else {
@@ -1487,19 +1463,19 @@ public class PcdDatabase { }
}
-
+
s += tab + "}";
-
+
return s;
}
-
- public static String getPcdDatabaseCommonDefinitions ()
+
+ public static String getPcdDatabaseCommonDefinitions ()
throws EntityException {
String retStr = "";
try {
- File file = new File(GlobalData.getWorkspacePath() + File.separator +
- "Tools" + File.separator +
+ File file = new File(GlobalData.getWorkspacePath() + File.separator +
+ "Tools" + File.separator +
"Conf" + File.separator +
"Pcd" + File.separator +
"PcdDatabaseCommonDefinitions.sample");
@@ -1516,13 +1492,13 @@ public class PcdDatabase { return retStr;
}
- public static String getPcdDxeDatabaseDefinitions ()
+ public static String getPcdDxeDatabaseDefinitions ()
throws EntityException {
String retStr = "";
try {
- File file = new File(GlobalData.getWorkspacePath() + File.separator +
- "Tools" + File.separator +
+ File file = new File(GlobalData.getWorkspacePath() + File.separator +
+ "Tools" + File.separator +
"Conf" + File.separator +
"Pcd" + File.separator +
"PcdDatabaseDxeDefinitions.sample");
@@ -1539,13 +1515,13 @@ public class PcdDatabase { return retStr;
}
- public static String getPcdPeiDatabaseDefinitions ()
+ public static String getPcdPeiDatabaseDefinitions ()
throws EntityException {
String retStr = "";
try {
- File file = new File(GlobalData.getWorkspacePath() + File.separator +
- "Tools" + File.separator +
+ File file = new File(GlobalData.getWorkspacePath() + File.separator +
+ "Tools" + File.separator +
"Conf" + File.separator +
"Pcd" + File.separator +
"PcdDatabasePeiDefinitions.sample");
@@ -1564,21 +1540,21 @@ public class PcdDatabase { /**
Translate the schema string to UUID instance.
-
+
In schema, the string of UUID is defined as following two types string:
1) GuidArrayType: pattern = 0x[a-fA-F0-9]{1,8},( )*0x[a-fA-F0-9]{1,4},(
)*0x[a-fA-F0-9]{1,4}(,( )*\{)?(,?( )*0x[a-fA-F0-9]{1,2}){8}( )*(\})?
-
+
2) GuidNamingConvention: pattern =
[a-fA-F0-9]{8}-[a-fA-F0-9]{4}-[a-fA-F0-9]{4}-[a-fA-F0-9]{4}-[a-fA-F0-9]{12}
-
+
This function will convert string and create uuid instance.
-
+
@param uuidString UUID string in XML file
-
+
@return UUID UUID instance
**/
- private UUID translateSchemaStringToUUID(String uuidString)
+ private UUID translateSchemaStringToUUID(String uuidString)
throws EntityException {
String temp;
String[] splitStringArray;
@@ -1603,9 +1579,9 @@ public class PcdDatabase { uuidString = uuidString.replaceAll("\\}", "");
//
- // If the UUID schema string is GuidArrayType type then need translate
+ // If the UUID schema string is GuidArrayType type then need translate
// to GuidNamingConvention type at first.
- //
+ //
if ((uuidString.charAt(0) == '0') && ((uuidString.charAt(1) == 'x') || (uuidString.charAt(1) == 'X'))) {
splitStringArray = uuidString.split("," );
if (splitStringArray.length != 11) {
@@ -1614,7 +1590,7 @@ public class PcdDatabase { //
// Remove blank space from these string and remove header string "0x"
- //
+ //
for (index = 0; index < 11; index ++) {
splitStringArray[index] = splitStringArray[index].trim();
splitStringArray[index] = splitStringArray[index].substring(2, splitStringArray[index].length());
@@ -1622,7 +1598,7 @@ public class PcdDatabase { //
// Add heading '0' to normalize the string length
- //
+ //
for (index = 3; index < 11; index ++) {
chLen = splitStringArray[index].length();
for (chIndex = 0; chIndex < 2 - chLen; chIndex ++) {
@@ -1632,7 +1608,7 @@ public class PcdDatabase { //
// construct the final GuidNamingConvention string
- //
+ //
temp = String.format("%s-%s-%s-%s%s-%s%s%s%s%s%s",
splitStringArray[0],
splitStringArray[1],
diff --git a/Tools/Source/GenBuild/org/tianocore/build/pcd/action/PlatformPcdPreprocessActionForBuilding.java b/Tools/Source/GenBuild/org/tianocore/build/pcd/action/PlatformPcdPreprocessActionForBuilding.java new file mode 100644 index 0000000000..2e50531d7e --- /dev/null +++ b/Tools/Source/GenBuild/org/tianocore/build/pcd/action/PlatformPcdPreprocessActionForBuilding.java @@ -0,0 +1,719 @@ +/** @file
+ PlatformPcdPreprocessActionForBuilding class.
+
+ This action class is to collect PCD information from MSA, SPD, FPD xml file.
+ This class will be used for wizard and build tools, So it can *not* inherit
+ from buildAction or wizardAction.
+
+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.
+
+**/
+package org.tianocore.build.pcd.action;
+
+import java.io.File;
+import java.io.IOException;
+import java.math.BigInteger;
+import java.util.ArrayList;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+
+import org.apache.xmlbeans.XmlException;
+import org.apache.xmlbeans.XmlObject;
+import org.tianocore.DynamicPcdBuildDefinitionsDocument.DynamicPcdBuildDefinitions;
+import org.tianocore.PlatformSurfaceAreaDocument;
+import org.tianocore.build.fpd.FpdParserTask;
+import org.tianocore.build.global.GlobalData;
+import org.tianocore.build.id.FpdModuleIdentification;
+import org.tianocore.pcd.action.ActionMessage;
+import org.tianocore.pcd.entity.ModulePcdInfoFromFpd;
+import org.tianocore.pcd.entity.MemoryDatabaseManager;
+import org.tianocore.pcd.entity.Token;
+import org.tianocore.pcd.entity.UsageIdentification;
+import org.tianocore.pcd.exception.EntityException;
+import org.tianocore.pcd.action.PlatformPcdPreprocessAction;
+
+/**
+ This action class is to collect PCD information from MSA, SPD, FPD xml file.
+ This class will be used for wizard and build tools, So it can *not* inherit
+ from buildAction or UIAction.
+**/
+public class PlatformPcdPreprocessActionForBuilding extends PlatformPcdPreprocessAction {
+ ///
+ /// Workspacepath hold the workspace information.
+ ///
+ private String workspacePath;
+
+ ///
+ /// FPD file is the root file.
+ ///
+ private String fpdFilePath;
+
+ ///
+ /// Message level for CollectPCDAction.
+ ///
+ private int originalMessageLevel;
+
+ ///
+ /// Cache the fpd docment instance for private usage.
+ ///
+ private PlatformSurfaceAreaDocument fpdDocInstance;
+
+ /**
+ Set WorkspacePath parameter for this action class.
+
+ @param workspacePath parameter for this action
+ **/
+ public void setWorkspacePath(String workspacePath) {
+ this.workspacePath = workspacePath;
+ }
+
+ /**
+ Set action message level for CollectPcdAction tool.
+
+ The message should be restored when this action exit.
+
+ @param actionMessageLevel parameter for this action
+ **/
+ public void setActionMessageLevel(int actionMessageLevel) {
+ originalMessageLevel = ActionMessage.messageLevel;
+ ActionMessage.messageLevel = actionMessageLevel;
+ }
+
+ /**
+ Set FPDFileName parameter for this action class.
+
+ @param fpdFilePath fpd file path
+ **/
+ public void setFPDFilePath(String fpdFilePath) {
+ this.fpdFilePath = fpdFilePath;
+ }
+
+ /**
+ Common function interface for outer.
+
+ @param workspacePath The path of workspace of current build or analysis.
+ @param fpdFilePath The fpd file path of current build or analysis.
+ @param messageLevel The message level for this Action.
+
+ @throws Exception The exception of this function. Because it can *not* be predict
+ where the action class will be used. So only Exception can be throw.
+
+ **/
+ public void perform(String workspacePath, String fpdFilePath,
+ int messageLevel) throws Exception {
+ setWorkspacePath(workspacePath);
+ setFPDFilePath(fpdFilePath);
+ setActionMessageLevel(messageLevel);
+ checkParameter();
+ execute();
+ ActionMessage.messageLevel = originalMessageLevel;
+ }
+
+ /**
+ Core execution function for this action class.
+
+ This function work flows will be:
+ 1) Collect and prepocess PCD information from FPD file, all PCD
+ information will be stored into memory database.
+ 2) Generate 3 strings for
+ a) All modules using Dynamic(Ex) PCD entry.(Token Number)
+ b) PEI PCDDatabase (C Structure) for PCD Service PEIM.
+ c) DXE PCD Database (C structure) for PCD Service DXE.
+
+
+ @throws EntityException Exception indicate failed to execute this action.
+
+ **/
+ public void execute() throws EntityException {
+ MemoryDatabaseManager pcdDbManager = null;
+
+ //
+ // Get memoryDatabaseManager instance from GlobalData.
+ // The memoryDatabaseManager should be initialized for whatever build
+ // tools or wizard tools
+ //
+ if((pcdDbManager = GlobalData.getPCDMemoryDBManager()) == null) {
+ throw new EntityException("The instance of PCD memory database manager is null");
+ }
+
+ this.setPcdDbManager(pcdDbManager);
+
+ //
+ // Collect all PCD information defined in FPD file.
+ // Evenry token defind in FPD will be created as an token into
+ // memory database.
+ //
+ initPcdMemoryDbWithPlatformInfo();
+
+ //
+ // Generate for PEI, DXE PCD DATABASE's definition and initialization.
+ //
+ genPcdDatabaseSourceCode ();
+
+ }
+
+ /**
+ Override function: implementate the method of get Guid string information from SPD file.
+
+ @param guidCName Guid CName string.
+
+ @return String[] Guid information from SPD file.
+ **/
+ public String[] getGuidInfoFromSpd(String guidCName) throws EntityException {
+ String[] tokenSpaceStrRet = null;
+ try {
+ tokenSpaceStrRet = GlobalData.getGuidInfoFromCname(guidCName);
+ } catch ( Exception e ) {
+ throw new EntityException ("Failed get Guid CName " + guidCName + "from SPD file!");
+ }
+ return tokenSpaceStrRet;
+ }
+
+ /**
+ This function generates source code for PCD Database.
+
+ @param void
+ @throws EntityException If the token does *not* exist in memory database.
+
+ **/
+ private void genPcdDatabaseSourceCode()
+ throws EntityException {
+ String PcdCommonHeaderString = PcdDatabase.getPcdDatabaseCommonDefinitions();
+
+ ArrayList<Token> alPei = new ArrayList<Token> ();
+ ArrayList<Token> alDxe = new ArrayList<Token> ();
+
+ getPcdDbManager().getTwoPhaseDynamicRecordArray(alPei, alDxe);
+ PcdDatabase pcdPeiDatabase = new PcdDatabase (alPei, "PEI", 0);
+ pcdPeiDatabase.genCode();
+ MemoryDatabaseManager.PcdPeimHString = PcdCommonHeaderString + pcdPeiDatabase.getHString() +
+ PcdDatabase.getPcdPeiDatabaseDefinitions();
+ MemoryDatabaseManager.PcdPeimCString = pcdPeiDatabase.getCString();
+
+ PcdDatabase pcdDxeDatabase = new PcdDatabase(alDxe, "DXE", alPei.size());
+ pcdDxeDatabase.genCode();
+ MemoryDatabaseManager.PcdDxeHString = MemoryDatabaseManager.PcdPeimHString + pcdDxeDatabase.getHString() +
+ PcdDatabase.getPcdDxeDatabaseDefinitions();
+ MemoryDatabaseManager.PcdDxeCString = pcdDxeDatabase.getCString();
+ }
+
+ /**
+ Override function: Get component array from FPD.
+
+ This function maybe provided by some Global class.
+
+ @return List<ModuleInfo> the component array.
+
+ */
+ public List<ModulePcdInfoFromFpd> getComponentsFromFpd()
+ throws EntityException {
+ List<ModulePcdInfoFromFpd> allModules = new ArrayList<ModulePcdInfoFromFpd>();
+ Map<FpdModuleIdentification, XmlObject> pcdBuildDefinitions = null;
+ UsageIdentification usageId = null;
+
+ pcdBuildDefinitions = GlobalData.getFpdPcdBuildDefinitions();
+ if (pcdBuildDefinitions == null) {
+ return null;
+ }
+
+ //
+ // Loop map to retrieve all PCD build definition and Module id
+ //
+ Iterator item = pcdBuildDefinitions.keySet().iterator();
+ while (item.hasNext()){
+ FpdModuleIdentification id = (FpdModuleIdentification) item.next();
+ usageId = new UsageIdentification(id.getModule().getName(),
+ id.getModule().getGuid(),
+ id.getModule().getPackage().getName(),
+ id.getModule().getPackage().getGuid(),
+ id.getArch(),
+ id.getModule().getVersion(),
+ id.getModule().getModuleType());
+ allModules.add(new ModulePcdInfoFromFpd(usageId, pcdBuildDefinitions.get(id)));
+ }
+ return allModules;
+ }
+
+ /**
+ Override function: Verify the datum value according its datum size and datum type, this
+ function maybe moved to FPD verification tools in future.
+
+ @param cName
+ @param moduleName
+ @param datum
+ @param datumType
+ @param maxDatumSize
+
+ @return String
+ */
+ /***/
+ public String verifyDatum(String cName,
+ String moduleName,
+ String datum,
+ Token.DATUM_TYPE datumType,
+ int maxDatumSize) {
+ String exceptionString = null;
+ int value;
+ BigInteger value64;
+ String subStr;
+ int index;
+
+ if (moduleName == null) {
+ moduleName = "section <DynamicPcdBuildDefinitions>";
+ } else {
+ moduleName = "module " + moduleName;
+ }
+
+ if (maxDatumSize == 0) {
+ exceptionString = String.format("[FPD file error] You maybe miss <MaxDatumSize> for PCD %s in %s",
+ cName,
+ moduleName);
+ return exceptionString;
+ }
+
+ switch (datumType) {
+ case UINT8:
+ if (maxDatumSize != 1) {
+ exceptionString = String.format("[FPD file error] The datum type of PCD data %s in %s "+
+ "is UINT8, but datum size is %d, they are not matched!",
+ cName,
+ moduleName,
+ maxDatumSize);
+ return exceptionString;
+ }
+
+ if (datum != null) {
+ try {
+ value = Integer.decode(datum);
+ } catch (NumberFormatException nfeExp) {
+ exceptionString = String.format("[FPD file error] The datum for PCD %s in %s is not valid "+
+ "digital format of UINT8",
+ cName,
+ moduleName);
+ return exceptionString;
+ }
+ if (value > 0xFF) {
+ exceptionString = String.format("[FPD file error] The datum for PCD %s in %s is %s exceed"+
+ " the max size of UINT8 - 0xFF",
+ cName,
+ moduleName,
+ datum);
+ return exceptionString;
+ }
+ }
+ break;
+ case UINT16:
+ if (maxDatumSize != 2) {
+ exceptionString = String.format("[FPD file error] The datum type of PCD data %s in %s "+
+ "is UINT16, but datum size is %d, they are not matched!",
+ cName,
+ moduleName,
+ maxDatumSize);
+ return exceptionString;
+ }
+ if (datum != null) {
+ try {
+ value = Integer.decode(datum);
+ } catch (NumberFormatException nfeExp) {
+ exceptionString = String.format("[FPD file error] The datum for PCD %s in %s is "+
+ "not valid digital of UINT16",
+ cName,
+ moduleName);
+ return exceptionString;
+ }
+ if (value > 0xFFFF) {
+ exceptionString = String.format("[FPD file error] The datum for PCD %s in %s is %s "+
+ "which exceed the range of UINT16 - 0xFFFF",
+ cName,
+ moduleName,
+ datum);
+ return exceptionString;
+ }
+ }
+ break;
+ case UINT32:
+ if (maxDatumSize != 4) {
+ exceptionString = String.format("[FPD file error] The datum type of PCD data %s in %s "+
+ "is UINT32, but datum size is %d, they are not matched!",
+ cName,
+ moduleName,
+ maxDatumSize);
+ return exceptionString;
+ }
+
+ if (datum != null) {
+ try {
+ if (datum.length() > 2) {
+ if ((datum.charAt(0) == '0') &&
+ ((datum.charAt(1) == 'x') || (datum.charAt(1) == 'X'))){
+ subStr = datum.substring(2, datum.length());
+ value64 = new BigInteger(subStr, 16);
+ } else {
+ value64 = new BigInteger(datum);
+ }
+ } else {
+ value64 = new BigInteger(datum);
+ }
+ } catch (NumberFormatException nfeExp) {
+ exceptionString = String.format("[FPD file error] The datum for PCD %s in %s is not "+
+ "valid digital of UINT32",
+ cName,
+ moduleName);
+ return exceptionString;
+ }
+
+ if (value64.bitLength() > 32) {
+ exceptionString = String.format("[FPD file error] The datum for PCD %s in %s is %s which "+
+ "exceed the range of UINT32 - 0xFFFFFFFF",
+ cName,
+ moduleName,
+ datum);
+ return exceptionString;
+ }
+ }
+ break;
+ case UINT64:
+ if (maxDatumSize != 8) {
+ exceptionString = String.format("[FPD file error] The datum type of PCD data %s in %s "+
+ "is UINT64, but datum size is %d, they are not matched!",
+ cName,
+ moduleName,
+ maxDatumSize);
+ return exceptionString;
+ }
+
+ if (datum != null) {
+ try {
+ if (datum.length() > 2) {
+ if ((datum.charAt(0) == '0') &&
+ ((datum.charAt(1) == 'x') || (datum.charAt(1) == 'X'))){
+ subStr = datum.substring(2, datum.length());
+ value64 = new BigInteger(subStr, 16);
+ } else {
+ value64 = new BigInteger(datum);
+ }
+ } else {
+ value64 = new BigInteger(datum);
+ }
+ } catch (NumberFormatException nfeExp) {
+ exceptionString = String.format("[FPD file error] The datum for PCD %s in %s is not valid"+
+ " digital of UINT64",
+ cName,
+ moduleName);
+ return exceptionString;
+ }
+
+ if (value64.bitLength() > 64) {
+ exceptionString = String.format("[FPD file error] The datum for PCD %s in %s is %s "+
+ "exceed the range of UINT64 - 0xFFFFFFFFFFFFFFFF",
+ cName,
+ moduleName,
+ datum);
+ return exceptionString;
+ }
+ }
+ break;
+ case BOOLEAN:
+ if (maxDatumSize != 1) {
+ exceptionString = String.format("[FPD file error] The datum type of PCD data %s in %s "+
+ "is BOOLEAN, but datum size is %d, they are not matched!",
+ cName,
+ moduleName,
+ maxDatumSize);
+ return exceptionString;
+ }
+
+ if (datum != null) {
+ if (!(datum.equalsIgnoreCase("TRUE") ||
+ datum.equalsIgnoreCase("FALSE"))) {
+ exceptionString = String.format("[FPD file error] The datum type of PCD data %s in %s "+
+ "is BOOELAN, but value is not 'true'/'TRUE' or 'FALSE'/'false'",
+ cName,
+ moduleName);
+ return exceptionString;
+ }
+
+ }
+ break;
+ case POINTER:
+ if (datum == null) {
+ break;
+ }
+
+ char ch = datum.charAt(0);
+ int start, end;
+ String strValue;
+ //
+ // For void* type PCD, only three datum is support:
+ // 1) Unicode: string with start char is "L"
+ // 2) Ansci: String start char is ""
+ // 3) byte array: String start char "{"
+ //
+ if (ch == 'L') {
+ start = datum.indexOf('\"');
+ end = datum.lastIndexOf('\"');
+ if ((start > end) ||
+ (end > datum.length())||
+ ((start == end) && (datum.length() > 0))) {
+ exceptionString = String.format("[FPD file error] The datum type of PCD %s in %s is VOID* and datum is "+
+ "a UNICODE string because start with L\", but format maybe"+
+ "is not right, correct UNICODE string is L\"...\"!",
+ cName,
+ moduleName);
+ return exceptionString;
+ }
+
+ strValue = datum.substring(start + 1, end);
+ if ((strValue.length() * 2) > maxDatumSize) {
+ exceptionString = String.format("[FPD file error] The datum type of PCD %s in %s is VOID*, and datum is "+
+ "a UNICODE string, but the datum size is %d exceed to <MaxDatumSize> : %d",
+ cName,
+ moduleName,
+ strValue.length() * 2,
+ maxDatumSize);
+ return exceptionString;
+ }
+ } else if (ch == '\"'){
+ start = datum.indexOf('\"');
+ end = datum.lastIndexOf('\"');
+ if ((start > end) ||
+ (end > datum.length())||
+ ((start == end) && (datum.length() > 0))) {
+ exceptionString = String.format("[FPD file error] The datum type of PCD %s in %s is VOID* and datum is "+
+ "a ANSCII string because start with \", but format maybe"+
+ "is not right, correct ANSIC string is \"...\"!",
+ cName,
+ moduleName);
+ return exceptionString;
+ }
+ strValue = datum.substring(start + 1, end);
+ if ((strValue.length()) > maxDatumSize) {
+ exceptionString = String.format("[FPD file error] The datum type of PCD %s in %s is VOID*, and datum is "+
+ "a ANSCI string, but the datum size is %d which exceed to <MaxDatumSize> : %d",
+ cName,
+ moduleName,
+ strValue.length(),
+ maxDatumSize);
+ return exceptionString;
+ }
+ } else if (ch =='{') {
+ String[] strValueArray;
+
+ start = datum.indexOf('{');
+ end = datum.lastIndexOf('}');
+ strValue = datum.substring(start + 1, end);
+ strValue = strValue.trim();
+ if (strValue.length() == 0) {
+ exceptionString = String.format ("[FPD file error] The datum type of PCD %s in %s is VOID*, and "+
+ "it is byte array in fact, but '{}' is not valid for NULL datam but"+
+ " need use '{0}'",
+ cName,
+ moduleName);
+ return exceptionString;
+ }
+ strValueArray = strValue.split(",");
+ for (index = 0; index < strValueArray.length; index ++) {
+ try{
+ value = Integer.decode(strValueArray[index].trim());
+ } catch (NumberFormatException nfeEx) {
+ exceptionString = String.format("[FPD file error] The datum type of PCD %s in %s is VOID*, and "+
+ "it is byte array in fact. For every byte in array should be a valid"+
+ "byte digital, but element %s is not a valid byte digital!",
+ cName,
+ moduleName,
+ strValueArray[index]);
+ return exceptionString;
+ }
+ if (value > 0xFF) {
+ exceptionString = String.format("[FPD file error] The datum type of PCD %s in %s is VOID*, "+
+ "it is byte array in fact. But the element of %s exceed the byte range",
+ cName,
+ moduleName,
+ strValueArray[index]);
+ return exceptionString;
+ }
+ }
+
+ if (strValueArray.length > maxDatumSize) {
+ exceptionString = String.format("[FPD file error] The datum type of PCD %s in %s is VOID*, and datum is byte"+
+ "array, but the number of bytes is %d which exceed to <MaxDatumSzie> : %d!",
+ cName,
+ moduleName,
+ strValueArray.length,
+ maxDatumSize);
+ return exceptionString;
+ }
+ } else {
+ exceptionString = String.format("[FPD file error] The datum type of PCD %s in %s is VOID*. For VOID* type, you have three format choise:\n "+
+ "1) UNICODE string: like L\"xxxx\";\r\n"+
+ "2) ANSIC string: like \"xxx\";\r\n"+
+ "3) Byte array: like {0x2, 0x45, 0x23}\r\n"+
+ "But the datum in seems does not following above format!",
+ cName,
+ moduleName);
+ return exceptionString;
+ }
+ break;
+ default:
+ exceptionString = String.format("[FPD file error] For PCD entry %s in %s, datum type is unknown, it should be one of "+
+ "UINT8, UINT16, UINT32, UINT64, VOID*, BOOLEAN",
+ cName,
+ moduleName);
+ return exceptionString;
+ }
+ return null;
+ }
+
+ /**
+ Override function: Get dynamic information for a dynamic PCD from <DynamicPcdBuildDefinition> seciton in FPD file.
+
+ This function should be implemented in GlobalData in future.
+
+ @param token The token instance which has hold module's PCD information
+ @param moduleName The name of module who will use this Dynamic PCD.
+
+ @return DynamicPcdBuildDefinitions.PcdBuildData
+ **/
+ public DynamicPcdBuildDefinitions.PcdBuildData getDynamicInfoFromFpd(Token token,
+ String moduleName)
+ throws EntityException {
+ int index = 0;
+ String exceptionString = null;
+ String dynamicPrimaryKey = null;
+ DynamicPcdBuildDefinitions dynamicPcdBuildDefinitions = null;
+ List<DynamicPcdBuildDefinitions.PcdBuildData> dynamicPcdBuildDataArray = null;
+ String[] tokenSpaceStrRet = null;
+
+ //
+ // If FPD document is not be opened, open and initialize it.
+ // BUGBUG: The code should be moved into GlobalData in future.
+ //
+ if (fpdDocInstance == null) {
+ try {
+ fpdDocInstance = (PlatformSurfaceAreaDocument)XmlObject.Factory.parse(new File(fpdFilePath));
+ } catch(IOException ioE) {
+ throw new EntityException("File IO error for xml file:" + fpdFilePath + "\n" + ioE.getMessage());
+ } catch(XmlException xmlE) {
+ throw new EntityException("Can't parse the FPD xml fle:" + fpdFilePath + "\n" + xmlE.getMessage());
+ }
+ }
+
+ dynamicPcdBuildDefinitions = fpdDocInstance.getPlatformSurfaceArea().getDynamicPcdBuildDefinitions();
+ if (dynamicPcdBuildDefinitions == null) {
+ exceptionString = String.format("[FPD file error] There are no <PcdDynamicBuildDescriptions> in FPD file but contains Dynamic type "+
+ "PCD entry %s in module %s!",
+ token.cName,
+ moduleName);
+ throw new EntityException(exceptionString);
+ }
+
+ dynamicPcdBuildDataArray = dynamicPcdBuildDefinitions.getPcdBuildDataList();
+ for (index = 0; index < dynamicPcdBuildDataArray.size(); index ++) {
+ try {
+ tokenSpaceStrRet = GlobalData.getGuidInfoFromCname(dynamicPcdBuildDataArray.get(index).getTokenSpaceGuidCName());
+ } catch (Exception e) {
+ throw new EntityException ("Fail to get token space guid for token " + dynamicPcdBuildDataArray.get(index).getCName());
+ }
+
+ if (tokenSpaceStrRet == null) {
+ throw new EntityException ("Fail to get token space guid for token " + dynamicPcdBuildDataArray.get(index).getCName());
+ }
+
+ dynamicPrimaryKey = Token.getPrimaryKeyString(dynamicPcdBuildDataArray.get(index).getCName(),
+ tokenSpaceStrRet[1]);
+ if (dynamicPrimaryKey.equalsIgnoreCase(token.getPrimaryKeyString())) {
+ return dynamicPcdBuildDataArray.get(index);
+ }
+ }
+
+ return null;
+ }
+
+ /**
+ Override function: get all <DynamicPcdBuildDefinition> from FPD file.
+
+ @return List<DynamicPcdBuildDefinitions.PcdBuildData>
+ **/
+ public List<DynamicPcdBuildDefinitions.PcdBuildData>
+ getAllDynamicPcdInfoFromFpd()
+ throws EntityException {
+ DynamicPcdBuildDefinitions dynamicPcdBuildDefinitions = null;
+
+ //
+ // Open fpd document to get <DynamicPcdBuildDefinition> Section.
+ // BUGBUG: the function should be move GlobalData in furture.
+ //
+ if (fpdDocInstance == null) {
+ try {
+ fpdDocInstance = (PlatformSurfaceAreaDocument)XmlObject.Factory.parse(new File(fpdFilePath));
+ } catch(IOException ioE) {
+ throw new EntityException("File IO error for xml file:" + fpdFilePath + "\n" + ioE.getMessage());
+ } catch(XmlException xmlE) {
+ throw new EntityException("Can't parse the FPD xml fle:" + fpdFilePath + "\n" + xmlE.getMessage());
+ }
+ }
+
+ dynamicPcdBuildDefinitions = fpdDocInstance.getPlatformSurfaceArea().getDynamicPcdBuildDefinitions();
+ if (dynamicPcdBuildDefinitions == null) {
+ return null;
+ }
+
+ return dynamicPcdBuildDefinitions.getPcdBuildDataList();
+ }
+
+ /**
+ check parameter for this action.
+
+ @throws EntityException Bad parameter.
+ **/
+ private void checkParameter() throws EntityException {
+ File file = null;
+
+ if((fpdFilePath == null) ||(workspacePath == null)) {
+ throw new EntityException("WorkspacePath and FPDFileName should be blank for CollectPCDAtion!");
+ }
+
+ if(fpdFilePath.length() == 0 || workspacePath.length() == 0) {
+ throw new EntityException("WorkspacePath and FPDFileName should be blank for CollectPCDAtion!");
+ }
+
+ file = new File(workspacePath);
+ if(!file.exists()) {
+ throw new EntityException("WorkpacePath " + workspacePath + " does not exist!");
+ }
+
+ file = new File(fpdFilePath);
+
+ if(!file.exists()) {
+ throw new EntityException("FPD File " + fpdFilePath + " does not exist!");
+ }
+ }
+
+ /**
+ Test case function
+
+ @param argv parameter from command line
+ **/
+ public static void main(String argv[]) throws EntityException {
+ PlatformPcdPreprocessActionForBuilding ca = new PlatformPcdPreprocessActionForBuilding();
+ String projectDir = "x:/edk2";
+ ca.setWorkspacePath(projectDir);
+ ca.setFPDFilePath(projectDir + "/EdkNt32Pkg/Nt32.fpd");
+ ca.setActionMessageLevel(ActionMessage.MAX_MESSAGE_LEVEL);
+ GlobalData.initInfo("Tools" + File.separator + "Conf" + File.separator + "FrameworkDatabase.db",
+ projectDir,
+ "tools_def.txt");
+ System.out.println("After initInfo!");
+ FpdParserTask fpt = new FpdParserTask();
+ fpt.parseFpdFile(new File(projectDir + "/EdkNt32Pkg/Nt32.fpd"));
+ ca.execute();
+ }
+}
|