Chromium Code Reviews| Index: tools/trusted_cross_toolchains/trusted-toolchain-creator.mipsel.squeeze.sh |
| diff --git a/tools/trusted_cross_toolchains/trusted-toolchain-creator.mipsel.squeeze.sh b/tools/trusted_cross_toolchains/trusted-toolchain-creator.mipsel.squeeze.sh |
| index 8037dd07d779e67754ac54a90f8543b41b10f16f..51d3bed3a488840f7e07283241e0e481dd42da8d 100755 |
| --- a/tools/trusted_cross_toolchains/trusted-toolchain-creator.mipsel.squeeze.sh |
| +++ b/tools/trusted_cross_toolchains/trusted-toolchain-creator.mipsel.squeeze.sh |
| @@ -1,5 +1,5 @@ |
| #!/bin/bash |
| -# Copyright (c) 2012 The Native Client Authors. All rights reserved. |
| +# Copyright (c) 2013 The Native Client Authors. All rights reserved. |
|
Mark Seaborn
2013/03/12 23:13:42
The policy is not to update copyright years any mo
petarj
2013/03/12 23:50:07
Done.
|
| # Use of this source code is governed by a BSD-style license that can be |
| # found in the LICENSE file. |
| # |
| @@ -24,6 +24,8 @@ set -o nounset |
| set -o errexit |
| set -o xtrace |
| +readonly SCRIPT_DIR=$(dirname $0) |
| + |
| readonly MAKE_OPTS="-j8" |
| readonly ARCH="mips32" |
| @@ -54,6 +56,8 @@ readonly PATCH_MIPS32=$(readlink -f ../third_party/qemu/qemu-0.12.5.patch_mips) |
| readonly JAIL_MIPS32=${INSTALL_ROOT}/sysroot |
| +readonly CROSS_TARBALL="chromesdk_linux_mipsel" |
| + |
| # These are simple compiler wrappers to force 32bit builds. |
| readonly CC32=$(readlink -f pnacl/scripts/mygcc32) |
| readonly CXX32=$(readlink -f pnacl/scripts/myg++32) |
| @@ -76,9 +80,10 @@ SubBanner() { |
| Usage() { |
| echo |
| - echo "$0 trusted_sdk" |
| + echo "$0 <nacl_sdk|chrome_sdk>" |
| echo |
| - echo "trusted_sdk - Build everything and package it" |
| + echo "nacl_sdk - Build nacl toolchain and package it" |
| + echo "chrome_sdk - Build chrome toolchain and package it" |
| echo |
| } |
| @@ -183,6 +188,7 @@ SanityCheck() { |
| ClearInstallDir() { |
| Banner "clearing dirs in ${INSTALL_ROOT}" |
| rm -rf ${INSTALL_ROOT}/* |
| + mkdir -p ${JAIL_MIPS32} |
| } |
| ClearBuildDir() { |
| @@ -193,7 +199,7 @@ ClearBuildDir() { |
| CreateTarBall() { |
| local tarball=$1 |
| Banner "creating tar ball ${tarball}" |
| - tar cfz ${tarball}-mips.tgz -C ${INSTALL_ROOT} . |
| + tar cfz ${tarball}.tgz -C ${INSTALL_ROOT} . |
| } |
| @@ -468,52 +474,52 @@ InstallTrustedLinkerScript() { |
| readonly REPO_DEBIAN=http://ftp.debian.org/debian |
| readonly MIPS32_PACKAGES=${REPO_DEBIAN}/dists/squeeze/main/binary-mipsel/Packages.bz2 |
| -readonly TMP_PACKAGELIST_MIPS32=${TMP}/../packagelist_mipsel.tmp |
| - |
| -# These are good enough for native client. |
| -readonly BASE_PACKAGES="\ |
| - libssl0.9.8 \ |
| - libssl-dev \ |
| - libx11-6 \ |
| - libx11-dev \ |
| - x11proto-core-dev \ |
| - libxt6 \ |
| - libxt-dev \ |
| - zlib1g \ |
| - zlib1g-dev \ |
| - libasound2 \ |
| - libasound2-dev \ |
| - libaa1 \ |
| - libaa1-dev \ |
| - libxau-dev \ |
| - libxau6 \ |
| - libxcb1 \ |
| - libxcb1-dev \ |
| - libxcb-render0 \ |
| - libxcb-render0-dev \ |
| - libxcb-render-util0 \ |
| - libxcb-render-util0-dev \ |
| - libxcb-shm0 \ |
| - libxcb-shm0-dev \ |
| - libxdmcp6 \ |
| - libxdmcp-dev \ |
| - libxss1 \ |
| - libxss-dev" |
| +readonly BASE_PACKAGELIST_MIPS32=${SCRIPT_DIR}/packagelist.squeeze.mipsel.base |
| +readonly EXTRA_PACKAGELIST_MIPS32=${SCRIPT_DIR}/packagelist.squeeze.mipsel.extra |
| +readonly TMP_BASE_PACKAGELIST_MIPS32=${TMP}/packagelist.generated.squeeze.mipsel.base |
| +readonly TMP_EXTRA_PACKAGELIST_MIPS32=${TMP}/packagelist.generated.squeeze.mipsel.extra |
| GeneratePackageLists() { |
| - Banner "generating package lists for mips32" |
| - echo -n > ${TMP_PACKAGELIST_MIPS32} |
| + local sdk_target=$1 |
| + local packages= |
| + local TMP_PACKAGELIST= |
| + Banner "generating ${sdk_target} package lists for mips32" |
| DownloadOrCopy ${MIPS32_PACKAGES} |
| bzcat ${TMP}/Packages.bz2\ |
| | egrep '^(Package:|Filename:)' > ${TMP}/Packages_mipsel |
| - for pkg in ${BASE_PACKAGES} ; do |
| + |
| + if [ ${sdk_target} == "nacl_sdk" ] ; then |
| + echo -n > ${TMP_BASE_PACKAGELIST_MIPS32} |
| + TMP_PACKAGELIST=${TMP_BASE_PACKAGELIST_MIPS32} |
| + packages=$(cat ${BASE_PACKAGELIST_MIPS32}) |
| + elif [ ${sdk_target} == "chrome_sdk" ] ; then |
| + echo -n > ${TMP_EXTRA_PACKAGELIST_MIPS32} |
| + TMP_PACKAGELIST=${TMP_EXTRA_PACKAGELIST_MIPS32} |
| + packages=$(cat ${EXTRA_PACKAGELIST_MIPS32}) |
| + else |
| + Banner "ERROR: Packages for \"${sdk_taget}\" not defined." |
| + exit -1 |
| + fi |
| + |
| + for pkg in ${packages} ; do |
| grep -A 1 "${pkg}\$" ${TMP}/Packages_mipsel\ |
| - | egrep -o "pool/.*" >> ${TMP_PACKAGELIST_MIPS32} |
| + | egrep -o "pool/.*" >> ${TMP_PACKAGELIST} |
| done |
| } |
| InstallMissingLibraries() { |
| - readonly DEP_FILES_NEEDED_MIPS32=$(cat ${TMP_PACKAGELIST_MIPS32}) |
| + local sdk_target=$1 |
| + local DEP_FILES_NEEDED_MIPS32= |
| + |
| + if [ ${sdk_target} == "nacl_sdk" ] ; then |
| + DEP_FILES_NEEDED_MIPS32=$(cat ${TMP_BASE_PACKAGELIST_MIPS32}) |
| + elif [ ${sdk_target} == "chrome_sdk" ] ; then |
| + DEP_FILES_NEEDED_MIPS32=$(cat ${TMP_EXTRA_PACKAGELIST_MIPS32}) |
| + else |
| + Banner "ERROR: Target \"${sdk_taget}\" not defined." |
| + exit -1 |
| + fi |
| + |
| for file in ${DEP_FILES_NEEDED_MIPS32} ; do |
| local package="${TMP}/${file##*/}" |
| Banner "installing ${file}" |
| @@ -552,10 +558,24 @@ FixLibs() { |
| rm -f libresolv.so |
| ln -s ../../lib/libresolv.so.2 libresolv.so |
| + rm -f libglib-2.0.so |
| + ln -s ../../lib/libglib-2.0.so.0 libglib-2.0.so |
| + |
| + rm -f libudev.so |
| + ln -s ../../lib/libudev.so.0 libudev.so |
| + |
| + rm -f libcom_err.so |
| + ln -s ../../lib/libcom_err.so.2 libcom_err.so |
| + |
| + rm -f libXdmcp.so |
| + ln -s ../../lib/libXdmcp.so.6 libXdmcp.so |
| + |
| + rm -f libstdc++.so* |
| ln -s ../../../mipsel-linux-gnu/lib/libstdc++.so.6.0.17 . |
| ln -s libstdc++.so.6.0.17 libstdc++.so.6 |
| ln -s libstdc++.so.6.0.17 libstdc++.so |
| + rm -f libgcc_s.so* |
| ln -s ../../../mipsel-linux-gnu/lib/libgcc_s.so.1 . |
| ln -s libgcc_s.so.1 libgcc_s.so |
| } |
| @@ -619,17 +639,21 @@ if [[ $# -eq 0 ]] ; then |
| Usage |
| exit -1 |
| -elif [[ $1 == "trusted_sdk" ]]; then |
| +elif [[ $1 == "nacl_sdk" || $1 == "chrome_sdk" ]] ; then |
| mkdir -p ${TMP} |
| SanityCheck |
| ClearInstallDir |
| ClearBuildDir |
| DownloadOrCopyAndInstallToolchain |
| - GeneratePackageLists |
| - InstallMissingLibraries |
| - InstallTrustedLinkerScript |
| - BuildAndInstallQemu |
| - CreateTarBall $1 |
| + GeneratePackageLists $1 |
| + InstallMissingLibraries $1 |
| + if [[ $1 == "nacl_sdk" ]] ; then |
| + InstallTrustedLinkerScript |
| + BuildAndInstallQemu |
| + CreateTarBall $1 |
| + else |
| + CreateTarBall ${CROSS_TARBALL} |
| + fi |
| else |
| Usage |