summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/hdf-eos5-1-fixes.patch158
-rw-r--r--src/hdf-eos5-test.c33
-rw-r--r--src/hdf-eos5.mk34
3 files changed, 225 insertions, 0 deletions
diff --git a/src/hdf-eos5-1-fixes.patch b/src/hdf-eos5-1-fixes.patch
new file mode 100644
index 0000000..3850246
--- /dev/null
+++ b/src/hdf-eos5-1-fixes.patch
@@ -0,0 +1,158 @@
+This file is part of MXE.
+See index.html for further information.
+
+Contains ad hoc patches for cross building.
+
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Thomas Danckaert <thomas.danckaert@gmail.com>
+Date: Fri, 27 May 2016 17:39:23 +0200
+Subject: [PATCH] fixes
+
+
+diff --git a/configure.ac b/configure.ac
+index 1111111..2222222 100644
+--- a/configure.ac
++++ b/configure.ac
+@@ -104,17 +104,7 @@ dnl Check if -Df2cFortran is specified
+ dnl Running only the preprocessor may not be a good idea
+ dnl because this can be hard-coded.
+ AC_MSG_CHECKING([for fc2Fortran macro])
+-AC_CACHE_VAL([he5_cv_f2cFortran_defined],
+- [AC_TRY_RUN([
+- int main(void)
+- {
+- #ifdef f2cFortran
+- return 0;
+- #else
+- return 1;
+- #endif
+- }
+- ], [he5_cv_f2cFortran_defined=yes], [he5_cv_f2cFortran_defined=no],)])
++AC_CACHE_VAL([he5_cv_f2cFortran_defined],[he5_cv_f2cFortran_defined=yes])
+ if test ${he5_cv_f2cFortran_defined} = "yes"; then
+ F2CFORTRAN_MACRO="yes"
+ AC_MSG_RESULT([defined])
+@@ -124,18 +114,7 @@ else
+ fi
+
+ if test ${he5_cv_f2cFortran_defined} = "yes"; then
+- AC_CHECK_SIZEOF([int*])
+- AC_CACHE_VAL([he5_cv_32ptr],
+- [AC_TRY_RUN([
+- int main(void)
+- {
+-#ifdef SIZEOF_INTP
+- return SIZEOF_INTP == 4 ? 0 : 1;
+-#else
+-#error SIZEOF_INTP is not defined
+-#endif
+- }
+- ], [he5_cv_32ptr=yes], [he5_cv_32ptr=no],)])
++ AC_CACHE_VAL([he5_cv_32ptr],[he5_cv_32ptr=no])
+ if test ${he5_cv_32ptr} = "yes"; then
+ AC_MSG_NOTICE([possibly 32 bit system])
+ F2CFORTRAN_32PTR="yes"
+@@ -417,20 +396,7 @@ fi
+
+ # Check whether HDF5 threadsafety is enabled
+ AC_MSG_CHECKING([if HDF5 threadsafe mode is enabled])
+-AC_TRY_RUN([
+-#include "hdf5.h"
+-
+-int main(void) {
+-#ifdef H5_HAVE_THREADSAFE
+- return 0;
+-#else
+- return 1;
+-#endif
+-} ],
+- [ AC_MSG_RESULT([yes])
+- THREADSAFE="yes"],
+- [AC_MSG_RESULT([no])
+- THREADSAFE="no"])
++THREADSAFE=no
+
+ # Record threadsafe status in config.h and for Makefiles
+ if test "X$THREADSAFE" = "Xyes"; then
+@@ -445,24 +411,7 @@ if test "x$HAVE_HDF5" = "xyes"; then
+ dnl Check if HDF5 is linked with SZIP encoder
+
+ AC_MSG_CHECKING([for hdf5 szip decoding filter])
+- AC_CACHE_VAL([he5_cv_hdf5_szip_can_decode],
+- [AC_TRY_RUN([
+- #include <H5Ipublic.h>
+- #include <H5Zpublic.h>
+-
+- int main(int argc, char **argv)
+- {
+- herr_t ret;
+- unsigned int flags = 0;
+- int decoder = 0;
+-
+- ret = H5Zget_filter_info(H5Z_FILTER_SZIP, &flags);
+- if (ret < 0) exit(1);
+- decoder = flags & H5Z_FILTER_CONFIG_DECODE_ENABLED;
+- if (decoder) exit(0);
+- else exit(1);
+- }
+- ], [he5_cv_hdf5_szip_can_decode=yes], [he5_cv_hdf5_szip_can_decode=no],)])
++ AC_CACHE_VAL([he5_cv_hdf5_szip_can_decode],[he5_cv_hdf5_szip_can_decode=no])
+ if test ${he5_cv_hdf5_szip_can_decode} = "yes"; then
+ AC_DEFINE(HAVE_HDF5_SZIP_DECODER, 1,
+ [Define if HDF5 has szip decoder filter])
+@@ -474,24 +423,7 @@ if test "x$HAVE_HDF5" = "xyes"; then
+ fi
+
+ AC_MSG_CHECKING([for hdf5 szip encoding filter])
+- AC_CACHE_VAL([he5_cv_hdf5_szip_can_encode],
+- [AC_TRY_RUN([
+- #include <H5Ipublic.h>
+- #include <H5Zpublic.h>
+-
+- int main(int argc, char **argv)
+- {
+- herr_t ret;
+- unsigned int flags = 0;
+- int encoder = 0;
+-
+- ret = H5Zget_filter_info(H5Z_FILTER_SZIP, &flags);
+- if (ret < 0) exit(1);
+- encoder = flags & H5Z_FILTER_CONFIG_ENCODE_ENABLED;
+- if (encoder) exit(0);
+- else exit(1);
+- }
+- ], [he5_cv_hdf5_szip_can_encode=yes], [he5_cv_hdf5_szip_can_encode=no],)])
++ AC_CACHE_VAL([he5_cv_hdf5_szip_can_encode],[he5_cv_hdf5_szip_can_encode=no])
+
+ if test ${he5_cv_hdf5_szip_can_encode} = "yes"; then
+ AC_DEFINE(HAVE_HDF5_SZIP_ENCODER, 1,
+
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Thomas Danckaert <thomas.danckaert@gmail.com>
+Date: Fri, 27 May 2016 17:49:30 +0200
+Subject: [PATCH] Fix compilation without SZIP.
+
+A wrongly placed #endif causes a missing symbol 'HE5_EHHEisHE5' when
+compiling without szip. Bug & fix reported upstream.
+
+diff --git a/src/EHapi.c b/src/EHapi.c
+index 1111111..2222222 100755
+--- a/src/EHapi.c
++++ b/src/EHapi.c
+@@ -11379,6 +11379,7 @@ int HE5_szip_can_encode(void )
+ return(-1);
+ }
+
++#endif /* H5_HAVE_FILTER_SZIP */
+
+
+ /*----------------------------------------------------------------------------|
+@@ -11509,8 +11510,6 @@ HE5_EHHEisHE5(char *filename)
+ }
+ }
+
+-#endif /* H5_HAVE_FILTER_SZIP */
+-
+
+ #ifndef __cplusplus
+
diff --git a/src/hdf-eos5-test.c b/src/hdf-eos5-test.c
new file mode 100644
index 0000000..b803dbd
--- /dev/null
+++ b/src/hdf-eos5-test.c
@@ -0,0 +1,33 @@
+/*
+ * This file is part of MXE.
+ * See index.html for further information.
+ */
+
+#include "HE5_HdfEosDef.h"
+
+int main() {
+
+ char filename[] = "test.he5";
+ hid_t output_file = HE5_SWopen(filename, H5F_ACC_TRUNC);
+ char swathname[] = "testswath";
+ hid_t swath_id = HE5_SWcreate(output_file, swathname);
+
+ char dimension[] = "dummydim";
+ HE5_SWdefdim(swath_id, dimension, 10);
+ char fieldname[] = "test_field";
+ HE5_SWdefdatafield(swath_id, fieldname, dimension, NULL, HE5T_NATIVE_FLOAT, 0);
+
+ hssize_t start[HE5_DTSETRANKMAX] = {0};
+ hsize_t edge[HE5_DTSETRANKMAX] = {10};
+ float testdata[10];
+
+ for(unsigned int i=0; i<10; ++i)
+ testdata[i] = (float)i;
+
+ HE5_SWwritefield(swath_id, fieldname, start, NULL, edge, testdata);
+
+ HE5_SWdetach(swath_id);
+ HE5_SWclose(output_file);
+
+ return 0;
+}
diff --git a/src/hdf-eos5.mk b/src/hdf-eos5.mk
new file mode 100644
index 0000000..626930f
--- /dev/null
+++ b/src/hdf-eos5.mk
@@ -0,0 +1,34 @@
+# This file is part of MXE.
+# See index.html for further information.
+
+PKG := hdf-eos5
+$(PKG)_IGNORE :=
+$(PKG)_VERSION := 1.15
+$(PKG)_CHECKSUM := 119588067abf139c1c600a4519b880d04a3933049576c88acdc8ff6fc71803dd
+$(PKG)_SUBDIR := hdfeos5
+$(PKG)_FILE := HDF-EOS5.$($(PKG)_VERSION).tar.Z
+$(PKG)_URL := ftp://edhs1.gsfc.nasa.gov/edhs/hdfeos5/latest_release/$($(PKG)_FILE)
+$(PKG)_DEPS := gcc hdf5
+
+define $(PKG)_UPDATE
+ echo 'TODO: write update script for hdf-eos5.' >&2;
+ echo $(hdf-eos5_VERSION)
+endef
+
+define $(PKG)_BUILD
+ cd '$(1)' && chmod -R ugo+w .
+ cd '$(1)' && autoconf
+ cd '$(1)' && ./configure \
+ $(MXE_CONFIGURE_OPTS) \
+ --enable-install-include
+
+ $(MAKE) -C '$(1)' -j '$(JOBS)'
+ $(MAKE) -C '$(1)' -j 1 install
+
+ '$(TARGET)-gcc' \
+ -std=c99 -W -Wall -Werror -pedantic \
+ '$(2).c' -o '$(PREFIX)/$(TARGET)/bin/test-$(PKG).exe' \
+ -lhe5_hdfeos -lhdf5_hl -lhdf5 -lz
+endef
+
+$(PKG)_BUILD_SHARED =