dnl -*- shell-script -*-
dnl
dnl Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
dnl                         University Research and Technology
dnl                         Corporation.  All rights reserved.
dnl Copyright (c) 2004-2005 The University of Tennessee and The University
dnl                         of Tennessee Research Foundation.  All rights
dnl                         reserved.
dnl Copyright (c) 2004-2005 High Performance Computing Center Stuttgart, 
dnl                         University of Stuttgart.  All rights reserved.
dnl Copyright (c) 2004-2005 The Regents of the University of California.
dnl                         All rights reserved.
dnl Copyright (c) 2011-2012 Cisco Systems, Inc.  All rights reserved.
dnl $COPYRIGHT$
dnl 
dnl Additional copyrights may follow
dnl 
dnl $HEADER$
dnl

# OMPI_FORTRAN_GET_HANDLE_MAX()
# ---------------------------------------------------------------
# Find the maximum value of fortran integers, then calculate
# min(INT_MAX, max fortran INTEGER).  This represents the maximum
# number of fortran MPI handle index.
AC_DEFUN([OMPI_FORTRAN_GET_HANDLE_MAX],[
    AS_VAR_PUSHDEF([fortran_handle_max_var], 
                   [ompi_cv_fortran_handle_max])

    AC_CACHE_CHECK([for max Fortran MPI handle index],
        fortran_handle_max_var,
        [ # Find max fortran INTEGER value.  Set to sentinel value if we don't
         # have a Fortran compiler (e.g., if --disable-fortran was given). 
         if test $OMPI_WANT_FORTRAN_BINDINGS -eq 0; then
             ompi_fint_max=0
         else
             # Calculate the number of f's that we need to append to the hex
             # value.  Do one less than we really need becaue we assume the
             # top nybble is 0x7 to avoid sign issues.
             ompi_numf=`expr $OMPI_SIZEOF_FORTRAN_INTEGER \* 8 - 1`
             ompi_fint_max=1
             # Use string comparisons when comparing these values to
             # 0, because $ompi_numf may be larger than "test -eq
             # ..." can handle (e.g., if we compile Fortran with
             # "ifort -i8").
             while test "$ompi_numf" != "0"; do
                 ompi_fint_max=`expr $ompi_fint_max \* 2`
                 ompi_numf=`expr $ompi_numf - 1`
             done
         fi

         # Get INT_MAX.  Compute a SWAG if we are cross compiling or something
         # goes wrong.
         rm -f conftest.out >/dev/null 2>&1
         AC_RUN_IFELSE([AC_LANG_PROGRAM([[
#include <stdio.h>
#include <limits.h>
]],[[FILE *fp = fopen("conftest.out", "w");
long cint = INT_MAX;
fprintf(fp, "%ld", cint);
fclose(fp);]])], 
             [ompi_cint_max=`cat conftest.out`], 
             [ompi_cint_max=0],
             [ #cross compiling is fun.  compute INT_MAX same as INTEGER max
              ompi_numf=`expr $ac_cv_sizeof_int \* 8 - 1`
              ompi_cint_max=1
              # Use string comparisons with "test"; see comment above
              # for rationale.
              while test "$ompi_numf" != "0" ; do
                  ompi_cint_max=`expr $ompi_cint_max \* 2`
                  ompi_numf=`expr $ompi_numf - 1`
              done])

         # Use string comparisons with "test"; see comment above for
         # rationale.
         if test "$ompi_cint_max" = "0" ; then
             # wow - something went really wrong.  Be conservative
             value=32767
         elif test "$ompi_fint_max" = "0" ; then
             # we aren't compiling Fortran - just set it to C INT_MAX
             value=$ompi_cint_max
         else
             # Take the lesser of C INT_MAX and Fortran INTEGER max.
             # The resulting value will then be storable in either
             # type.  Use expr (instead of "test -lt"), because it can
             # handle 8-byte integer values.
             value=$ompi_fint_max
             if test "`expr $ompi_cint_max \< $value`" = "1"; then
                 value=$ompi_cint_max
             fi
          fi
          AS_VAR_SET(fortran_handle_max_var, [$value])
          rm -f conftest.out > /dev/null 2>&1 
          unset value])

    AS_VAR_COPY([ompi_fortran_handle_max], [fortran_handle_max_var])
    AC_DEFINE_UNQUOTED([OMPI_FORTRAN_HANDLE_MAX],
        [$ompi_fortran_handle_max],
        [Max handle value for fortran MPI handles, effectively min(INT_MAX, max fortran INTEGER value)])
    AS_VAR_POPDEF([fortran_handle_max_var])
])dnl