X-Git-Url: https://sigrok.org/gitweb/?p=sigrok-util.git;a=blobdiff_plain;f=cross-compile%2Fmingw%2Fsigrok-cross-mingw;h=12783ad19704d761f2bccd6611fdef255fd83860;hp=65887005b859dc334ad399010d79e098feb21c5f;hb=ada172f42ff218e7cc298c755358b5ab55114212;hpb=ca9127e8a89ab220519a66dcc09faaff808b635d diff --git a/cross-compile/mingw/sigrok-cross-mingw b/cross-compile/mingw/sigrok-cross-mingw index 6588700..12783ad 100755 --- a/cross-compile/mingw/sigrok-cross-mingw +++ b/cross-compile/mingw/sigrok-cross-mingw @@ -1,8 +1,8 @@ -#!/bin/bash +#!/bin/sh ## ## This file is part of the sigrok-util project. ## -## Copyright (C) 2013-2014 Uwe Hermann +## Copyright (C) 2013-2017 Uwe Hermann ## ## 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 @@ -15,8 +15,7 @@ ## 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 St, Fifth Floor, Boston, MA 02110-1301 USA +## along with this program; if not, see . ## set -e @@ -33,18 +32,22 @@ PREFIX=$HOME/sr_mingw # The path where to download files to and where to build packages. BUILDDIR=./build +# Edit this to control verbose build output. +# V="V=1 VERBOSE=1" + # Edit this to enable/disable/modify parallel compiles. PARALLEL="-j 2" +# Edit this to enable/disable debug builds. +DEBUG=0 + # You usually don't need to change anything below this line. # ----------------------------------------------------------------------------- -VER_ZADIG=v2.0.1.160 - SF_MIRROR=switch.dl.sourceforge.net -WGET="wget --quiet" +WGET="wget -c --quiet" GIT_CLONE="git clone --depth=1" # ----------------------------------------------------------------------------- @@ -52,18 +55,24 @@ GIT_CLONE="git clone --depth=1" # We need to find tools in the toolchain. export PATH=$MXE/usr/bin:$PATH -TOOLCHAIN_TRIPLET="$TARGET-w64-mingw32.static" +TOOLCHAIN_TRIPLET="$TARGET-w64-mingw32.static.posix" + +CMAKE="$TOOLCHAIN_TRIPLET-cmake" P="$PREFIX/lib/pkgconfig" P2="$MXE/usr/$TOOLCHAIN_TRIPLET/lib/pkgconfig" -C="--host=$TOOLCHAIN_TRIPLET --prefix=$PREFIX" -CM="-DCMAKE_TOOLCHAIN_FILE=$MXE/usr/$TOOLCHAIN_TRIPLET/share/cmake/mxe-conf.cmake" +C="--host=$TOOLCHAIN_TRIPLET --prefix=$PREFIX CPPFLAGS=-D__printf__=__gnu_printf__" L="--disable-shared --enable-static" -if [ $TARGET == "i686" ]; then - export PKG_CONFIG_PATH_i686_w64_mingw32_static="$P:$P2" +if [ $TARGET = "i686" ]; then + export PKG_CONFIG_PATH_i686_w64_mingw32_static_posix="$P:$P2" else - export PKG_CONFIG_PATH_x86_64_w64_mingw32_static="$P:$P2" + export PKG_CONFIG_PATH_x86_64_w64_mingw32_static_posix="$P:$P2" +fi + +if [ $DEBUG = 1 ]; then + # CFLAGS/CXXFLAGS contains "-g" per default for autotools projects. + CM="$CM -DCMAKE_BUILD_TYPE=Debug" fi # Remove build directory contents (if any) and create a new build dir. @@ -76,14 +85,14 @@ cd $BUILDDIR mkdir -p $PREFIX # Cross-compiling Python is highly non-trivial, so we avoid it for now. -# The download below is a repackaged tarball of the official Python 3.2.3 MSI +# The download below is a repackaged tarball of the official Python 3.6.0 EXE # installer for Windows: -# - https://www.python.org/ftp/python/3.2.3/python-3.2.3.msi -# - https://www.python.org/ftp/python/3.2.3/python-3.2.3.amd64.msi -# The MSI file has been installed on a Windows box and then c:\Python32\libs -# and c:\Python32\include have been stored in the Python32_*.tar.gz tarball. -$WGET http://www.sigrok.org/tmp/Python32_$TARGET.tar.gz -O $PREFIX/Python32.tar.gz -tar xzf $PREFIX/Python32.tar.gz -C $PREFIX +# - https://www.python.org/ftp/python/3.6.0/python-3.6.0.exe +# - https://www.python.org/ftp/python/3.6.0/python-3.6.0-amd64.exe +# The EXE file has been installed on a Windows box and then the "libs" and +# "include" directories have been stored in the Python36_*.tar.gz tarball. +$WGET http://www.sigrok.org/tmp/Python36_$TARGET.tar.gz -O $PREFIX/Python36.tar.gz +tar xzf $PREFIX/Python36.tar.gz -C $PREFIX # Create a dummy python3.pc file so that pkg-config finds Python 3. mkdir -p $PREFIX/lib/pkgconfig @@ -94,55 +103,60 @@ libdir=\${exec_prefix}/lib includedir=\${prefix}/include Name: Python Description: Python library -Version: 3.2 -Libs: -L$PREFIX/Python32/libs -lpython32 -Cflags: -I$PREFIX/Python32/include +Version: 3.6 +Libs: $PREFIX/Python36/libs/libpython36.a +Cflags: -I$PREFIX/Python36/include EOF -# The python32.dll and python32.zip files will be shipped in the NSIS +# The python36.dll and python36.zip files will be shipped in the NSIS # Windows installers (required for protocol decoding to work). -# The file python32.dll (NOT the same as python3.dll) is copied from an -# installed Python 3.2.3 (see above) from c:\Windows\system32\python32.dll. -# The file python32.zip contains all files from the 'DLLs', 'Lib', and 'libs' -# subdirectories from an installed Python on Windows (c:\python32), i.e. some -# libraries and all Python stdlib modules. -$WGET http://www.sigrok.org/tmp/python32_$TARGET.dll -O $PREFIX/python32.dll -$WGET http://www.sigrok.org/tmp/python32_$TARGET.zip -O $PREFIX/python32.zip +# The file python36.dll (NOT the same as python3.dll) is copied from an +# installed Python 3.6.0 (see above). +# The file python36.zip contains all files from the 'DLLs', 'Lib', and 'libs' +# subdirectories from an installed Python on Windows, i.e. some libraries and +# all Python stdlib modules. +$WGET http://www.sigrok.org/tmp/python36_$TARGET.dll -O $PREFIX/python36.dll +$WGET http://www.sigrok.org/tmp/python36_$TARGET.zip -O $PREFIX/python36.zip # Zadig (we ship this with frontends for easy driver switching). -$WGET -c http://$SF_MIRROR/project/libwdi/zadig/zadig_$VER_ZADIG.7z -$WGET -c http://$SF_MIRROR/project/libwdi/zadig/zadig_xp_$VER_ZADIG.7z -7zr e zadig_$VER_ZADIG.7z -7zr e zadig_xp_$VER_ZADIG.7z -cp -f zadig.exe zadig_xp.exe $PREFIX +$WGET http://zadig.akeo.ie/downloads/zadig.exe -O $PREFIX/zadig.exe +$WGET http://zadig.akeo.ie/downloads/zadig_xp.exe -O $PREFIX/zadig_xp.exe + +# libusb +$GIT_CLONE git://github.com/dickens/libusb -b event-abstraction-v4 +cd libusb +patch -p1 < ../../libusb_raw_io.patch +./bootstrap.sh +./configure $C $L +make -j1 $V +make install $V +cd .. # libserialport $GIT_CLONE git://sigrok.org/libserialport cd libserialport ./autogen.sh ./configure $C $L -make $PARALLEL V=1 -make install +make $PARALLEL $V +make install $V cd .. # libsigrok $GIT_CLONE git://sigrok.org/libsigrok cd libsigrok -patch -p1 < ../../libsigrok_firmwaredir.patch ./autogen.sh ./configure $C $L -make $PARALLEL V=1 -make install +make $PARALLEL $V +make install $V cd .. # libsigrokdecode $GIT_CLONE git://sigrok.org/libsigrokdecode cd libsigrokdecode ./autogen.sh -patch -p1 < ../../srd_decodersdir.patch ./configure $C $L -make $PARALLEL V=1 -make install +make $PARALLEL $V +make install $V cd .. # sigrok-firmware @@ -151,7 +165,7 @@ cd sigrok-firmware ./autogen.sh # Nothing gets cross-compiled here, we just need 'make install' basically. ./configure --prefix=$PREFIX -make install +make install $V cd .. # sigrok-firmware-fx2lafw @@ -160,14 +174,14 @@ cd sigrok-firmware-fx2lafw ./autogen.sh # We're building the fx2lafw firmware on the host, no need to cross-compile. ./configure --prefix=$PREFIX -make $PARALLEL V=1 -make install +make $PARALLEL $V +make install $V cd .. # sigrok-dumps $GIT_CLONE git://sigrok.org/sigrok-dumps cd sigrok-dumps -make install DESTDIR=$PREFIX/share/sigrok-dumps +make install DESTDIR=$PREFIX/share/sigrok-dumps $V cd .. # sigrok-cli @@ -175,17 +189,25 @@ $GIT_CLONE git://sigrok.org/sigrok-cli cd sigrok-cli ./autogen.sh ./configure $C -make $PARALLEL V=1 -make install +make $PARALLEL $V +make install $V makensis -DHOME=$HOME contrib/sigrok-cli_cross.nsi cd .. # PulseView $GIT_CLONE git://sigrok.org/pulseview cd pulseview -cmake $CM -DCMAKE_INSTALL_PREFIX:PATH=$PREFIX -DDISABLE_WERROR=y . -make $PARALLEL VERBOSE=1 -make install +if [ $DEBUG = 1 ]; then + # Allow a "DOS box" to open on Windows, it'll contain logging output. + patch -p1 < ../../pv_mwindows.patch +fi +$CMAKE -DCMAKE_INSTALL_PREFIX:PATH=$PREFIX -DDISABLE_WERROR=y -DENABLE_TESTS=y . +make $PARALLEL $V +if [ $DEBUG = 1 ]; then + make install $V +else + make install/strip $V +fi makensis -DHOME=$HOME contrib/pulseview_cross.nsi cd ..