BZ:https://bugzilla.tianocore.org/show_bug.cgi?id=1784
BZ:https://bugzilla.tianocore.org/show_bug.cgi?id=1785

Need extend the options in the Intel/build_bios.py file
to support Binary Cache.

 --hash:
   Enable hash-based caching during build process.
 --binary-destination:
   Generate a cache of binary files in the specified directory.
 --binary-source:
   Consume a cache of binary files from the specified directory.

Cc: Liming Gao <liming....@intel.com>
Cc: Bob Feng <bob.c.f...@intel.com>
Cc: Steven Shi <steven....@intel.com>
Cc: Shifei A Lu <shifei.a...@intel.com>
Cc: Xiaohu Zhou <bowen.z...@intel.com>
Cc: Isaac W Oram <isaac.w.o...@intel.com>
Cc: Chasel Chiu <chasel.c...@intel.com>
Cc: Michael Kubacki <michael.a.kuba...@intel.com>
Cc: Nate DeSimone <nathaniel.l.desim...@intel.com>
Signed-off-by: Zhiju.Fan <zhijux....@intel.com>
---
 Platform/Intel/build_bios.py | 27 +++++++++++++++++++++++++++
 1 file changed, 27 insertions(+)

diff --git a/Platform/Intel/build_bios.py b/Platform/Intel/build_bios.py
index 9f8d78f6e8..628b127417 100644
--- a/Platform/Intel/build_bios.py
+++ b/Platform/Intel/build_bios.py
@@ -333,6 +333,7 @@ def build(config):
     print(" SILENT_MODE    = ", config.get("SILENT_MODE"))
     print(" REBUILD_MODE   = ", config.get("REBUILD_MODE"))
     print(" BUILD_ROM_ONLY = ", config.get("BUILD_ROM_ONLY"))
+    print(" BINARY_CACHE_CMD_LINE = ", config.get("HASH"), 
config.get("BINARY_CACHE_CMD_LINE"))
     print("==========================================")
 
     command = ["build", "-n", config["NUMBER_OF_PROCESSORS"]]
@@ -343,6 +344,10 @@ def build(config):
     if config["EXT_BUILD_FLAGS"] and config["EXT_BUILD_FLAGS"] != "":
         command.append(config["EXT_BUILD_FLAGS"])
 
+    if config.get('BINARY_CACHE_CMD_LINE'):
+        command.append(config['HASH'])
+        command.append(config['BINARY_CACHE_CMD_LINE'])
+
     if config.get("SILENT_MODE", "FALSE") == "TRUE":
         command.append("--silent")
         command.append("--quiet")
@@ -848,6 +853,17 @@ def get_cmd_config_arguments(arguments):
     if arguments.fspapi is True:
         result["API_MODE_FSP_WRAPPER_BUILD"] = "TRUE"
 
+    if not arguments.UseHashCache:
+        result['BINARY_CACHE_CMD_LINE'] = ''
+    elif arguments.BinCacheDest:
+        result['HASH'] = '--hash'
+        result['BINARY_CACHE_CMD_LINE'] = '--binary-destination=%s' % 
arguments.BinCacheDest
+    elif arguments.BinCacheSource:
+        result['HASH'] = '--hash'
+        result['BINARY_CACHE_CMD_LINE'] = '--binary-source=%s' % 
arguments.BinCacheSource
+    else:
+        result['BINARY_CACHE_CMD_LINE'] = ''
+
     return result
 
 
@@ -924,6 +940,17 @@ def get_cmd_arguments(build_config):
     parser.add_argument("--fspapi", help="API mode fsp wrapper build enabled",
                         action='store_true', dest="fspapi")
 
+    parser.add_argument("--hash", action="store_true", dest="UseHashCache", 
default=False,
+                        help="Enable hash-based caching during build process.")
+
+    parser.add_argument("--binary-destination", help="Generate a cache of 
binary \
+                            files in the specified directory.",
+                        action='store', dest="BinCacheDest")
+
+    parser.add_argument("--binary-source", help="Consume a cache of binary 
files \
+                                from the specified directory.",
+                        action='store', dest="BinCacheSource")
+
     return parser.parse_args()
 
 
-- 
2.14.1.windows.1


-=-=-=-=-=-=-=-=-=-=-=-
Groups.io Links: You receive all messages sent to this group.

View/Reply Online (#41698): https://edk2.groups.io/g/devel/message/41698
Mute This Topic: https://groups.io/mt/31875862/21656
Group Owner: devel+ow...@edk2.groups.io
Unsubscribe: https://edk2.groups.io/g/devel/unsub  [arch...@mail-archive.com]
-=-=-=-=-=-=-=-=-=-=-=-

<<attachment: winmail.dat>>

Reply via email to