summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--MANIFEST1
-rw-r--r--config/freebsd19
-rw-r--r--config/gnu-fflags85
-rw-r--r--fortran/src/H5f90i.h31
4 files changed, 135 insertions, 1 deletions
diff --git a/MANIFEST b/MANIFEST
index c3b80bd..1b9a63f 100644
--- a/MANIFEST
+++ b/MANIFEST
@@ -56,6 +56,7 @@
./config/depend4.in
./config/dependN.in
./config/freebsd
+./config/gnu-fflags
./config/gnu-flags
./config/hpux10.20
./config/hpux11.00
diff --git a/config/freebsd b/config/freebsd
index 80009b0..10ab716 100644
--- a/config/freebsd
+++ b/config/freebsd
@@ -15,9 +15,26 @@ fi
# from /usr/include/sys/cdefs.h
CPPFLAGS="$CPPFLAGS -D_POSIX_C_SOURCE=1"
-# Figure out compiler flags
+#
+# HDF5 FORTRAN integers
+#
+# R_LARGE is the number of digits for the bigest integer supported.
+# R_INTEGER is the number of digits in INTEGER
+#
+R_LARGE=18
+R_INTEGER=9
+HSIZE_T='SELECTED_INT_KIND(R_LARGE)'
+HSSIZE_T='SELECTED_INT_KIND(R_LARGE)'
+HID_T='SELECTED_INT_KIND(R_INTEGER)'
+SIZE_T='SELECTED_INT_KIND(R_INTEGER)'
+OBJECT_NAMELEN_DEFAULT_F=-1
+
+# Figure out C compiler flags
. $srcdir/config/gnu-flags
+# Figure out FORTRAN compiler flags
+. $srcdir/config/gnu-fflags
+
# Special setup to use pthread support if enable-threadsafe is on.
# Works with static executable only.
if test "X-" != "X-$enable_threadsafe"; then
diff --git a/config/gnu-fflags b/config/gnu-fflags
new file mode 100644
index 0000000..f1f50d7
--- /dev/null
+++ b/config/gnu-fflags
@@ -0,0 +1,85 @@
+# -*- shell-script -*-
+#
+# This file should be sourced into configure if the compiler is the
+# GNU g95/gfortran compiler or a derivative. It is careful not to do anything
+# if the compiler is not GNU; otherwise `f9x_flags_set' is set to `yes'
+#
+
+# Get the compiler version in a way that works for GNU fortran
+# gfortran unless a compiler version is already known
+#
+# f9x_vendor: The compiler name: gfortran
+# f9x_version: Version number: 5.0-2, 5.2-2
+#
+if test X = "X$f9x_flags_set"; then
+ f9x_version="`$F9X $FFLAGS -v 2>&1 |grep 'gcc version' |\
+ sed 's/.*gcc version \([-a-z0-9\.]*\).*/\1/'`"
+ if test X != "X$f9x_version"; then
+# is_mpi="`$F9X $FFLAGS -help 2>&1 |grep 'link MPI'`"
+ f9x_vendor=`echo $f9x_version |sed 's/\([a-z]*\).*/\1/'`
+ f9x_version=`echo $f9x_version |sed 's/[-a-z]//g'`
+ if test X = "X$f9x_vendor" -a X != "X$f9x_version"; then
+ f9x_vendor=gfortran
+ fi
+ if test "-" != "$f9x_vendor-$f9x_version"; then
+ echo "compiler '$F9X' is GNU $f9x_vendor-$f9x_version"
+ fi
+
+ # Some version numbers
+ f9x_vers_major=`echo $f9x_version | cut -f1 -d.`
+ f9x_vers_minor=`echo $f9x_version | cut -f2 -d.`
+ f9x_vers_patch=`echo $f9x_version | cut -f3 -d.`
+ test -n "$f9x_vers_major" || f9x_vers_major=0
+ test -n "$f9x_vers_minor" || f9x_vers_minor=0
+ test -n "$f9x_vers_patch" || f9x_vers_patch=0
+ f9x_vers_all=`expr $f9x_vers_major '*' 1000000 + $f9x_vers_minor '*' 1000 + $f9x_vers_patch`
+ fi
+fi
+
+# Common GNU flags for various situations
+if test "X-gfortran" = "X-$f9x_vendor"; then
+ # Insert section about version specific problems from gnu-flags here, if
+ # necessary.
+
+ arch=
+ # Architecture-specific flags
+ # Nothing currently. (Uncomment code below and modify to add any)
+ #case "$host_os-$host_cpu" in
+ # *-i686)
+ # arch="-march=i686"
+ # ;;
+ #esac
+
+ # Host-specific flags
+ # Nothing currently. (Uncomment code below and modify to add any)
+ #case "`hostname`" in
+ # sleipnir.ncsa.uiuc.edu)
+ # arch="$arch -pipe"
+ # ;;
+ #esac
+
+ # General
+ F9X_BASENAME=gfortran40
+ F9XSUFFIXFLAG=""
+ FSEARCH_DIRS=""
+ FFLAGS="$FFLAGS -pedantic -Wall -Wconversion -Wunderflow -Wimplicit-interface -W"
+
+ # Production
+ PROD_FFLAGS="-O2 -s"
+
+ # Debug
+ DEBUG_FFLAGS="-g -fbounds-check"
+
+ # Profile
+ PROFILE_FFLAGS="-g -pg"
+
+ # Flags are set
+ f9x_flags_set=yes
+fi
+
+# Clear f9x info if no flags set
+if test "X-$f9x_flags_set" = "X-"; then
+ f9x_vendor=
+ f9x_version=
+fi
+
diff --git a/fortran/src/H5f90i.h b/fortran/src/H5f90i.h
index 996a143..1eb6480 100644
--- a/fortran/src/H5f90i.h
+++ b/fortran/src/H5f90i.h
@@ -193,6 +193,37 @@ typedef float real_f;
#endif /*WINDOWS */
+/* FreeBSD definitions */
+#if (defined(__FreeBSD) || defined(__FreeBSD__))
+
+/* Common definitions */
+typedef char *_fcd;
+typedef int int_f;
+typedef int hid_t_f;
+typedef float real_f;
+#define _fcdtocp(desc) (desc)
+
+/* IA32 specific definitions */
+#if (defined(i386) || defined(__i386) || defined(__i386__))
+typedef long long hsize_t_f;
+typedef long long hssize_t_f;
+typedef int size_t_f;
+/* AMD64 specific definitions */
+#elif defined __x86_64__
+typedef long long hsize_t_f;
+typedef long long hssize_t_f;
+typedef int size_t_f;
+/* IA64 specific definitions */
+#elif defined __ia64
+typedef long hsize_t_f;
+typedef long hssize_t_f;
+typedef long size_t_f;
+#endif /* IA64 */
+
+#define FNAME_POST_UNDERSCORE
+
+#endif /* FreeBSD */
+
/*----------------------------------------------------------------
** MACRO FNAME for any fortran callable routine name.
**