diff options
author | Tao Bao <tbao@google.com> | 2015-04-01 17:15:29 +0000 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2015-04-01 17:15:29 +0000 |
commit | 93d46584170a9aae1728cdb9010eef41e25b4d4a (patch) | |
tree | d0c3a16544811fe660ff057175e619702fb8147b /tools/releasetools | |
parent | 320d976429f0f08b9954edca13930442f63300a8 (diff) | |
parent | ae26f5b002de956d495c4019b365040490ff18dd (diff) | |
download | build-93d46584170a9aae1728cdb9010eef41e25b4d4a.zip build-93d46584170a9aae1728cdb9010eef41e25b4d4a.tar.gz build-93d46584170a9aae1728cdb9010eef41e25b4d4a.tar.bz2 |
am ae26f5b0: am 53602955: Merge "Add support to sign bootable images with vboot_signer"
* commit 'ae26f5b002de956d495c4019b365040490ff18dd':
Add support to sign bootable images with vboot_signer
Diffstat (limited to 'tools/releasetools')
-rw-r--r-- | tools/releasetools/common.py | 22 |
1 files changed, 20 insertions, 2 deletions
diff --git a/tools/releasetools/common.py b/tools/releasetools/common.py index f76f812..6a5d22f 100644 --- a/tools/releasetools/common.py +++ b/tools/releasetools/common.py @@ -346,8 +346,14 @@ def BuildBootableImage(sourcedir, fs_config_file, info_dict=None): if args and args.strip(): cmd.extend(shlex.split(args)) - cmd.extend(["--ramdisk", ramdisk_img.name, - "--output", img.name]) + img_unsigned = None + if info_dict.get("vboot", None): + img_unsigned = tempfile.NamedTemporaryFile() + cmd.extend(["--ramdisk", ramdisk_img.name, + "--output", img_unsigned.name]) + else: + cmd.extend(["--ramdisk", ramdisk_img.name, + "--output", img.name]) p = Run(cmd, stdout=subprocess.PIPE) p.communicate() @@ -362,6 +368,18 @@ def BuildBootableImage(sourcedir, fs_config_file, info_dict=None): p.communicate() assert p.returncode == 0, "boot_signer of %s image failed" % path + # Sign the image if vboot is non-empty. + elif info_dict.get("vboot", None): + path = "/" + os.path.basename(sourcedir).lower() + img_keyblock = tempfile.NamedTemporaryFile() + cmd = [info_dict["vboot_signer_cmd"], info_dict["futility"], + img_unsigned.name, info_dict["vboot_key"] + ".vbpubk", + info_dict["vboot_key"] + ".vbprivk", img_keyblock.name, + img.name] + p = Run(cmd, stdout=subprocess.PIPE) + p.communicate() + assert p.returncode == 0, "vboot_signer of %s image failed" % path + img.seek(os.SEEK_SET, 0) data = img.read() |