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);
}
//