From 7db4ab705a654e2202b083968e92d5b552007d6b Mon Sep 17 00:00:00 2001 From: klu2 Date: Tue, 13 Jun 2006 09:40:16 +0000 Subject: [PATCH] Fix some bugs in PCD tools: 1) Normalize the exception text format, 2) Add throw exception in some special case. 3) Add more code to verify Datum Size. git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@497 6f19259b-4bc3-4df7-8a09-765794883524 --- EdkNt32Pkg/Nt32.fpd | 2 +- .../tianocore/build/fpd/FpdParserTask.java | 34 ++++--- .../build/pcd/action/CollectPCDAction.java | 95 +++++++++++++------ 3 files changed, 86 insertions(+), 45 deletions(-) diff --git a/EdkNt32Pkg/Nt32.fpd b/EdkNt32Pkg/Nt32.fpd index e041ef53d5..8bee2a0782 100644 --- a/EdkNt32Pkg/Nt32.fpd +++ b/EdkNt32Pkg/Nt32.fpd @@ -4980,7 +4980,7 @@ PcdWinNtSerialPort 0x00001002 VOID* - 20 + 18 0 L"COM1!COM2" diff --git a/Tools/Source/GenBuild/org/tianocore/build/fpd/FpdParserTask.java b/Tools/Source/GenBuild/org/tianocore/build/fpd/FpdParserTask.java index 1e3de2a4e6..011e13de52 100644 --- a/Tools/Source/GenBuild/org/tianocore/build/fpd/FpdParserTask.java +++ b/Tools/Source/GenBuild/org/tianocore/build/fpd/FpdParserTask.java @@ -783,20 +783,24 @@ public class FpdParserTask extends Task { } public void collectPCDInformation() { - CollectPCDAction collectAction = new CollectPCDAction (); - // - // Collect all PCD information from FPD to MSA, and get help information from SPD. - // These all information will be stored into memory database for future usage such - // as autogen. - // - try { - collectAction.perform ( - getProject().getProperty("WORKSPACE_DIR"), - fpdFilename.getPath(), - ActionMessage.MAX_MESSAGE_LEVEL - ); - } catch (Exception exp) { - throw new BuildException (String.format("Fail to do PCD preprocess from FPD file, the cause is %s", exp.getMessage())); - } + String exceptionString = null; + CollectPCDAction collectAction = new CollectPCDAction (); + // + // Collect all PCD information from FPD to MSA, and get help information from SPD. + // These all information will be stored into memory database for future usage such + // as autogen. + // + try { + collectAction.perform (getProject().getProperty("WORKSPACE_DIR"), + fpdFilename.getPath(), + ActionMessage.MAX_MESSAGE_LEVEL + ); + } catch (Exception exp) { + exceptionString = exp.getMessage(); + if (exceptionString == null) { + exceptionString = "[Internal Error]Pcd tools catch a internel errors, Please report this bug into TianoCore or send email to Wang, scott or Lu, ken!"; + } + throw new BuildException (String.format("Fail to do PCD preprocess from FPD file: %s", exceptionString)); + } } } diff --git a/Tools/Source/GenBuild/org/tianocore/build/pcd/action/CollectPCDAction.java b/Tools/Source/GenBuild/org/tianocore/build/pcd/action/CollectPCDAction.java index 4057c417e4..fe09be2b9a 100644 --- a/Tools/Source/GenBuild/org/tianocore/build/pcd/action/CollectPCDAction.java +++ b/Tools/Source/GenBuild/org/tianocore/build/pcd/action/CollectPCDAction.java @@ -1469,7 +1469,7 @@ public class CollectPCDAction { modules = getComponentsFromFPD(); if (modules == null) { - throw new EntityException("No modules in FPD file, Please check whether there are elements in in FPD file!"); + throw new EntityException("[FPD file error] No modules in FPD file, Please check whether there are elements in in FPD file!"); } // @@ -1542,7 +1542,7 @@ public class CollectPCDAction { // Value is required. // if (datum == null) { - exceptionString = String.format("There is no value for PCD entry %s in module %s!", + exceptionString = String.format("[FPD file error] There is no value for PCD entry %s in module %s!", pcdBuildData.getCName(), moduleName); throw new EntityException(exceptionString); @@ -1576,7 +1576,7 @@ public class CollectPCDAction { // modules. // if (token.datumType != datumType) { - exceptionString = String.format("The datum type of PCD entry %s is %s, which is different with %s defined in before!", + 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)); @@ -1587,7 +1587,7 @@ public class CollectPCDAction { // Check token number is valid // if (tokenNumber != token.tokenNumber) { - exceptionString = String.format("The token number of PCD entry %s in module %s is different with same PCD entry in other modules!", + 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); @@ -1597,7 +1597,7 @@ public class CollectPCDAction { // 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("For PCD entry %s in module %s, you define dynamic or non-dynamic PCD type which"+ + 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); @@ -1611,15 +1611,28 @@ public class CollectPCDAction { // But if you write, the must be same as the value in . // if (!token.isSkuEnable() && - (token.skuData.get(0).value.type == DynamicTokenValue.VALUE_TYPE.DEFAULT_TYPE)) { - if (!datum.equalsIgnoreCase(token.skuData.get(0).value.value)) { - exceptionString = String.format("For dynamic PCD %s in module %s, the datum in is "+ + (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 is "+ "not equal to the datum in , it is "+ - "illega! You can choose no in !", + "illega! You could no set in 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 %d defined in !", + token.cName, + moduleName, + maxDatumSize, + token.datumSize); + throw new EntityException(exceptionString); + } } } else { @@ -1712,7 +1725,7 @@ public class CollectPCDAction { dynamicPcdBuildDefinitions = fpdDocInstance.getFrameworkPlatformDescription().getDynamicPcdBuildDefinitions(); if (dynamicPcdBuildDefinitions == null) { - exceptionString = String.format("There are no in FPD file but contains Dynamic type "+ + exceptionString = String.format("[FPD file error] There are no in FPD file but contains Dynamic type "+ "PCD entry %s in module %s!", token.cName, moduleName); @@ -1747,10 +1760,18 @@ public class CollectPCDAction { int maxDatumSize, Token.DATUM_TYPE datumType) { String exceptionString = null; + + if (maxDatumSize == 0) { + exceptionString = String.format("[FPD file error] You maybe miss for PCD %s in module %s", + cName, + moduleName); + return exceptionString; + } + switch (datumType) { case UINT8: if (maxDatumSize != 1) { - exceptionString = String.format("In FPD file, the datum type of PCD data %s in module %s "+ + exceptionString = String.format("[FPD file error] The datum type of PCD data %s in module %s "+ "is UINT8, but datum size is %d, they are not matched!", cName, moduleName, @@ -1759,7 +1780,7 @@ public class CollectPCDAction { break; case UINT16: if (maxDatumSize != 2) { - exceptionString = String.format("In FPD file, the datum type of PCD data %s in module %s "+ + exceptionString = String.format("[FPD file error] The datum type of PCD data %s in module %s "+ "is UINT16, but datum size is %d, they are not matched!", cName, moduleName, @@ -1768,7 +1789,7 @@ public class CollectPCDAction { break; case UINT32: if (maxDatumSize != 4) { - exceptionString = String.format("In FPD file, the datum type of PCD data %s in module %s "+ + exceptionString = String.format("[FPD file error] the datum type of PCD data %s in module %s "+ "is UINT32, but datum size is %d, they are not matched!", cName, moduleName, @@ -1777,7 +1798,7 @@ public class CollectPCDAction { break; case UINT64: if (maxDatumSize != 8) { - exceptionString = String.format("In FPD file, the datum type of PCD data %s in module %s "+ + exceptionString = String.format("[FPD file error] the datum type of PCD data %s in module %s "+ "is UINT64, but datum size is %d, they are not matched!", cName, moduleName, @@ -1786,7 +1807,7 @@ public class CollectPCDAction { break; case BOOLEAN: if (maxDatumSize != 1) { - exceptionString = String.format("In FPD file, the datum type of PCD data %s in module %s "+ + exceptionString = String.format("[FPD file error] the datum type of PCD data %s in module %s "+ "is BOOLEAN, but datum size is %d, they are not matched!", cName, moduleName, @@ -1829,7 +1850,7 @@ public class CollectPCDAction { dynamicInfo = getDynamicInfoFromFPD(token, moduleName); if (dynamicInfo == null) { - exceptionString = String.format("For Dynamic PCD %s used by module %s, "+ + exceptionString = String.format("[FPD file error] For Dynamic PCD %s used by module %s, "+ "there is no dynamic information in "+ "in FPD file, but it is required!", token.cName, @@ -1837,6 +1858,24 @@ public class CollectPCDAction { throw new EntityException(exceptionString); } + token.datumSize = dynamicInfo.getMaxDatumSize(); + + exceptionString = verifyDatumSize(token.cName, moduleName, token.datumSize, token.datumType); + 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 is %d, they are not match!", + token.cName, + moduleName, + maxDatumSize, + dynamicInfo.getMaxDatumSize()); + throw new EntityException(exceptionString); + } + skuInfoList = dynamicInfo.getSkuInfoList(); // @@ -1849,7 +1888,6 @@ public class CollectPCDAction { // temp = skuInfoList.get(index).getSkuId().toString(); skuInstance.id = Integer.decode(temp); - if (skuInstance.id == 0) { hasSkuId0 = true; } @@ -1867,11 +1905,9 @@ public class CollectPCDAction { if (datum != null) { if ((skuInstance.id == 0) && !datum.equalsIgnoreCase(skuInfoList.get(index).getValue())) { - exceptionString = String.format("For dynamic PCD %s, module %s give as %s which is different with "+ - "Sku 0's %s defined in ! Please sync them at first!", - token.cName, - datum, - skuInfoList.get(index).getValue()); + exceptionString = "[FPD file error] For dynamic PCD " + token.cName + ", the value in module is " + datum.toString() + " but the "+ + "value of sku 0 data in is " + skuInstance.value.value + ". They are must be same!"+ + " or you could not define value for a dynamic PCD in every !"; throw new EntityException(exceptionString); } } @@ -1884,7 +1920,7 @@ public class CollectPCDAction { if (skuInfoList.get(index).getVariableName() != null) { exceptionString = null; if (skuInfoList.get(index).getVariableGuid() == null) { - exceptionString = String.format("For dynamic PCD %s in section in FPD "+ + exceptionString = String.format("[FPD file error] For dynamic PCD %s in section in FPD "+ "file, who use HII, but there is no defined for Sku %d data!", token.cName, index); @@ -1892,14 +1928,14 @@ public class CollectPCDAction { } if (skuInfoList.get(index).getVariableOffset() == null) { - exceptionString = String.format("For dynamic PCD %s in section in FPD "+ + exceptionString = String.format("[FPD file error] For dynamic PCD %s in section in FPD "+ "file, who use HII, but there is no defined for Sku %d data!", token.cName, index); } if (skuInfoList.get(index).getHiiDefaultValue() == null) { - exceptionString = String.format("For dynamic PCD %s in section in FPD "+ + exceptionString = String.format("[FPD file error] For dynamic PCD %s in section in FPD "+ "file, who use HII, but there is no defined for Sku %d data!", token.cName, index); @@ -1910,7 +1946,7 @@ public class CollectPCDAction { } offset = Integer.decode(skuInfoList.get(index).getVariableOffset()); if (offset > 0xFFFF) { - throw new EntityException(String.format("For dynamic PCD %s , the variable offset defined in sku %d data "+ + 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)); @@ -1930,16 +1966,17 @@ public class CollectPCDAction { continue; } - exceptionString = String.format("For dynamic PCD %s, the dynamic info must "+ + 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("For dynamic PCD %s in , there are "+ + exceptionString = String.format("[FPD file error] For dynamic PCD %s in , there are "+ "no sku id = 0 data, which is required for every dynamic PCD", token.cName); + throw new EntityException(exceptionString); } return token; @@ -1989,7 +2026,7 @@ public class CollectPCDAction { if ((uuidString.charAt(0) == '0') && ((uuidString.charAt(1) == 'x') || (uuidString.charAt(1) == 'X'))) { splitStringArray = uuidString.split("," ); if (splitStringArray.length != 11) { - throw new EntityException ("Wrong format for UUID string: " + uuidString); + throw new EntityException ("[FPD file error] Wrong format for UUID string: " + uuidString); } //