Skip to content

Staging AVR toolchain 3.6.0 (with 328pb support files) #47

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 25 commits into from
Aug 24, 2018
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
d71745d
Update to AVR toolchain 3.6.0
facchinm Jul 26, 2017
1a6e09b
Avoid applying gcc patches
facchinm Jul 26, 2017
f9bd9e2
Automatically apply patches from atpack file (if present)
facchinm Jul 26, 2017
d0a2ebc
Copy whole ATPack directory if needed
facchinm Dec 6, 2017
1db1ba2
Check for whole extra folder in its actual location
facchinm Dec 6, 2017
fe47b93
Don't show extra resources
facchinm Dec 6, 2017
69fe575
Update to Release 3.6.1
facchinm Dec 6, 2017
3a3682c
TEST: re-enable canadian cross for mingw
facchinm Dec 13, 2017
a7337ad
Fix toolchain crosscompilation with mingw
facchinm Dec 18, 2017
d6fcbba
Remove lto patch from gcc
facchinm Dec 18, 2017
2b7072c
Revert "Remove lto patch from gcc"
facchinm Dec 18, 2017
8107730
Fix lto-wrapper patch
facchinm Dec 18, 2017
76cd6a9
exclude gcc patches (again)
facchinm Dec 18, 2017
fd426b8
Remove gdb patches
facchinm Dec 20, 2017
57d8c67
Update to latest atpack
facchinm Dec 20, 2017
da641da
Add libwinpthread to precompiled dlls
facchinm Dec 20, 2017
68e21e4
Change version to arduino1
facchinm Dec 20, 2017
bccf2d0
Remove Darwin specific LDFLAGS
facchinm Feb 14, 2018
92fe4fd
Uniform build flags with atmel script
facchinm Feb 14, 2018
ab73f84
Restore gdb build
facchinm Feb 15, 2018
befa8cc
Try to cross compile everything
facchinm Feb 14, 2018
aee4cd7
Make sure OSX build uses bash 4+
facchinm Feb 19, 2018
4496a9d
Slightly fix arm crosscompile export
facchinm Feb 19, 2018
5249b87
Merge branch 'master' into staging
facchinm May 22, 2018
9da5600
Update readme to 3.6.1
facchinm Jul 12, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions Readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,9 @@ Therefore, the resulting binaries may differ significantly from Atmel's. And you

Edit the `build.conf` file, currently the only thing worth changing is `AVR_VERSION` on the first line to match whatever the [latest version is](http://distribute.atmel.no/tools/opensource/Atmel-AVR-GNU-Toolchain/).

At time of writing, the latest toolchain available is based on Atmel 3.5.4 version. It contains:
At time of writing, the latest toolchain available is based on Atmel 3.6.1 version. It contains:
- binutils-2.26
- gcc-4.9.2
- gcc-5.4.0
- avr-libc-2.0.0
- gdb-7.8

Expand Down
88 changes: 88 additions & 0 deletions atpack.build.bash
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
#!/bin/bash -ex
# Copyright (c) 2017 Arduino LLC
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.

source build.conf

mkdir -p atpack
cd atpack
rm -rf *
mv ../*.atpack .

mv ${ATMEL_ATMEGA_PACK_FILENAME}.atpack ${ATMEL_ATMEGA_PACK_FILENAME}.zip
unzip ${ATMEL_ATMEGA_PACK_FILENAME}.zip

ALL_FILES=`find ../objdir`

#copy relevant files to the right folders
# 1- copy includes definitions
EXTRA_INCLUDES=`diff -q ../objdir/avr/include/avr ../atpack/include/avr | grep "Only in" | grep atpack | cut -f4 -d" "`
for x in $EXTRA_INCLUDES; do
cp include/avr/${x} ../objdir/avr/include/avr
done

# 2 - compact specs into a single folder
SPECS_FOLDERS=`ls gcc/dev`
mkdir temp
for folder in $SPECS_FOLDERS; do
cp -r gcc/dev/${folder}/* temp/
done

# 3 - find different files (device-specs)
EXTRA_SPECS=`diff -q ../objdir/lib/gcc/avr/${GCC_VERSION}/device-specs/ temp/device-specs | grep "Only in" | grep temp | cut -f4 -d" "`
for x in $EXTRA_SPECS; do
cp temp/device-specs/${x} ../objdir/lib/gcc/avr/${GCC_VERSION}/device-specs/
done

#since https://github.com/gcc-mirror/gcc/commit/21a6b87b86defda10ac903a9cd49e34b1f8ce6fb a lot of devices has specs but avr-libc doesn't support them yet
ALL_DEVICE_SPECS=`ls temp/device-specs`
rm -rf temp/device-specs

EXTRA_LIBS=`diff -r -q ../objdir/avr/lib temp/ | grep "Only in" | grep temp | cut -f4 -d" "`
for x in $EXTRA_LIBS; do
if [ ! -d temp/${x} ]; then
cd temp
LOCATION=`find . | grep ${x}`
cd ..
else
LOCATION=${x}
fi
cp -r temp/${LOCATION} ../objdir/avr/lib/${LOCATION}
done

# 4 - extract the correct includes and add them to io.h
# ARGH! difficult!
for x in $ALL_DEVICE_SPECS; do
DEFINITION=`cat ../objdir/lib/gcc/avr/${GCC_VERSION}/device-specs/${x} | grep __AVR_DEVICE_NAME__ | cut -f1 -d" " | cut -f2 -d"D"`
FANCY_NAME=`cat ../objdir/lib/gcc/avr/${GCC_VERSION}/device-specs/${x} | grep __AVR_DEVICE_NAME__ | cut -f2 -d"="`
LOWERCASE_DEFINITION="${DEFINITION,,}"
HEADER_TEMP="${LOWERCASE_DEFINITION#__avr_atmega}"
HEADER="${HEADER_TEMP%__}"
_DEFINITION="#elif defined (${DEFINITION})"
_HEADER="# include <avr/iom${HEADER}.h>"
if [ "$(grep -c "${DEFINITION}" ../objdir/avr/include/avr/io.h)" == 0 ]; then
NEWFILE=`awk '/iom3000.h/ { print; print "____DEFINITION____"; print "____HEADER____"; next }1' ../objdir/avr/include/avr/io.h | sed "s/____DEFINITION____/$_DEFINITION/g" | sed "s@____HEADER____@$_HEADER@g"`
echo "$NEWFILE" > ../objdir/avr/include/avr/io.h
fi
done

#NEW_ALL_FILES=`find ../objdir`

#echo "NEW FILES ADDED: "
#diff <(echo "$ALL_FILES" ) <(echo "$NEW_ALL_FILES")

cd ..

11 changes: 11 additions & 0 deletions automake-patches/0001-fix-perl-522.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
--- /automake.in 2017-12-18 12:26:59.455263520 +0100
+++ /automake.in 2017-12-18 12:27:21.228596603 +0100
@@ -4110,7 +4110,7 @@
sub substitute_ac_subst_variables ($)
{
my ($text) = @_;
- $text =~ s/\${([^ \t=:+{}]+)}/&substitute_ac_subst_variables_worker ($1)/ge;
+ $text =~ s/\$[{]([^ \t=:+{}]+)}/substitute_ac_subst_variables_worker ($1)/ge;
return $text;
}

4 changes: 2 additions & 2 deletions avr-gcc-patches/0001-gcc-lto-wrapper.patch
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
--- gcc/lto-wrapper.c.orig 2016-06-14 21:13:06.985134945 +0200
+++ gcc/lto-wrapper.c 2016-06-14 21:15:37.825167119 +0200
--- gcc/lto-wrapper.c 2016-08-22 11:19:17.000000000 +0200
+++ gcc/lto-wrapper.c 2017-12-18 12:48:25.685248735 +0100
@@ -594,7 +594,7 @@
filename[p - argv[i]] = '\0';
file_offset = (off_t) loffset;
Expand Down
13 changes: 9 additions & 4 deletions binutils.build.bash
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,10 @@ then
exit 1
fi

if [[ x$CROSS_COMPILE != x ]] ; then
EXTRA_CONFARGS="--host=$OUTPUT_TAG"
fi

cd toolsdir/bin
TOOLS_BIN_PATH=`pwd`
cd -
Expand Down Expand Up @@ -58,12 +62,13 @@ CONFARGS=" \
--disable-werror \
--enable-install-libiberty \
--enable-install-libbfd \
--enable-lto \
--enable-plugins\
--with-pic \
--disable-libdecnumber \
--disable-gdb \
--disable-readline \
--disable-sim \
--target=avr"

CFLAGS="-w -O2 -g0 $CFLAGS" CXXFLAGS="-w -O2 -g0 $CXXFLAGS" LDFLAGS="-s $LDFLAGS" ../binutils/configure $CONFARGS
CFLAGS="-w -O2 -g0 $CFLAGS" CXXFLAGS="-w -O2 -g0 $CXXFLAGS" LDFLAGS="-s $LDFLAGS" ../binutils/configure $CONFARGS $EXTRA_CONFARGS

if [ -z "$MAKE_JOBS" ]; then
MAKE_JOBS="2"
Expand Down
7 changes: 6 additions & 1 deletion build.conf
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
AVR_VERSION=3.5.4
AVR_VERSION=3.6.1
BUILD_NUMBER=arduino2

AVR_SOURCES="http://distribute.atmel.no/tools/opensource/Atmel-AVR-GNU-Toolchain/${AVR_VERSION}"
ATMEL_PACKS_SOURCES="http://packs.download.atmel.com/"
GNU_SOURCES="http://mirror.switch.ch/ftp/mirror/gnu"
MPC_SOURCES="http://www.multiprecision.org/downloads"

Expand All @@ -15,6 +16,10 @@ MPC_SOURCES="http://www.multiprecision.org/downloads"
# MPFR_VERSION=3.0.0
# MPC_VERSION=0.9

ATMEL_ATMEGA_PACK_VERSION=1.2.203
ATMEL_ATMEGA_PACK_FILENAME=Atmel.ATmega_DFP.${ATMEL_ATMEGA_PACK_VERSION}
ATMEL_ATMEGA_PACK_URL=${ATMEL_PACKS_SOURCES}/${ATMEL_ATMEGA_PACK_FILENAME}.atpack

# With any luck, you don't need to edit the below
################################################################################

Expand Down
41 changes: 18 additions & 23 deletions gcc.build.bash
Original file line number Diff line number Diff line change
Expand Up @@ -57,20 +57,20 @@ fi

tar xfv avr-gcc.tar.bz2

pushd gcc
#pushd gcc
#pushd gcc/config/avr/
#sh genopt.sh avr-mcus.def > avr-tables.opt
#cat avr-mcus.def | awk -f genmultilib.awk FORMAT="Makefile" > t-multilib
#popd
pushd gcc
for p in ../../avr-gcc-patches/*.patch
do
echo Applying $p
patch -p1 < $p
done
autoconf
popd
popd
#pushd gcc
#for p in ../../avr-gcc-patches/*.patch
#do
# echo Applying $p
# patch -p1 < $p
#done
#autoconf
#popd
#popd

mv gmp-${GMP_VERSION} gcc/gmp
mv mpfr-${MPFR_VERSION} gcc/mpfr
Expand All @@ -81,32 +81,27 @@ cd objdir
PREFIX=`pwd`
cd -

if [[ x$CROSS_COMPILE != x ]] ; then
EXTRA_CONFARGS="--host=$OUTPUT_TAG"
fi

mkdir -p gcc-build
cd gcc-build

CONFARGS=" \
--enable-fixed-point \
--enable-languages=c,c++ \
--prefix=$PREFIX \
--enable-long-long \
--disable-nls \
--disable-checking \
--disable-libssp \
--disable-libada \
--disable-libada \
--disable-shared \
--enable-lto \
--with-avrlibc=yes \
--with-avrlibc=yes \
--with-dwarf2 \
--disable-doc \
--disable-doc \
--target=avr"

if [ `uname -s` == "Darwin" ]
then
# Use default system libraries (no other Macports libraries)
LDFLAGS="$LDFLAGS -L/usr/lib"
fi

CFLAGS="-w -O2 -g0 $CFLAGS" CXXFLAGS="-w -O2 -g0 $CXXFLAGS" LDFLAGS="-s $LDFLAGS" ../gcc/configure $CONFARGS
CFLAGS="-w -O2 -g0 $CFLAGS" CXXFLAGS="-w -O2 -g0 $CXXFLAGS" LDFLAGS="-s $LDFLAGS" ../gcc/configure $CONFARGS $EXTRA_CONFARGS

if [ -z "$MAKE_JOBS" ]; then
MAKE_JOBS="2"
Expand Down
20 changes: 12 additions & 8 deletions gdb.build.bash
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,10 @@ cd toolsdir/bin
TOOLS_BIN_PATH=`pwd`
cd -

if [[ x$CROSS_COMPILE != x ]] ; then
EXTRA_CONFARGS="--host=$OUTPUT_TAG"
fi

export PATH="$TOOLS_BIN_PATH:$PATH"

if [[ ! -f avr-gdb.tar.bz2 ]] ;
Expand All @@ -36,13 +40,13 @@ fi

tar xfv avr-gdb.tar.bz2

cd gdb
for p in ../avr-gdb-patches/*.patch
do
echo Applying $p
patch -p1 < $p
done
cd -
#cd gdb
#for p in ../avr-gdb-patches/*.patch
#do
# echo Applying $p
# patch -p1 < $p
#done
#cd -

mkdir -p objdir
cd objdir
Expand All @@ -59,7 +63,7 @@ CONFARGS=" \
--disable-binutils \
--target=avr"

CFLAGS="-w -O2 -g0 $CFLAGS" CXXFLAGS="-w -O2 -g0 $CXXFLAGS" LDFLAGS="-s $LDFLAGS" ../gdb/configure $CONFARGS
CFLAGS="-w -O2 -g0 $CFLAGS" CXXFLAGS="-w -O2 -g0 $CXXFLAGS" LDFLAGS="-s $LDFLAGS" ../gdb/configure $CONFARGS $EXTRA_CONFARGS

if [ -z "$MAKE_JOBS" ]; then
MAKE_JOBS="2"
Expand Down
23 changes: 22 additions & 1 deletion package-avr-gcc.bash
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,23 @@ if [[ $CROSS_COMPILE == "mingw" ]] ; then
export CXX="i686-w64-mingw32-g++"
export CROSS_COMPILE_HOST="i686-w64-mingw32"
export TARGET_OS="Windows"
OUTPUT_TAG=i686-w64-mingw32
export OUTPUT_TAG=i686-w64-mingw32

elif [[ $CROSS_COMPILE == "osxcross" ]] ; then

export CC="o32-clang"
export CXX="o32-clang++"
export CROSS_COMPILE_HOST="i386-apple-darwin13"
export TARGET_OS="OSX"
export OUTPUT_TAG=i386-apple-darwin13

elif [[ $CROSS_COMPILE == "arm-cross" ]] ; then

export CC="arm-linux-gnueabihf-gcc"
export CXX="arm-linux-gnueabihf-g++"
export CROSS_COMPILE_HOST="arm-linux-gnueabihf"
export TARGET_OS="LinuxARM"
export OUTPUT_TAG=arm-linux-gnueabihf

elif [[ $OS == "GNU/Linux" ]] ; then

Expand Down Expand Up @@ -83,6 +99,11 @@ rm -rf toolsdir objdir *-build

rm -rf objdir/{info,man,share}

if [[ -f ${ATMEL_ATMEGA_PACK_FILENAME}.atpack ]] ; then
#add extra files from atpack (only if the package is altrady there)
${BASH} ./atpack.build.bash
fi

# if producing a windows build, compress as zip and
# copy *toolchain-precompiled* content to any folder containing a .exe
if [[ ${OUTPUT_TAG} == *"mingw"* ]] ; then
Expand Down
Binary file added toolchain-precompiled/libwinpthread-1.dll
Binary file not shown.
2 changes: 2 additions & 0 deletions tools.bash
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,8 @@ tar xfjv automake-${AUTOMAKE_VERSION}.tar.bz2

cd automake-${AUTOMAKE_VERSION}

patch -p1 < ../automake-patches/0001-fix-perl-522.patch

cp ../config.guess-am-1.11.4 lib/config.guess
./bootstrap

Expand Down