313 lines
11 KiB
Bash
Executable File
313 lines
11 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
# Yocto ADT Installer
|
|
#
|
|
# Copyright 2010-2011 by Intel Corp.
|
|
#
|
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
# of this software and associated documentation files (the "Software"), to deal
|
|
# in the Software without restriction, including without limitation the rights
|
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
# copies of the Software, and to permit persons to whom the Software is
|
|
# furnished to do so, subject to the following conditions:
|
|
|
|
# The above copyright notice and this permission notice shall be included in
|
|
# all copies or substantial portions of the Software.
|
|
|
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
# THE SOFTWARE.
|
|
|
|
parse_config()
|
|
{
|
|
INST_ARCH=`uname -m`
|
|
|
|
case $INST_ARCH in
|
|
i[3-6]86)
|
|
OPKG_CONFIG_FILE=$YOCTOADT_OPKG_CONF_FILE_32
|
|
OECORE_NATIVE_SYSROOT="$INSTALL_FOLDER/sysroots/$INST_ARCH$SDK_VENDOR-linux/"
|
|
;;
|
|
x86_64)
|
|
OPKG_CONFIG_FILE=$YOCTOADT_OPKG_CONF_FILE_64
|
|
OECORE_NATIVE_SYSROOT="$INSTALL_FOLDER/sysroots/x86_64$SDK_VENDOR-linux/"
|
|
;;
|
|
*)
|
|
echo_info "[ADT_INST] Error: Installation Machine is not supported!"
|
|
exit -1
|
|
;;
|
|
esac
|
|
}
|
|
|
|
get_sudo_app()
|
|
{
|
|
username=$(id -nu)
|
|
|
|
# find the owner of the parent
|
|
dir=$1
|
|
while [ 1 ]; do
|
|
if [ -d $dir ]; then
|
|
owner=$(stat -c %U $dir)
|
|
break
|
|
else
|
|
dir=$(dirname $dir)
|
|
fi
|
|
done
|
|
|
|
if [ "$owner" = "$username" ]; then
|
|
true
|
|
else
|
|
echo sudo
|
|
fi
|
|
}
|
|
|
|
# this function accepts arch_type (x86, x86_64, arm, ppc, mips) as the first
|
|
# argument, returning the location of the target rootfs
|
|
get_target_rootfs_location() {
|
|
[ -z "$1" ] && return
|
|
|
|
arch_type=$1
|
|
# rootfs extraction directory
|
|
target_sysroot_var="\$YOCTOADT_TARGET_SYSROOT_LOC_$arch_type"
|
|
target_sysroot=`eval echo $target_sysroot_var`
|
|
|
|
if [ "$target_sysroot" == "" ]; then
|
|
return
|
|
else
|
|
echo "`readlink -m $target_sysroot`"
|
|
fi
|
|
}
|
|
|
|
|
|
#let us install a qemu-native firstly
|
|
#installation step 2
|
|
install_native_sdk()
|
|
{
|
|
|
|
echo_info "\nStart installing selected native ADT for archs: $YOCTOADT_TARGETS..."
|
|
|
|
# where the packages are installed.
|
|
NATIVE_INSTALL_DIR=$INSTALL_FOLDER
|
|
|
|
if [ -d "$INSTALL_FOLDER" ]; then
|
|
echo_info "\nNative ADT installation directory \"$INSTALL_FOLDER\" already exists! Continue installation will override its contents!"
|
|
confirm_install $1
|
|
fi
|
|
|
|
#Now begin to install native sdk and extract qemu rootfs which needs privilege rights
|
|
#depending on the install location
|
|
SUDO=$(get_sudo_app $NATIVE_INSTALL_DIR)
|
|
if [ -n "$SUDO" ]; then
|
|
echo_info "#######################################################################"
|
|
echo_info "Please note from this point on installation requires sudo password ..."
|
|
echo_info "#######################################################################"
|
|
fi
|
|
|
|
#we need to make this directory firstly since opkg need to use it.
|
|
OPKG_LOCK_DIR="$NATIVE_INSTALL_DIR/$OPKG_LIBDIR/opkg"
|
|
if [ ! -d "$OPKG_LOCK_DIR" ]; then
|
|
$SUDO mkdir -p $OPKG_LOCK_DIR
|
|
echo_info "Successfully create directory $OPKG_LOCK_DIR. "
|
|
#if user delete /opt/xxx, while dangling folders there, report error
|
|
elif [ ! -d "$INSTALL_FOLDER" ]; then
|
|
echo_info "\nDangling opkg cache folder $OPKG_LOCK_DIR detected. Continue installation will remove the folder!"
|
|
confirm_install $1
|
|
$SUDO rm -rf $OPKG_LOCK_DIR
|
|
$SUDO mkdir -p $OPKG_LOCK_DIR
|
|
#if user are updating installing, just let him/her go, give her/him prompt
|
|
else
|
|
echo_info "ADT has already been installed. Will update its contents..."
|
|
fi
|
|
|
|
#first update repository
|
|
if [ "x$SUDO" = "x" ]; then
|
|
OPKG_CMD="$LOCAL_OPKG_LOC/bin/opkg"
|
|
else
|
|
OPKG_CMD="sudo -E $LOCAL_OPKG_LOC/bin/opkg"
|
|
fi
|
|
|
|
echo_info "Updating opkg..."
|
|
$OPKG_CMD -f $OPKG_CONFIG_FILE -o $NATIVE_INSTALL_DIR update &>> $YOCTOADT_INSTALL_LOG_FILE
|
|
check_result
|
|
echo_info "opkg update process ended..."
|
|
|
|
#install below must sdk-host packages
|
|
OPKG_INSTALL_CMD="$OPKG_CMD "
|
|
OPKG_INSTALL_NATIVE_CMD="$OPKG_INSTALL_CMD --force-overwrite -f $OPKG_CONFIG_FILE -o $NATIVE_INSTALL_DIR install"
|
|
|
|
BASE_HOSTSDK_PKGNAMES="pseudo opkg pkgconfig libtool autoconf automake"
|
|
for pkg in $BASE_HOSTSDK_PKGNAMES; do
|
|
echo_info "Installing ${pkg} nativesdk ...\n"
|
|
$OPKG_INSTALL_NATIVE_CMD nativesdk-${pkg} &>> $YOCTOADT_INSTALL_LOG_FILE
|
|
check_result
|
|
done
|
|
|
|
for target_type in $YOCTOADT_TARGETS; do
|
|
machine_var="\$YOCTOADT_TARGET_MACHINE_$target_type"
|
|
machine=`eval echo $machine_var`
|
|
echo_info "Installing cross canadian packages for $machine ..."
|
|
$OPKG_INSTALL_NATIVE_CMD packagegroup-cross-canadian-$machine &>> $YOCTOADT_INSTALL_LOG_FILE
|
|
check_result
|
|
|
|
target_sysroot=`get_target_rootfs_location $target_type`
|
|
[ -z "$target_sysroot" ] && continue
|
|
|
|
# get the environment setup script paths: original (the one before relocation)
|
|
# and relocated
|
|
env_script_original=`$OPKG_CMD -f $OPKG_CONFIG_FILE -o $NATIVE_INSTALL_DIR files meta-environment-$machine|\
|
|
grep environment-setup`
|
|
env_script_relocated=$INSTALL_FOLDER/${env_script_original##*/}
|
|
|
|
# opkg will not install packagegroup-cross-canadian package if it was already
|
|
# installed. So, the environment script is in one place or the other.
|
|
[ -e "$INSTALL_FOLDER/$env_script_original" ] && env_script=$INSTALL_FOLDER/$env_script_original
|
|
[ -e "$env_script_original" ] && env_script=$env_script_original
|
|
[ -e "$env_script_relocated" ] && env_script=$env_script_relocated
|
|
|
|
$SUDO sed -i -e "s%SDKTARGETSYSROOT=.*%SDKTARGETSYSROOT=$target_sysroot%g" $env_script
|
|
done
|
|
|
|
if [ "$YOCTOADT_QEMU" == "Y" ] || [ "$YOCTOADT_QEMU" == "y" ]; then
|
|
echo_info "\nInstalling qemu native ..."
|
|
$OPKG_INSTALL_NATIVE_CMD nativesdk-qemu &>> $YOCTOADT_INSTALL_LOG_FILE
|
|
check_result
|
|
$OPKG_INSTALL_NATIVE_CMD nativesdk-qemu-helper &>> $YOCTOADT_INSTALL_LOG_FILE
|
|
check_result
|
|
fi
|
|
|
|
if [ "$YOCTOADT_NFS_UTIL" == "Y" ] || [ "$YOCTOADT_NFS_UTIL" == "y" ]; then
|
|
echo_info "\nInstalling unfs ..."
|
|
$OPKG_INSTALL_NATIVE_CMD nativesdk-unfs3 &>> $YOCTOADT_INSTALL_LOG_FILE
|
|
check_result
|
|
fi
|
|
|
|
# Lose the ./opt/${DISTRO}/${SDK_VERSION} part, we don't really need to keep
|
|
# the entire directory structure. We could patch opkg to do that but it's far
|
|
# simpler to do that here and achieve the same result.
|
|
# This is done in two steps:
|
|
if [ -d $NATIVE_INSTALL_DIR/$DEFAULT_INSTALL_FOLDER ]; then
|
|
# Step 1: copy ./opt/${DISTRO}/${SDK_VERSION} contents to $NATIVE_INSTALL_DIR.
|
|
# We cannot use move if $NATIVE_INSTALL_DIR is not empty (for example: contains
|
|
# another SDK)
|
|
$SUDO cp -r $NATIVE_INSTALL_DIR/$DEFAULT_INSTALL_FOLDER/* $NATIVE_INSTALL_DIR
|
|
|
|
# delete the source directory now
|
|
$SUDO rm -rf $NATIVE_INSTALL_DIR/$DEFAULT_INSTALL_FOLDER/*
|
|
|
|
# Step 2: Delete the ./opt/${DISTRO}/${SDK_VERSION} directories too, they should be empty
|
|
dir=$NATIVE_INSTALL_DIR/$DEFAULT_INSTALL_FOLDER
|
|
while [ "$dir" != "$NATIVE_INSTALL_DIR" ]; do
|
|
# if the user chose / as the install folder, then we should leave /opt in place
|
|
if [ "$dir" = "/opt" ]; then
|
|
break
|
|
fi
|
|
|
|
# try to delete the directory, only if it's empty
|
|
$SUDO rmdir $dir
|
|
if [ $? -ne 0 ]; then
|
|
break
|
|
fi
|
|
|
|
# go to the next directory
|
|
dir=$(dirname $dir)
|
|
done
|
|
# Step 3: Rewrite the *.list files to contain the correct paths
|
|
$SUDO find $NATIVE_INSTALL_DIR/var/lib/opkg -type f -exec sed -i -e '#^$DEFAULT_INSTALL_FOLDER#$NATIVE_INSTALL_DIR#' {} \;
|
|
fi
|
|
|
|
# Link the ld.so.cache file into the hosts filesystem
|
|
if [ ! -f "$OECORE_NATIVE_SYSROOT/etc/ld.so.cache" ]; then
|
|
echo_info "Link the ld.so.cache file into the host filesystem"
|
|
$SUDO ln -s /etc/ld.so.cache $OECORE_NATIVE_SYSROOT/etc/ld.so.cache
|
|
check_result
|
|
fi
|
|
|
|
# relocate binaries
|
|
echo_info "\nRelocating binaries ..."
|
|
escaped_sdkpath=$(echo $DEFAULT_INSTALL_FOLDER |sed -e "s:[\+\.]:\\\\\\\\\0:g")
|
|
|
|
# We don't change the script in-place since we may want the user to re-run
|
|
# adt-installer script
|
|
sed -e "s:##DEFAULT_INSTALL_DIR##:$escaped_sdkpath:" scripts/relocate_sdk.py > scripts/relocate_sdk_tmp.py
|
|
chmod +x scripts/relocate_sdk_tmp.py
|
|
|
|
dl_path=$(find $OECORE_NATIVE_SYSROOT/lib -name "ld-linux*")
|
|
executable_files=$(find $OECORE_NATIVE_SYSROOT -type f -perm /111)
|
|
|
|
$SUDO scripts/relocate_sdk_tmp.py $INSTALL_FOLDER $dl_path $executable_files
|
|
check_result
|
|
|
|
# replace /opt/${DISTRO}/${SDK_VERSION} with the install folder in all configs
|
|
env_setup_script=$(find $NATIVE_INSTALL_DIR/ -name "environment-setup-*")
|
|
$SUDO sed -i -e "s:$DEFAULT_INSTALL_FOLDER:$NATIVE_INSTALL_DIR:g" $env_setup_script
|
|
|
|
find $OECORE_NATIVE_SYSROOT -type f -exec file '{}' \; | grep ":.*\(ASCII\|script\|source\).*text" | \
|
|
cut -d':' -f1 | xargs $SUDO sed -i -e "s:$DEFAULT_INSTALL_FOLDER:$NATIVE_INSTALL_DIR:g"
|
|
|
|
# change all symlinks pointing to /opt/${DISTRO}/${SDK_VERSION}
|
|
for l in $(find $NATIVE_INSTALL_DIR -type l); do
|
|
$SUDO ln -sfn $(readlink $l|sed -e "s:$DEFAULT_INSTALL_FOLDER:$NATIVE_INSTALL_DIR:") $l
|
|
done
|
|
|
|
# find out all perl scripts in $OECORE_NATIVE_SYSROOT and modify them
|
|
# replacing the host perl with SDK perl.
|
|
for perl_script in $($SUDO grep -m 1 "^#!.*perl" -rl $OECORE_NATIVE_SYSROOT); do
|
|
$SUDO sed -i -e "s:^#! */usr/bin/perl.*:#! /usr/bin/env perl:g" -e \
|
|
"s: /usr/bin/perl: /usr/bin/env perl:g" $perl_script
|
|
done
|
|
|
|
echo_info "\nSuccessfully installed selected native ADT!"
|
|
}
|
|
|
|
#Need three input params, $1 -- arch_type(arm powerpc x86 mips) #2 -- user installation type
|
|
#customer or scilent
|
|
|
|
install_target()
|
|
{
|
|
|
|
target_sysroot=`get_target_rootfs_location $1`
|
|
[ -z "$target_sysroot" ] && return 0
|
|
|
|
target_sysroot_image_var="\$YOCTOADT_TARGET_SYSROOT_IMAGE_$1"
|
|
target_sysroot_image=`eval echo $target_sysroot_image_var`
|
|
if [ "$target_sysroot_image" == "" ]; then
|
|
echo_info "[ADT_INST] Error: YOCTOADT_TARGET_SYSROOT_IMAGE_$1 selection is empty, failed to create target sysroot!"
|
|
return 1
|
|
fi
|
|
|
|
echo_info "Installing target sysroot for arch: $1, rootfs type: $target_sysroot_image, location: $target_sysroot"
|
|
|
|
target_machine_var="\$YOCTOADT_TARGET_MACHINE_$1"
|
|
target_machine=`eval echo $target_machine_var`
|
|
sysroot_image_name="core-image-$target_sysroot_image-$target_machine.tar.bz2"
|
|
#echo_info "Extracting rootfs: $sysroot_image_name, using pseudo..."
|
|
|
|
# sudo password might be needed to install the target sysroot
|
|
SUDO=$(get_sudo_app $target_sysroot)
|
|
|
|
$SUDO scripts/extract_rootfs $sysroot_image_name $target_sysroot $OECORE_NATIVE_SYSROOT $user_inst_type
|
|
check_result
|
|
}
|
|
|
|
|
|
#Main part
|
|
. scripts/data_define
|
|
. scripts/util
|
|
|
|
parse_config
|
|
|
|
#secondly we will start to install native tools
|
|
user_inst_type=$1
|
|
install_native_sdk $user_inst_type
|
|
check_result
|
|
|
|
for arch_type in $YOCTOADT_TARGETS; do
|
|
install_target $arch_type
|
|
check_result
|
|
done
|
|
|
|
|