X-Git-Url: https://sigrok.org/gitweb/?p=sigrok-util.git;a=blobdiff_plain;f=cross-compile%2Fmingw%2Fsigrok-cross-mingw;h=c5c3a39af91d9473ac93452c72295c2231a0aed4;hp=8465f4a870b006481abf35d0f00718b4390a7810;hb=7b5d29b694e64356ec5ece92f2048f846e3c83a2;hpb=b65a0b061de5a8f796b8a0bc447329913ff97c05 diff --git a/cross-compile/mingw/sigrok-cross-mingw b/cross-compile/mingw/sigrok-cross-mingw index 8465f4a..c5c3a39 100755 --- a/cross-compile/mingw/sigrok-cross-mingw +++ b/cross-compile/mingw/sigrok-cross-mingw @@ -2,7 +2,7 @@ ## ## This file is part of the sigrok-util project. ## -## Copyright (C) 2013-2016 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 @@ -50,6 +50,8 @@ SF_MIRROR=switch.dl.sourceforge.net WGET="wget -c --quiet" GIT_CLONE="git clone --depth=1" +REPO_BASE="git://sigrok.org" + # ----------------------------------------------------------------------------- # We need to find tools in the toolchain. @@ -57,10 +59,11 @@ export PATH=$MXE/usr/bin:$PATH 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 CPPFLAGS=-D__printf__=__gnu_printf__" -CM="-DCMAKE_TOOLCHAIN_FILE=$MXE/usr/$TOOLCHAIN_TRIPLET/share/cmake/mxe-conf.cmake" L="--disable-shared --enable-static" if [ $TARGET = "i686" ]; then @@ -84,14 +87,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.4.4 MSI # 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.4.4/python-3.4.4.msi +# - https://www.python.org/ftp/python/3.4.4/python-3.4.4.amd64.msi +# The MSI file has been installed on a Windows box and then c:\Python34\libs +# and c:\Python34\include have been stored in the Python34_*.tar.gz tarball. +$WGET http://www.sigrok.org/tmp/Python34_$TARGET.tar.gz -O $PREFIX/Python34.tar.gz +tar xzf $PREFIX/Python34.tar.gz -C $PREFIX # Create a dummy python3.pc file so that pkg-config finds Python 3. mkdir -p $PREFIX/lib/pkgconfig @@ -102,20 +105,20 @@ 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.4 +Libs: $PREFIX/Python34/libs/libpython34.a +Cflags: -I$PREFIX/Python34/include EOF -# The python32.dll and python32.zip files will be shipped in the NSIS +# The python34.dll and python34.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 +# The file python34.dll (NOT the same as python3.dll) is copied from an +# installed Python 3.4.4 (see above) from c:\Windows\system32\python34.dll. +# The file python34.zip contains all files from the 'DLLs', 'Lib', and 'libs' +# subdirectories from an installed Python on Windows (c:\python34), 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 +$WGET http://www.sigrok.org/tmp/python34_$TARGET.dll -O $PREFIX/python34.dll +$WGET http://www.sigrok.org/tmp/python34_$TARGET.zip -O $PREFIX/python34.zip # Zadig (we ship this with frontends for easy driver switching). $WGET http://zadig.akeo.ie/downloads/zadig.exe -O $PREFIX/zadig.exe @@ -132,7 +135,7 @@ make install $V cd .. # libserialport -$GIT_CLONE git://sigrok.org/libserialport +$GIT_CLONE $REPO_BASE/libserialport cd libserialport ./autogen.sh ./configure $C $L @@ -141,7 +144,7 @@ make install $V cd .. # libsigrok -$GIT_CLONE git://sigrok.org/libsigrok +$GIT_CLONE $REPO_BASE/libsigrok cd libsigrok ./autogen.sh ./configure $C $L @@ -150,7 +153,7 @@ make install $V cd .. # libsigrokdecode -$GIT_CLONE git://sigrok.org/libsigrokdecode +$GIT_CLONE $REPO_BASE/libsigrokdecode cd libsigrokdecode ./autogen.sh ./configure $C $L @@ -159,7 +162,7 @@ make install $V cd .. # sigrok-firmware -$GIT_CLONE git://sigrok.org/sigrok-firmware +$GIT_CLONE $REPO_BASE/sigrok-firmware cd sigrok-firmware ./autogen.sh # Nothing gets cross-compiled here, we just need 'make install' basically. @@ -168,7 +171,7 @@ make install $V cd .. # sigrok-firmware-fx2lafw -$GIT_CLONE git://sigrok.org/sigrok-firmware-fx2lafw +$GIT_CLONE $REPO_BASE/sigrok-firmware-fx2lafw cd sigrok-firmware-fx2lafw ./autogen.sh # We're building the fx2lafw firmware on the host, no need to cross-compile. @@ -178,13 +181,13 @@ make install $V cd .. # sigrok-dumps -$GIT_CLONE git://sigrok.org/sigrok-dumps +$GIT_CLONE $REPO_BASE/sigrok-dumps cd sigrok-dumps make install DESTDIR=$PREFIX/share/sigrok-dumps $V cd .. # sigrok-cli -$GIT_CLONE git://sigrok.org/sigrok-cli +$GIT_CLONE $REPO_BASE/sigrok-cli cd sigrok-cli ./autogen.sh ./configure $C @@ -194,13 +197,14 @@ makensis -DHOME=$HOME contrib/sigrok-cli_cross.nsi cd .. # PulseView -$GIT_CLONE git://sigrok.org/pulseview +$GIT_CLONE $REPO_BASE/pulseview cd pulseview +cp ../../FileAssociation.nsh contrib if [ $DEBUG = 1 ]; then # Allow a "DOS box" to open on Windows, it'll contain logging output. patch -p1 < ../../pv_mwindows.patch fi -cmake $CM -DCMAKE_INSTALL_PREFIX:PATH=$PREFIX -DDISABLE_WERROR=y -DENABLE_TESTS=y . +$CMAKE -DCMAKE_INSTALL_PREFIX:PATH=$PREFIX -DDISABLE_WERROR=y -DENABLE_TESTS=y . make $PARALLEL $V if [ $DEBUG = 1 ]; then make install $V