1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2024-12-23 14:58:09 +00:00
trezor-firmware/core/embed/vendorheader/generate.sh
matejcik 5d9bb0ebfc tools(core): nicer build_vendorheader for manual use
also will show you required header size
2024-04-12 16:13:52 +02:00

47 lines
1.1 KiB
Bash
Executable File

#!/usr/bin/env bash
set -e
cd $(dirname $0)
BUILDVH=$(realpath ../../tools/build_vendorheader)
BINCTL=$(realpath ../../tools/headertool.py)
for arg in "$@"; do
if [ "$arg" == "--check" ]; then
CHECK="--check"
fi
if [ "$arg" == "--quiet" ]; then
QUIET="--quiet"
fi
done
MODELS=(T2T1 T2B1 T3T1 D001 D002)
for MODEL in ${MODELS[@]}; do
cd $MODEL
echo "Generating vendor headers for $MODEL"
# construct all vendor headers
for fn in *.json; do
$BUILDVH $QUIET $CHECK $fn
done
TMPDIR=$(mktemp -d)
trap "rm -rf $TMPDIR" EXIT
# sign dev and QA vendor header
for name in unsafe dev_DO_NOT_SIGN; do
SRC_NAME="vendorheader_${name}_unsigned.bin"
DEST_NAME="vendorheader_${name}_signed_dev.bin"
if [ ! -f "$SRC_NAME" ]; then
continue
fi
cp -a vendorheader_${name}_unsigned.bin "$TMPDIR/$DEST_NAME"
$BINCTL $QUIET -D "$TMPDIR/$DEST_NAME"
if [ -n "$CHECK" ]; then
diff "$DEST_NAME" "$TMPDIR/$DEST_NAME"
fi
cp -a "$TMPDIR/$DEST_NAME" "$DEST_NAME"
done
cd ..
done