From d670b6acf642e1e6db2b194a704de961314ddf6f Mon Sep 17 00:00:00 2001 From: Ladislav Heller Date: Tue, 10 Oct 2023 11:10:33 +0200 Subject: [PATCH] Windows/Cygwin support (#1950) --- README.Cygwin | 74 ++++++++++++++++++++++++++++++++++ libs/dsp/dsp.h | 5 ++- libs/eventloop/eventloop.c | 4 ++ libs/indibase/indidrivermain.c | 4 ++ libs/indicore/indidevapi.h | 3 ++ libs/indicore/shm_open_anon.c | 5 +++ 6 files changed, 94 insertions(+), 1 deletion(-) create mode 100644 README.Cygwin diff --git a/README.Cygwin b/README.Cygwin new file mode 100644 index 0000000000..75eecc8cea --- /dev/null +++ b/README.Cygwin @@ -0,0 +1,74 @@ +Build and install INDI on Windows/Cygwin platform +================================================= + +Install Cygwin and the required packages +------------------------------------ +Download Cygwin setup executable from [cygwin.com](https://cygwin.com/setup-x86_64.exe). It provides a GUI wizard to support the installation but probably it is faster to install it via the command line to a predefined location and a preselected list of required packages: + +> setup-x86_64.exe -q -v -R "C:\cygwin" -O -s "https://cygwin.mirror.constant.com/" -l "%Temp%\CygwinPackages" -P aalib-devel -P autoconf -P automake -P cmake -P curl -P gcc-g++ -P gettext -P gettext-devel -P git -P help2man -P libboost-devel -P libcfitsio-devel -P libcurl-devel -P libev-devel -P libexif-devel -P libffi-devel -P libfftw3-devel -P libftdi1-devel -P libgd-devel -P libgsl-devel -P libiconv -P libiconv-devel -P libintl-devel -P libjpeg-devel -P libkrb5-devel -P liblapack-devel -P libpng-devel -P libpng16-devel -P libpopt-devel -P libraw-devel -P libtheora-devel -P libtiff-devel -P libtool -P libusb-devel -P libusb0 -P libusb-win32 -P libxml2-devel -P m4 -P make -P mc -P procps-ng -P texi2html -P texinfo -P wget -P zlib-devel + +The above command line installs the Cygwin environment and required packages silently to the _C:\cygwin_ folder while downloading packages from the preselected mirror _https://cygwin.mirror.constant.com/_ to the current user's _TEMP_ folder. + +Note: +The latest versions of Cygwin installers support only 64-bit versions of Windows 7 and newer! + +Once Cygwin is installed, a shortcut icon to _Cygwin Terminal_ is created on the user's Desktop. It is recommended to run Cygwin Terminal with elevated privileges (by right-clicking and _Run as Administrator_). + +Build and install libnova +------------------------- +Since the [libnova](https://gitlab.com/libnova/libnova) is not prebuilt for Cygwin, but required for INDI, we have to build it manually: + +> git clone https://gitlab.com/libnova/libnova.git + +> cd ./libnova + +> ./autogen.sh + +> ./configure --prefix=/usr + +> make + +> make install + +Once built & installed, INDI should find its headers and library. + +Build and install INDI +---------------------- + +This is similar to what happens in Linux environments: + + +> git clone https://github.com/indilib/indi.git + +> cd ./indi + +> mkdir _build && cd _build + +> export CXXFLAGS="-std=c++17 -I/usr/lib/gcc/x86_64-pc-cygwin/11/include/c++" + +> cmake -DCMAKE_INSTALL_PREFIX=/usr -DCMAKE_BUILD_TYPE=Debug .. + +> make -j 4 + +> make install + +Build and install indiweb manager +---------------------------------- +Indiweb Manager is a python web application that requires the _psutil_ python package. In cygwin environment, we have to manually build this requirement package: + +> git clone -b cygwin/v3 https://github.com/embray/psutil.git + +> cd ./psutil + +> pip3 install -e . + +Once _psutil_ is installed we can easily install indiweb: + +> pip3 install indiweb + +Finally, run it: +> indi-web -v + +Test using clients like KSTARS +------------------------------ +Once INDI & indiweb manager are installed, all the simulator devices should work out-of-the-box using KSTARS/EKOS. diff --git a/libs/dsp/dsp.h b/libs/dsp/dsp.h index 82a8fc4c14..bc8c98c8c4 100644 --- a/libs/dsp/dsp.h +++ b/libs/dsp/dsp.h @@ -31,7 +31,7 @@ extern "C" { #endif #endif -#ifdef __linux__ +#if defined(__linux__) || defined(_WIN32) || defined(__CYGWIN__) #include #else #define __bswap_16(a) __builtin_bswap16(a) @@ -48,6 +48,9 @@ extern "C" { #include #include #include +#ifndef M_PI + #define M_PI 3.14159265358979323846 +#endif /** * \defgroup DSP Digital Signal Processing API diff --git a/libs/eventloop/eventloop.c b/libs/eventloop/eventloop.c index 0ac87a5b19..e1fb60517e 100644 --- a/libs/eventloop/eventloop.c +++ b/libs/eventloop/eventloop.c @@ -41,6 +41,10 @@ #include #include +#if defined(_WIN32) || defined(__CYGWIN__) +#include +#endif + #include "eventloop.h" /* info about one registered callback. diff --git a/libs/indibase/indidrivermain.c b/libs/indibase/indidrivermain.c index dc9d5507b3..20e3b00e7e 100644 --- a/libs/indibase/indidrivermain.c +++ b/libs/indibase/indidrivermain.c @@ -47,6 +47,10 @@ #include #include +#if defined(_WIN32) || defined(__CYGWIN__) +#include +#endif + #define MAXRBUF 2048 static void usage(void); diff --git a/libs/indicore/indidevapi.h b/libs/indicore/indidevapi.h index 34580c73ae..17f60b33a5 100644 --- a/libs/indicore/indidevapi.h +++ b/libs/indicore/indidevapi.h @@ -93,6 +93,9 @@ * */ +#if defined(_WIN32) || defined(__CYGWIN__) +#include +#endif #include "indiapi.h" #include "lilxml.h" diff --git a/libs/indicore/shm_open_anon.c b/libs/indicore/shm_open_anon.c index a56980af93..fd96ac6941 100644 --- a/libs/indicore/shm_open_anon.c +++ b/libs/indicore/shm_open_anon.c @@ -112,8 +112,13 @@ shm_open_anon(void) r = (unsigned long)tv.tv_sec + (unsigned long)tv.tv_nsec; for (fill = start; fill < limit; r /= 8) *fill++ = '0' + (r % 8); +#if defined(_WIN32) || defined(__CYGWIN__) + fd = shm_open( + name, O_RDWR | O_CREAT | O_EXCL, 0600); +#else fd = shm_open( name, O_RDWR | O_CREAT | O_EXCL | O_NOFOLLOW, 0600); +#endif if (fd != -1) return shm_unlink_or_close(name, fd); if (errno != EEXIST)