From e284b218a7c52b666082fc552a21fc03b13459c1 Mon Sep 17 00:00:00 2001 From: Martin Guy Date: Sun, 31 Mar 2013 04:07:38 +0000 Subject: arch/avr32: Fix download of header files This patch fixes the download of the avr32 headers in crosstool-ng by fetching them directly from Atmel's web site instead of the now-broken URL given by the original author of the avr32-header-fetching modification, who fetched them from a copy on his own, now-defunct server. It also adds the necessary logic to extract from a zip file, as that is how the headers are packaged. To configure it for avr32 after launching ct-ng menuconfig in an empty directory: Paths and misc options -> Shell to use as CONFIG_SHELL = sh Target options -> Target Architecture = avr32 Toolchain options -> Tuple's alias = avr32 Binary utilities -> binutils version = 2.18a C compiler gcc version = 4.2.2 C-library newlib version = 1.17.0 Enable IOs on long long = yes Enable IOs on floats and doubles = yes Disable the syscalls supplied with newlib = yes CONFIG_SHELL is necessary to get round the "fragment: command not found" bug when binutils-2.18 is configured using bash. Prepared against crosstool-ng mercurial trunk on 31 March 2012. Signed-off-by: Martin Guy [yann.morin.1998@free.fr: update bundles sample accordingly] Signed-off-by: "Yann E. MORIN" Message-Id: Patchwork-Id: 232612 diff --git a/samples/avr32-unknown-none/crosstool.config b/samples/avr32-unknown-none/crosstool.config index 508dbd0..aed5349 100644 --- a/samples/avr32-unknown-none/crosstool.config +++ b/samples/avr32-unknown-none/crosstool.config @@ -1,4 +1,3 @@ -CT_EXPERIMENTAL=y CT_LOCAL_TARBALLS_DIR="${HOME}/src" CT_SAVE_TARBALLS=y CT_CONFIG_SHELL_SH=y @@ -7,3 +6,6 @@ CT_ARCH_avr32=y CT_BINUTILS_V_2_18a=y CT_CC_V_4_2_2=y CT_LIBC_NEWLIB_V_1_17_0=y +CT_LIBC_NEWLIB_IO_LL=y +CT_LIBC_NEWLIB_IO_FLOAT=y +CT_LIBC_NEWLIB_DISABLE_SUPPLIED_SYSCALLS=y diff --git a/scripts/build/libc/newlib.sh b/scripts/build/libc/newlib.sh index fe15fe5..068187b 100644 --- a/scripts/build/libc/newlib.sh +++ b/scripts/build/libc/newlib.sh @@ -6,11 +6,10 @@ # do_libc_get() { - local libc_src - local avr32headers_src - - libc_src="ftp://sourceware.org/pub/newlib" - avr32headers_src="http://dev.doredevelopment.dk/avr32-toolchain/sources" + local libc_src="ftp://sourceware.org/pub/newlib" + local avr32headers_src="http://www.atmel.com/Images" + avr32headers_base="avr-headers-3.2.3.970" # used below + local avr32headers_ext=".zip" if [ "${CT_LIBC_NEWLIB_CUSTOM}" = "y" ]; then CT_GetCustom "newlib" "${CT_LIBC_VERSION}" \ @@ -20,7 +19,7 @@ do_libc_get() { fi # ! custom location if [ "${CT_ATMEL_AVR32_HEADERS}" = "y" ]; then - CT_GetFile "avr32headers" ${avr32headers_src} + CT_GetFile ${avr32headers_base} ${avr32headers_ext} ${avr32headers_src} fi } @@ -35,7 +34,9 @@ do_libc_extract() { CT_Patch "newlib" "${CT_LIBC_VERSION}" if [ "${CT_ATMEL_AVR32_HEADERS}" = "y" ]; then - CT_Extract "avr32headers" + # The avr32header zip file extracts to avr32/*.h + # Put that in its directory, the same as normal tarballs + CT_Extract ${avr32headers_base} -d ${CT_SRC_DIR}/${avr32headers_base} fi } @@ -49,8 +50,8 @@ do_libc_start_files() { CT_DoLog EXTRA "Installing Atmel's AVR32 headers" CT_DoExecLog ALL mkdir -p "${CT_PREFIX_DIR}/${CT_TARGET}/include" - CT_DoExecLog ALL cp -r "${CT_SRC_DIR}/avr32headers" \ - "${CT_PREFIX_DIR}/${CT_TARGET}/include/avr32" + CT_DoExecLog ALL cp -r "${CT_SRC_DIR}/${avr32headers_base}/avr32" \ + "${CT_PREFIX_DIR}/${CT_TARGET}/include/" CT_EndStep fi diff --git a/scripts/functions b/scripts/functions index a411820..e6defa8 100644 --- a/scripts/functions +++ b/scripts/functions @@ -523,6 +523,7 @@ CT_DoListTarballExt() { printf ".tar.bz2\n" printf ".tar.gz\n.tgz\n" printf ".tar\n" + printf ".zip\n" } # Get the file name extension of a component @@ -861,7 +862,7 @@ CT_GetGit() { # by the caller, that did a 'cd' into the correct path before calling us # and sets nochdir to 'nochdir'. # Note also that this function handles the git trees! -# Usage: CT_Extract [nochdir] [options] +# Usage: CT_Extract [nochdir] [options] # where 'options' are dependent on the source (eg. git branch/tag...) CT_Extract() { local nochdir="$1" @@ -926,6 +927,7 @@ CT_Extract() { .tar.bz2) bzip2 -dc "${full_file}" | CT_DoExecLog FILE tar "${tar_opts[@]}" -f -;; .tar.gz|.tgz) gzip -dc "${full_file}" | CT_DoExecLog FILE tar "${tar_opts[@]}" -f -;; .tar) CT_DoExecLog FILE tar "${tar_opts[@]}" -f "${full_file}";; + .zip) CT_DoExecLog FILE unzip "${@}" "${full_file}";; /.git) CT_ExtractGit "${basename}" "${@}";; *) CT_DoLog WARN "Don't know how to handle '${basename}${ext}': unknown extension" return 1 -- cgit v0.10.2-6-g49f6