BaseTools/BinToPcd: --offset must be 8-byte aligned
authorKinney, Michael D <michael.d.kinney@intel.com>
Sat, 9 Jun 2018 04:15:26 +0000 (21:15 -0700)
committerKinney, Michael D <michael.d.kinney@intel.com>
Thu, 14 Jun 2018 22:43:22 +0000 (15:43 -0700)
https://bugzilla.tianocore.org/show_bug.cgi?id=974
https://bugzilla.tianocore.org/show_bug.cgi?id=965

Update help to state that --offset must be 8-byte aligned.
Verify that --offset is 8-byte aligned and print an error
message if it is not 8-byte aligned.

Cc: Yanyan Sun <yanyan.sun@intel.com>
Cc: Yonghong Zhu <yonghong.zhu@intel.com>
Cc: Liming Gao <liming.gao@intel.com>
Signed-off-by: Michael D Kinney <michael.d.kinney@intel.com>
Contributed-under: TianoCore Contribution Agreement 1.1
Reviewed-by: Yonghong Zhu <yonghong.zhu@intel.com>
BaseTools/Scripts/BinToPcd.py

index 7e33801..54cb844 100644 (file)
@@ -89,7 +89,7 @@ if __name__ == '__main__':
   parser.add_argument("-m", "--max-size", dest = 'MaxSize', type = ValidateUnsignedInteger,\r
                       help = "Maximum size of the PCD.  Ignored with --type HII.")\r
   parser.add_argument("-f", "--offset", dest = 'Offset', type = ValidateUnsignedInteger,\r
-                      help = "VPD offset if --type is VPD.  UEFI Variable offset if --type is HII.")\r
+                      help = "VPD offset if --type is VPD.  UEFI Variable offset if --type is HII.  Must be 8-byte aligned.")\r
   parser.add_argument("-n", "--variable-name", dest = 'VariableName',\r
                       help = "UEFI variable name.  Only used with --type HII.")\r
   parser.add_argument("-g", "--variable-guid", type = ValidateGuidName, dest = 'VariableGuid',\r
@@ -178,6 +178,12 @@ if __name__ == '__main__':
       Pcd = '  %s|*|%d|%s' % (args.PcdName, args.MaxSize, PcdValue)\r
     else:\r
       #\r
+      # --offset value must be 8-byte aligned\r
+      #\r
+      if (args.Offset % 8) != 0:\r
+        print 'BinToPcd: error: argument --offset must be 8-byte aligned.'\r
+        sys.exit()\r
+      #\r
       # Use the --offset value provided.\r
       #\r
       Pcd = '  %s|%d|%d|%s' % (args.PcdName, args.Offset, args.MaxSize, PcdValue)\r
@@ -194,6 +200,12 @@ if __name__ == '__main__':
       # Use UEFI Variable offset of 0 if --offset is not provided\r
       #\r
       args.Offset = 0\r
+    #\r
+    # --offset value must be 8-byte aligned\r
+    #\r
+    if (args.Offset % 8) != 0:\r
+      print 'BinToPcd: error: argument --offset must be 8-byte aligned.'\r
+      sys.exit()\r
     Pcd = '  %s|L"%s"|%s|%d|%s' % (args.PcdName, args.VariableName, args.VariableGuid, args.Offset, PcdValue)\r
     if args.Verbose:\r
       print 'BinToPcd: Convert binary file to PCD statement compatible with PCD sections'\r