mirror of
https://github.com/trezor/trezor-firmware.git
synced 2024-12-28 00:58:09 +00:00
46 lines
1.4 KiB
Python
Executable File
46 lines
1.4 KiB
Python
Executable File
#!/usr/bin/env python3
|
|
import json
|
|
|
|
import click
|
|
|
|
from trezorlib import firmware
|
|
|
|
|
|
def minimum_header_len(spec):
|
|
spec = spec.copy()
|
|
spec["header_len"] = 512000
|
|
reparsed = firmware.VendorHeader.parse(firmware.VendorHeader.build(spec))
|
|
data_length = reparsed._end_offset - reparsed._start_offset
|
|
# data length + 65 for signatures, rounded up to nearest multiple of 512
|
|
return (data_length + 65 + 511) // 512 * 512
|
|
|
|
|
|
@click.command()
|
|
@click.argument("specfile", type=click.File("r"))
|
|
@click.argument("image", type=click.File("rb"))
|
|
@click.argument("outfile", type=click.File("wb"))
|
|
def build_vendorheader(specfile, image, outfile):
|
|
spec = json.load(specfile)
|
|
spec["pubkeys"] = [bytes.fromhex(k) for k in spec["pubkeys"]]
|
|
spec["image"] = firmware.Toif.parse(image.read())
|
|
spec["sigmask"] = 0
|
|
spec["signature"] = b"\x00" * 64
|
|
|
|
min_length = minimum_header_len(spec)
|
|
if "header_len" not in spec:
|
|
spec["header_len"] = min_length
|
|
elif spec["header_len"] < min_length:
|
|
raise click.ClickException(
|
|
f"Specified header_len {spec['header_len']} too low. "
|
|
f"Minimum allowable value is {min_length}."
|
|
)
|
|
|
|
if spec["header_len"] % 512 != 0:
|
|
raise click.ClickException("Invalid header_len: must be a multiple of 512")
|
|
|
|
outfile.write(firmware.VendorHeader.build(spec))
|
|
|
|
|
|
if __name__ == "__main__":
|
|
build_vendorheader()
|