2016-03-08 13:42:20 -06:00
|
|
|
#!/bin/bash
|
|
|
|
## This script is to generate an ONIE installer image based on a file system overload
|
|
|
|
|
2019-07-29 23:07:54 -05:00
|
|
|
## Enable debug output for script
|
|
|
|
set -x -e
|
|
|
|
|
2016-03-08 13:42:20 -06:00
|
|
|
## Read ONIE image related config file
|
2019-07-26 00:06:41 -05:00
|
|
|
|
|
|
|
CONFIGURED_ARCH=$([ -f .arch ] && cat .arch || echo amd64)
|
|
|
|
|
|
|
|
if [[ $CONFIGURED_ARCH == armhf || $CONFIGURED_ARCH == arm64 ]]; then
|
|
|
|
. ./onie-image-${CONFIGURED_ARCH}.conf
|
|
|
|
else
|
|
|
|
. ./onie-image.conf
|
|
|
|
fi
|
|
|
|
|
2016-03-08 13:42:20 -06:00
|
|
|
[ -n "$ONIE_IMAGE_PART_SIZE" ] || {
|
|
|
|
echo "Error: Invalid ONIE_IMAGE_PART_SIZE in onie image config file"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
[ -n "$ONIE_INSTALLER_PAYLOAD" ] || {
|
|
|
|
echo "Error: Invalid ONIE_INSTALLER_PAYLOAD in onie image config file"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
2017-04-05 18:14:41 -05:00
|
|
|
IMAGE_VERSION=$(. functions.sh && sonic_get_version)
|
2016-03-08 13:42:20 -06:00
|
|
|
|
2017-08-27 22:13:38 -05:00
|
|
|
generate_onie_installer_image()
|
|
|
|
{
|
2017-03-29 06:17:49 -05:00
|
|
|
# Copy platform-specific ONIE installer config files where onie-mk-demo.sh expects them
|
|
|
|
rm -rf ./installer/x86_64/platforms/
|
|
|
|
mkdir -p ./installer/x86_64/platforms/
|
|
|
|
for VENDOR in `ls ./device`; do
|
|
|
|
for PLATFORM in `ls ./device/$VENDOR`; do
|
|
|
|
if [ -f ./device/$VENDOR/$PLATFORM/installer.conf ]; then
|
|
|
|
cp ./device/$VENDOR/$PLATFORM/installer.conf ./installer/x86_64/platforms/$PLATFORM
|
|
|
|
fi
|
2017-08-27 22:13:38 -05:00
|
|
|
|
2017-03-29 06:17:49 -05:00
|
|
|
done
|
|
|
|
done
|
|
|
|
|
2016-03-16 01:38:26 -05:00
|
|
|
## Generate an ONIE installer image
|
|
|
|
## Note: Don't leave blank between lines. It is single line command.
|
|
|
|
./onie-mk-demo.sh $TARGET_PLATFORM $TARGET_MACHINE $TARGET_PLATFORM-$TARGET_MACHINE-$ONIEIMAGE_VERSION \
|
2017-04-05 18:14:41 -05:00
|
|
|
installer platform/$TARGET_MACHINE/platform.conf $OUTPUT_ONIE_IMAGE OS $IMAGE_VERSION $ONIE_IMAGE_PART_SIZE \
|
2016-03-16 01:38:26 -05:00
|
|
|
$ONIE_INSTALLER_PAYLOAD
|
2017-08-27 22:13:38 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
if [ "$IMAGE_TYPE" = "onie" ]; then
|
|
|
|
echo "Build ONIE installer"
|
|
|
|
mkdir -p `dirname $OUTPUT_ONIE_IMAGE`
|
|
|
|
sudo rm -f $OUTPUT_ONIE_IMAGE
|
|
|
|
|
|
|
|
generate_onie_installer_image
|
|
|
|
|
|
|
|
## Build a raw partition dump image using the ONIE installer that can be
|
|
|
|
## used to dd' in-lieu of using the onie-nos-installer. Used while migrating
|
|
|
|
## into SONiC from other NOS.
|
|
|
|
elif [ "$IMAGE_TYPE" = "raw" ]; then
|
|
|
|
|
|
|
|
echo "Build RAW image"
|
|
|
|
mkdir -p `dirname $OUTPUT_RAW_IMAGE`
|
|
|
|
sudo rm -f $OUTPUT_RAW_IMAGE
|
|
|
|
|
|
|
|
generate_onie_installer_image
|
|
|
|
|
|
|
|
echo "Creating SONiC raw partition : $OUTPUT_RAW_IMAGE of size $RAW_IMAGE_DISK_SIZE MB"
|
|
|
|
fallocate -l "$RAW_IMAGE_DISK_SIZE"M $OUTPUT_RAW_IMAGE
|
|
|
|
|
2020-04-15 05:57:04 -05:00
|
|
|
# ensure proc is mounted
|
|
|
|
sudo mount proc /proc -t proc || true
|
|
|
|
|
2018-02-07 08:07:01 -06:00
|
|
|
## Generate a partition dump that can be used to 'dd' in-lieu of using the onie-nos-installer
|
2020-04-15 05:57:04 -05:00
|
|
|
## Run the installer
|
2017-08-27 22:13:38 -05:00
|
|
|
## The 'build' install mode of the installer is used to generate this dump.
|
|
|
|
sudo chmod a+x $OUTPUT_ONIE_IMAGE
|
|
|
|
sudo ./$OUTPUT_ONIE_IMAGE
|
|
|
|
|
|
|
|
[ -r $OUTPUT_RAW_IMAGE ] || {
|
|
|
|
echo "Error : $OUTPUT_RAW_IMAGE not generated!"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
|
|
|
gzip $OUTPUT_RAW_IMAGE
|
|
|
|
|
|
|
|
[ -r $OUTPUT_RAW_IMAGE.gz ] || {
|
|
|
|
echo "Error : gzip $OUTPUT_RAW_IMAGE failed!"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
|
|
|
mv $OUTPUT_RAW_IMAGE.gz $OUTPUT_RAW_IMAGE
|
|
|
|
echo "The compressed raw image is in $OUTPUT_RAW_IMAGE"
|
|
|
|
|
2018-11-21 00:32:40 -06:00
|
|
|
elif [ "$IMAGE_TYPE" = "kvm" ]; then
|
|
|
|
|
|
|
|
echo "Build KVM image"
|
|
|
|
KVM_IMAGE_DISK=${OUTPUT_KVM_IMAGE%.gz}
|
|
|
|
sudo rm -f $KVM_IMAGE_DISK $KVM_IMAGE_DISK.gz
|
|
|
|
|
|
|
|
generate_onie_installer_image
|
|
|
|
|
2019-11-23 14:30:22 -06:00
|
|
|
SONIC_USERNAME=$USERNAME PASSWD=$PASSWORD sudo -E ./scripts/build_kvm_image.sh $KVM_IMAGE_DISK $onie_recovery_image $OUTPUT_ONIE_IMAGE $KVM_IMAGE_DISK_SIZE
|
2018-11-21 00:32:40 -06:00
|
|
|
|
2018-11-25 13:33:00 -06:00
|
|
|
if [ $? -ne 0 ]; then
|
|
|
|
echo "Error : build kvm image failed"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2018-11-21 00:32:40 -06:00
|
|
|
[ -r $KVM_IMAGE_DISK ] || {
|
|
|
|
echo "Error : $KVM_IMAGE_DISK not generated!"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
|
|
|
gzip $KVM_IMAGE_DISK
|
|
|
|
|
|
|
|
[ -r $KVM_IMAGE_DISK.gz ] || {
|
|
|
|
echo "Error : gzip $KVM_IMAGE_DISK failed!"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
|
|
|
echo "The compressed kvm image is in $KVM_IMAGE_DISK.gz"
|
|
|
|
|
2016-03-16 01:38:26 -05:00
|
|
|
## Use 'aboot' as target machine category which includes Aboot as bootloader
|
2017-01-29 13:33:33 -06:00
|
|
|
elif [ "$IMAGE_TYPE" = "aboot" ]; then
|
2017-02-05 17:59:59 -06:00
|
|
|
echo "Build Aboot installer"
|
|
|
|
mkdir -p `dirname $OUTPUT_ABOOT_IMAGE`
|
|
|
|
sudo rm -f $OUTPUT_ABOOT_IMAGE
|
|
|
|
sudo rm -f $ABOOT_BOOT_IMAGE
|
|
|
|
## Add main payload
|
|
|
|
cp $ONIE_INSTALLER_PAYLOAD $OUTPUT_ABOOT_IMAGE
|
|
|
|
## Add Aboot boot0 file
|
|
|
|
j2 -f env files/Aboot/boot0.j2 ./onie-image.conf > files/Aboot/boot0
|
2017-04-21 19:23:36 -05:00
|
|
|
sed -i -e "s/%%IMAGE_VERSION%%/$IMAGE_VERSION/g" files/Aboot/boot0
|
2017-02-05 17:59:59 -06:00
|
|
|
pushd files/Aboot && zip -g $OLDPWD/$OUTPUT_ABOOT_IMAGE boot0; popd
|
|
|
|
pushd files/Aboot && zip -g $OLDPWD/$ABOOT_BOOT_IMAGE boot0; popd
|
2020-06-13 02:10:13 -05:00
|
|
|
pushd files/image_config/secureboot && zip -g $OLDPWD/$OUTPUT_ABOOT_IMAGE allowlist_paths.conf; popd
|
2017-04-05 18:14:41 -05:00
|
|
|
echo "$IMAGE_VERSION" >> .imagehash
|
2017-02-05 17:59:59 -06:00
|
|
|
zip -g $OUTPUT_ABOOT_IMAGE .imagehash
|
|
|
|
zip -g $ABOOT_BOOT_IMAGE .imagehash
|
2016-03-16 01:38:26 -05:00
|
|
|
rm .imagehash
|
2017-02-03 18:33:33 -06:00
|
|
|
echo "SWI_VERSION=42.0.0" > version
|
2018-09-05 00:33:50 -05:00
|
|
|
echo "SWI_MAX_HWEPOCH=2" >> version
|
2017-02-08 16:13:44 -06:00
|
|
|
echo "SWI_VARIANT=US" >> version
|
2017-02-05 17:59:59 -06:00
|
|
|
zip -g $OUTPUT_ABOOT_IMAGE version
|
|
|
|
zip -g $ABOOT_BOOT_IMAGE version
|
2017-02-03 18:33:33 -06:00
|
|
|
rm version
|
2017-02-05 17:59:59 -06:00
|
|
|
|
|
|
|
zip -g $OUTPUT_ABOOT_IMAGE $ABOOT_BOOT_IMAGE
|
|
|
|
rm $ABOOT_BOOT_IMAGE
|
2020-06-09 02:25:17 -05:00
|
|
|
if [ "$SONIC_ENABLE_IMAGE_SIGNATURE" = "y" ]; then
|
|
|
|
TARGET_CA_CERT="$TARGET_PATH/ca.cert"
|
|
|
|
rm -f "$TARGET_CA_CERT"
|
2020-06-29 17:01:20 -05:00
|
|
|
|
|
|
|
# If the ca certificate does not exist, the test certificate will be used to sign the image
|
|
|
|
if [ ! -f "$CA_CERT" ]; then
|
|
|
|
TEST_CERT_PATH=files/image_config/secureboot/test-certs
|
|
|
|
CA_CERT="${TEST_CERT_PATH}/ca.cert"
|
|
|
|
SIGNING_KEY="${TEST_CERT_PATH}/signing.key"
|
|
|
|
SIGNING_CERT="${TEST_CERT_PATH}/signing.cert"
|
|
|
|
fi
|
|
|
|
cp "$CA_CERT" "$TARGET_CA_CERT"
|
2020-06-09 02:25:17 -05:00
|
|
|
./scripts/sign_image.sh -i "$OUTPUT_ABOOT_IMAGE" -k "$SIGNING_KEY" -c "$SIGNING_CERT" -a "$TARGET_CA_CERT"
|
|
|
|
fi
|
2016-03-16 01:38:26 -05:00
|
|
|
else
|
2018-11-21 00:32:40 -06:00
|
|
|
echo "Error: Non supported image type $IMAGE_TYPE"
|
2016-03-16 01:38:26 -05:00
|
|
|
exit 1
|
|
|
|
fi
|