X-Git-Url: https://sigrok.org/gitweb/?p=sigrok-util.git;a=blobdiff_plain;f=cross-compile%2Fmingw%2Fsigrok-cross-mingw;h=0b28cf1fcccf46d0d411060344683e1caa1731bd;hp=61fceaf717cc9bde55313e1249423725d2050eed;hb=30f27835808d85b6c24230f445c2d99e5d6a18b2;hpb=b8ae68928081946f6798b9424c968631d9dbeba7 diff --git a/cross-compile/mingw/sigrok-cross-mingw b/cross-compile/mingw/sigrok-cross-mingw index 61fceaf..0b28cf1 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-2020 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 @@ -26,11 +26,11 @@ TARGET="i686" # The path where your MXE directory is located. MXE=$HOME/mxe-git -# The path where the cross-compiled packages will be installed. -PREFIX=$HOME/sr_mingw +# The base path prefix where the cross-compiled packages will be installed. +PREFIXBASE=$HOME/sr_mingw -# The path where to download files to and where to build packages. -BUILDDIR=./build +# The base path prefix where to download files to and where to build packages. +BUILDBASE=./build # Edit this to control verbose build output. # V="V=1 VERBOSE=1" @@ -41,17 +41,42 @@ PARALLEL="-j 2" # Edit this to enable/disable debug builds. DEBUG=0 +# Optionally show some progress as the script executes. +# ECHO=true +ECHO=echo + # You usually don't need to change anything below this line. # ----------------------------------------------------------------------------- -SF_MIRROR=switch.dl.sourceforge.net +$ECHO "setting up fetch variables ..." WGET="wget -c --quiet" GIT_CLONE="git clone --depth=1" +REPO_BASE="git://sigrok.org" + +# Construct the build and install directory pathnames. +if [ $TARGET = "i686" ]; then + SUFFIX="32" +else + SUFFIX="64" +fi +if [ $DEBUG = 1 ]; then + # CFLAGS/CXXFLAGS contains "-g" per default for autotools projects. + BUILD_TYPE="Debug" + PREFIX=$PREFIXBASE"_debug_"$SUFFIX + BUILDDIR=$BUILDBASE"_debug_"$SUFFIX +else + BUILD_TYPE="Release" + PREFIX=$PREFIXBASE"_release_"$SUFFIX + BUILDDIR=$BUILDBASE"_release_"$SUFFIX +fi + # ----------------------------------------------------------------------------- +$ECHO "setting up toolchain variables ..." + # We need to find tools in the toolchain. export PATH=$MXE/usr/bin:$PATH @@ -70,12 +95,8 @@ else 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. +$ECHO "starting new build directory: $BUILDDIR" rm -rf $BUILDDIR mkdir $BUILDDIR cd $BUILDDIR @@ -84,15 +105,27 @@ cd $BUILDDIR mkdir -p $PREFIX +$ECHO "preparing Python dependency ..." + +# This is a HACK which temporarily unbreaks Windows CI builds. +# TODO Remove this line as well as $WGET_SR references below +# when the Python34 download works again. +WGET_SR="$WGET --no-check-certificate" + # 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_SR http://www.sigrok.org/tmp/Python34_$TARGET.tar.gz -O $PREFIX/Python34.tar.gz +tar xzf $PREFIX/Python34.tar.gz -C $PREFIX + +# Fix for bug #1195. +if [ $TARGET = "x86_64" ]; then + patch -p1 $PREFIX/Python34/include/pyconfig.h < ../pyconfig.patch +fi # Create a dummy python3.pc file so that pkg-config finds Python 3. mkdir -p $PREFIX/lib/pkgconfig @@ -103,37 +136,46 @@ libdir=\${exec_prefix}/lib includedir=\${prefix}/include Name: Python Description: Python library -Version: 3.2 -Libs: $PREFIX/Python32/libs/libpython32.a -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_SR http://www.sigrok.org/tmp/python34_$TARGET.dll -O $PREFIX/python34.dll +$WGET_SR http://www.sigrok.org/tmp/python34_$TARGET.zip -O $PREFIX/python34.zip + +# In order to link against Python we need libpython34.a. +# The upstream Python 32bit installer ships this, the x86_64 installer +# doesn't. Thus, we generate the file manually here. +if [ $TARGET = "x86_64" ]; then + cp $PREFIX/python34.dll . + $MXE/usr/$TARGET-w64-mingw32.static.posix/bin/gendef python34.dll + $MXE/usr/bin/$TARGET-w64-mingw32.static.posix-dlltool \ + --dllname python34.dll --def python34.def \ + --output-lib libpython34.a + mv -f libpython34.a $PREFIX/Python34/libs + rm -f python34.dll +fi + +# We need to include the *.pyd files from python34.zip into the installers, +# otherwise importing certain modules (e.g. ctypes) won't work (bug #1409). +unzip -q $PREFIX/python34.zip *.pyd -d $PREFIX # Zadig (we ship this with frontends for easy driver switching). -$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 .. +$ECHO "fetching zadig ..." +$WGET https://github.com/pbatard/libwdi/releases/download/b721/zadig-2.4.exe -O $PREFIX/zadig.exe +$WGET https://github.com/pbatard/libwdi/releases/download/v1.2.5/zadig_xp-2.2.exe -O $PREFIX/zadig_xp.exe # libserialport -$GIT_CLONE git://sigrok.org/libserialport +$ECHO "component libserialport ..." +$GIT_CLONE $REPO_BASE/libserialport cd libserialport ./autogen.sh ./configure $C $L @@ -142,7 +184,8 @@ make install $V cd .. # libsigrok -$GIT_CLONE git://sigrok.org/libsigrok +$ECHO "component libsigrok ..." +$GIT_CLONE $REPO_BASE/libsigrok cd libsigrok ./autogen.sh ./configure $C $L @@ -151,7 +194,8 @@ make install $V cd .. # libsigrokdecode -$GIT_CLONE git://sigrok.org/libsigrokdecode +$ECHO "component libsigrokdecode ..." +$GIT_CLONE $REPO_BASE/libsigrokdecode cd libsigrokdecode ./autogen.sh ./configure $C $L @@ -160,7 +204,8 @@ make install $V cd .. # sigrok-firmware -$GIT_CLONE git://sigrok.org/sigrok-firmware +$ECHO "component sigrok-firmware ..." +$GIT_CLONE $REPO_BASE/sigrok-firmware cd sigrok-firmware ./autogen.sh # Nothing gets cross-compiled here, we just need 'make install' basically. @@ -169,7 +214,8 @@ make install $V cd .. # sigrok-firmware-fx2lafw -$GIT_CLONE git://sigrok.org/sigrok-firmware-fx2lafw +$ECHO "component 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. @@ -179,35 +225,53 @@ make install $V cd .. # sigrok-dumps -$GIT_CLONE git://sigrok.org/sigrok-dumps +$ECHO "component 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 +$ECHO "component sigrok-cli ..." +$GIT_CLONE $REPO_BASE/sigrok-cli cd sigrok-cli ./autogen.sh ./configure $C make $PARALLEL $V make install $V -makensis -DHOME=$HOME contrib/sigrok-cli_cross.nsi +if [ $TARGET = "i686" ]; then + makensis contrib/sigrok-cli_cross.nsi +else + makensis -DPE64=1 contrib/sigrok-cli_cross.nsi +fi cd .. # PulseView -$GIT_CLONE git://sigrok.org/pulseview +$ECHO "component pulseview ..." +$GIT_CLONE $REPO_BASE/pulseview cd pulseview -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 . +patch -p1 < ../../pulseview-manual-pdf-hack.patch +cp ../../FileAssociation.nsh contrib +$CMAKE \ + -DCMAKE_INSTALL_PREFIX:PATH=$PREFIX \ + -DCMAKE_BUILD_TYPE=$BUILD_TYPE \ + -DDISABLE_WERROR=y \ + -DENABLE_TESTS=y \ + . make $PARALLEL $V +make manual if [ $DEBUG = 1 ]; then make install $V else make install/strip $V fi -makensis -DHOME=$HOME contrib/pulseview_cross.nsi + +$ECHO "creating NSIS installer ..." +if [ $TARGET = "i686" ]; then + makensis contrib/pulseview_cross.nsi +else + makensis -DPE64=1 contrib/pulseview_cross.nsi +fi cd .. +$ECHO "cross compile script done.""