2019-07-26 00:06:41 -05:00
|
|
|
#!/bin/sh
|
|
|
|
|
2020-01-23 18:50:17 -06:00
|
|
|
# Copyright (C) Marvell Inc
|
2019-07-26 00:06:41 -05:00
|
|
|
#
|
2020-01-23 18:50:17 -06:00
|
|
|
|
|
|
|
_trap_push() {
|
|
|
|
local next="$1"
|
|
|
|
eval "trap_push() {
|
|
|
|
local oldcmd='$(echo "$next" | sed -e s/\'/\'\\\\\'\'/g)'
|
|
|
|
local newcmd=\"\$1; \$oldcmd\"
|
|
|
|
trap -- \"\$newcmd\" EXIT INT TERM HUP
|
|
|
|
_trap_push \"\$newcmd\"
|
|
|
|
}"
|
|
|
|
}
|
|
|
|
_trap_push true
|
2019-07-26 00:06:41 -05:00
|
|
|
|
|
|
|
set -e
|
|
|
|
|
|
|
|
if [ -d "/etc/sonic" ]; then
|
|
|
|
echo "Installing SONiC in SONiC"
|
|
|
|
install_env="sonic"
|
|
|
|
elif grep -Fxqs "DISTRIB_ID=onie" /etc/lsb-release > /dev/null
|
|
|
|
then
|
|
|
|
echo "Installing SONiC in ONIE"
|
|
|
|
install_env="onie"
|
|
|
|
else
|
|
|
|
echo "Installing SONiC in BUILD"
|
|
|
|
install_env="build"
|
|
|
|
fi
|
|
|
|
|
|
|
|
cd $(dirname $0)
|
|
|
|
if [ -r ./machine.conf ]; then
|
|
|
|
. ./machine.conf
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -r ./onie-image-arm64.conf ]; then
|
|
|
|
. ./onie-image-arm64.conf
|
|
|
|
fi
|
|
|
|
|
2020-01-23 18:50:17 -06:00
|
|
|
echo "ONIE Installer: platform: $platform"
|
2019-07-26 00:06:41 -05:00
|
|
|
|
2020-01-23 18:50:17 -06:00
|
|
|
# Make sure run as root or under 'sudo'
|
|
|
|
if [ $(id -u) -ne 0 ]
|
|
|
|
then echo "Please run as root"
|
|
|
|
exit 1
|
|
|
|
fi
|
2019-07-26 00:06:41 -05:00
|
|
|
|
2020-01-23 18:50:17 -06:00
|
|
|
if [ -r /etc/machine.conf ]; then
|
|
|
|
. /etc/machine.conf
|
|
|
|
elif [ -r /host/machine.conf ]; then
|
|
|
|
. /host/machine.conf
|
|
|
|
elif [ "$install_env" != "build" ]; then
|
|
|
|
echo "cannot find machine.conf"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "onie_platform: $onie_platform"
|
|
|
|
|
|
|
|
# Get platform specific linux kernel command line arguments
|
|
|
|
ONIE_PLATFORM_EXTRA_CMDLINE_LINUX=""
|
|
|
|
|
|
|
|
# Default var/log device size in MB
|
|
|
|
VAR_LOG_SIZE=4096
|
|
|
|
|
|
|
|
[ -r platforms/$onie_platform ] && . platforms/$onie_platform
|
|
|
|
|
|
|
|
|
|
|
|
# If running in ONIE
|
|
|
|
if [ "$install_env" = "onie" ]; then
|
|
|
|
# The onie bin tool prefix
|
|
|
|
onie_bin=
|
|
|
|
# The persistent ONIE directory location
|
|
|
|
onie_root_dir=/mnt/onie-boot/onie
|
|
|
|
# The onie file system root
|
|
|
|
onie_initrd_tmp=/
|
|
|
|
fi
|
|
|
|
|
|
|
|
# The build system prepares this script by replacing %%DEMO-TYPE%%
|
|
|
|
# with "OS" or "DIAG".
|
|
|
|
demo_type="%%DEMO_TYPE%%"
|
|
|
|
|
|
|
|
# The build system prepares this script by replacing %%IMAGE_VERSION%%
|
|
|
|
# with git revision hash as a version identifier
|
|
|
|
image_version="%%IMAGE_VERSION%%"
|
|
|
|
timestamp="$(date -u +%Y%m%d)"
|
|
|
|
|
|
|
|
demo_volume_label="SONiC-${demo_type}"
|
|
|
|
demo_volume_revision_label="SONiC-${demo_type}-${image_version}"
|
2019-07-26 00:06:41 -05:00
|
|
|
|
|
|
|
|
|
|
|
. ./platform.conf
|
|
|
|
|
2020-01-23 18:50:17 -06:00
|
|
|
image_dir="image-$image_version"
|
|
|
|
|
|
|
|
if [ "$install_env" = "onie" ]; then
|
|
|
|
# Create/format the flash
|
|
|
|
create_partition
|
|
|
|
mount_partition
|
|
|
|
elif [ "$install_env" = "sonic" ]; then
|
|
|
|
demo_mnt="/host"
|
2021-04-12 12:48:44 -05:00
|
|
|
# Get current SONiC image (grub/aboot/uboot)
|
|
|
|
eval running_sonic_revision="$(cat /proc/cmdline | sed -n 's/^.*loop=\/*image-\(\S\+\)\/.*$/\1/p')"
|
|
|
|
# Verify SONiC image exists
|
|
|
|
if [ ! -d "$demo_mnt/image-$running_sonic_revision" ]; then
|
|
|
|
echo "ERROR: SONiC installation is corrupted: path $demo_mnt/image-$running_sonic_revision doesn't exist"
|
|
|
|
exit 1
|
|
|
|
fi
|
2020-01-23 18:50:17 -06:00
|
|
|
# Prevent installing existing SONiC if it is running
|
|
|
|
if [ "$image_dir" = "image-$running_sonic_revision" ]; then
|
|
|
|
echo "Not installing SONiC version $running_sonic_revision, as current running SONiC has the same version"
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
# Remove extra SONiC images if any
|
|
|
|
for f in $demo_mnt/image-* ; do
|
|
|
|
if [ -d $f ] && [ "$f" != "$demo_mnt/image-$running_sonic_revision" ] && [ "$f" != "$demo_mnt/$image_dir" ]; then
|
|
|
|
echo "Removing old SONiC installation $f"
|
|
|
|
rm -rf $f
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
2019-07-26 00:06:41 -05:00
|
|
|
|
2020-01-23 18:50:17 -06:00
|
|
|
# Create target directory or clean it up if exists
|
|
|
|
if [ -d $demo_mnt/$image_dir ]; then
|
|
|
|
echo "Directory $demo_mnt/$image_dir/ already exists. Cleaning up..."
|
|
|
|
rm -rf $demo_mnt/$image_dir/*
|
|
|
|
else
|
|
|
|
mkdir $demo_mnt/$image_dir || {
|
|
|
|
echo "Error: Unable to create SONiC directory"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
fi
|
2019-07-26 00:06:41 -05:00
|
|
|
|
2020-01-23 18:50:17 -06:00
|
|
|
# Decompress the file for the file system directly to the partition
|
|
|
|
if [ x"$docker_inram" = x"on" ]; then
|
|
|
|
# when disk is small, keep dockerfs.tar.gz in disk, expand it into ramfs during initrd
|
[Build]: Support to use symbol links for lazy installation targets to reduce the image size (#10923)
Why I did it
Support to use symbol links in platform folder to reduce the image size.
The current solution is to copy each lazy installation targets (xxx.deb files) to each of the folders in the platform folder. The size will keep growing when more and more packages added in the platform folder. For cisco-8000 as an example, the size will be up to 2G, while most of them are duplicate packages in the platform folder.
How I did it
Create a new folder in platform/common, all the deb packages are copied to the folder, any other folders where use the packages are the symbol links to the common folder.
Why platform.tar?
We have implemented a patch for it, see #10775, but the problem is the the onie use really old unzip version, cannot support the symbol links.
The current solution is similar to the PR 10775, but make the platform folder into a tar package, which can be supported by onie. During the installation, the package.tar will be extracted to the original folder and removed.
2022-06-21 00:03:55 -05:00
|
|
|
unzip -o $ONIE_INSTALLER_PAYLOAD -x "platform.tar.gz" -d $demo_mnt/$image_dir
|
2020-01-23 18:50:17 -06:00
|
|
|
else
|
[Build]: Support to use symbol links for lazy installation targets to reduce the image size (#10923)
Why I did it
Support to use symbol links in platform folder to reduce the image size.
The current solution is to copy each lazy installation targets (xxx.deb files) to each of the folders in the platform folder. The size will keep growing when more and more packages added in the platform folder. For cisco-8000 as an example, the size will be up to 2G, while most of them are duplicate packages in the platform folder.
How I did it
Create a new folder in platform/common, all the deb packages are copied to the folder, any other folders where use the packages are the symbol links to the common folder.
Why platform.tar?
We have implemented a patch for it, see #10775, but the problem is the the onie use really old unzip version, cannot support the symbol links.
The current solution is similar to the PR 10775, but make the platform folder into a tar package, which can be supported by onie. During the installation, the package.tar will be extracted to the original folder and removed.
2022-06-21 00:03:55 -05:00
|
|
|
unzip -o $ONIE_INSTALLER_PAYLOAD -x "$FILESYSTEM_DOCKERFS" "platform.tar.gz" -d $demo_mnt/$image_dir
|
2020-01-23 18:50:17 -06:00
|
|
|
|
|
|
|
if [ "$install_env" = "onie" ]; then
|
|
|
|
TAR_EXTRA_OPTION="--numeric-owner"
|
|
|
|
else
|
|
|
|
TAR_EXTRA_OPTION="--numeric-owner --warning=no-timestamp"
|
|
|
|
fi
|
|
|
|
mkdir -p $demo_mnt/$image_dir/$DOCKERFS_DIR
|
|
|
|
unzip -op $ONIE_INSTALLER_PAYLOAD "$FILESYSTEM_DOCKERFS" | tar xz $TAR_EXTRA_OPTION -f - -C $demo_mnt/$image_dir/$DOCKERFS_DIR
|
|
|
|
fi
|
2019-07-26 00:06:41 -05:00
|
|
|
|
[Build]: Support to use symbol links for lazy installation targets to reduce the image size (#10923)
Why I did it
Support to use symbol links in platform folder to reduce the image size.
The current solution is to copy each lazy installation targets (xxx.deb files) to each of the folders in the platform folder. The size will keep growing when more and more packages added in the platform folder. For cisco-8000 as an example, the size will be up to 2G, while most of them are duplicate packages in the platform folder.
How I did it
Create a new folder in platform/common, all the deb packages are copied to the folder, any other folders where use the packages are the symbol links to the common folder.
Why platform.tar?
We have implemented a patch for it, see #10775, but the problem is the the onie use really old unzip version, cannot support the symbol links.
The current solution is similar to the PR 10775, but make the platform folder into a tar package, which can be supported by onie. During the installation, the package.tar will be extracted to the original folder and removed.
2022-06-21 00:03:55 -05:00
|
|
|
mkdir -p $demo_mnt/$image_dir/platform
|
|
|
|
unzip -op $ONIE_INSTALLER_PAYLOAD "platform.tar.gz" | tar xz $TAR_EXTRA_OPTION -f - -C $demo_mnt/$image_dir/platform
|
2019-07-26 00:06:41 -05:00
|
|
|
|
2020-01-23 18:50:17 -06:00
|
|
|
if [ "$install_env" = "onie" ]; then
|
|
|
|
# Store machine description in target file system
|
|
|
|
if [ -f /etc/machine-build.conf ]; then
|
|
|
|
# onie_ variable are generate at runtime.
|
|
|
|
# they are no longer hardcoded in /etc/machine.conf
|
|
|
|
# also remove single quotes around the value
|
|
|
|
set | grep ^onie | sed -e "s/='/=/" -e "s/'$//" > $demo_mnt/machine.conf
|
|
|
|
else
|
|
|
|
cp /etc/machine.conf $demo_mnt
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Update Bootloader Menu with installed image
|
|
|
|
bootloader_menu_config
|
2019-07-26 00:06:41 -05:00
|
|
|
|
|
|
|
# Set NOS mode if available. For manufacturing diag installers, you
|
|
|
|
# probably want to skip this step so that the system remains in ONIE
|
|
|
|
# "installer" mode for installing a true NOS later.
|
|
|
|
if [ -x /bin/onie-nos-mode ] ; then
|
|
|
|
/bin/onie-nos-mode -s
|
|
|
|
fi
|