2005-01-08 00:17:48 +03:00
|
|
|
dnl -*- shell-script -*-
|
|
|
|
dnl
|
2006-02-12 18:11:36 +03:00
|
|
|
dnl Copyright (c) 2004-2006 The Trustees of Indiana University and Indiana
|
2005-11-05 22:57:48 +03:00
|
|
|
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.
|
2005-01-08 00:17:48 +03:00
|
|
|
dnl Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
|
|
dnl University of Stuttgart. All rights reserved.
|
2005-03-24 15:43:37 +03:00
|
|
|
dnl Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
dnl All rights reserved.
|
2005-01-08 00:17:48 +03:00
|
|
|
dnl $COPYRIGHT$
|
|
|
|
dnl
|
|
|
|
dnl Additional copyrights may follow
|
|
|
|
dnl
|
|
|
|
dnl $HEADER$
|
|
|
|
dnl
|
|
|
|
|
2006-02-12 18:11:36 +03:00
|
|
|
# OMPI_F90_GET_SIZEOF(type, variable to set)
|
|
|
|
# ------------------------------------------
|
2005-01-08 00:17:48 +03:00
|
|
|
AC_DEFUN([OMPI_F90_GET_SIZEOF],[
|
2006-02-12 18:11:36 +03:00
|
|
|
AS_VAR_PUSHDEF([type_var], [ompi_cv_f90_sizeof_$1])
|
|
|
|
|
|
|
|
AC_CACHE_CHECK([size of Fortran 90 $1], type_var,
|
|
|
|
[OMPI_F77_MAKE_C_FUNCTION([ompi_ac_size_fn], [size])
|
|
|
|
# Fortran module
|
|
|
|
cat > conftestf.f90 <<EOF
|
2005-01-08 00:17:48 +03:00
|
|
|
program fsize
|
|
|
|
external SIZE
|
|
|
|
$1 :: x(2)
|
|
|
|
call SIZE(x(1),x(2))
|
|
|
|
end program
|
|
|
|
EOF
|
|
|
|
|
2006-02-12 18:11:36 +03:00
|
|
|
# C module
|
|
|
|
if test -f conftest.h; then
|
|
|
|
ompi_conftest_h="#include \"conftest.h\""
|
|
|
|
else
|
|
|
|
ompi_conftest_h=""
|
|
|
|
fi
|
|
|
|
cat > conftest.c <<EOF
|
2005-01-08 00:17:48 +03:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
$ompi_conftest_h
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
void $ompi_ac_size_fn(char *a, char *b)
|
|
|
|
{
|
|
|
|
int diff = (int) (b - a);
|
|
|
|
FILE *f=fopen("conftestval", "w");
|
|
|
|
if (!f) exit(1);
|
|
|
|
fprintf(f, "%d\n", diff);
|
|
|
|
}
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
EOF
|
|
|
|
|
2006-02-12 18:11:36 +03:00
|
|
|
OMPI_LOG_COMMAND([$CC $CFLAGS -I. -c conftest.c],
|
|
|
|
[OMPI_LOG_COMMAND([$FC $FCFLAGS $FCFLAGS_f90 conftestf.f90 conftest.o -o conftest $LDFLAGS $LIBS],
|
|
|
|
[happy="yes"], [happy="no"])], [happy="no"])
|
2005-01-08 00:17:48 +03:00
|
|
|
|
2006-02-12 18:11:36 +03:00
|
|
|
if test "$happy" = "no" ; then
|
|
|
|
OMPI_LOG_MSG([here is the fortran 90 program:], 1)
|
|
|
|
OMPI_LOG_FILE([conftestf.f90])
|
|
|
|
AC_MSG_WARN([Could not determine size of $1])
|
|
|
|
AC_MSG_WARN([See config.log for details])
|
|
|
|
AC_MSG_ERROR([Cannot continue])
|
|
|
|
fi
|
2005-01-08 00:17:48 +03:00
|
|
|
|
2006-02-12 18:11:36 +03:00
|
|
|
AS_IF([test "$cross_compiling" = "yes"],
|
|
|
|
[AC_MSG_ERROR([Can not determine size of $1 when cross-compiling])],
|
|
|
|
[OMPI_LOG_COMMAND([./conftest],
|
|
|
|
[AS_VAR_SET(type_var, [`cat conftestval`])],
|
|
|
|
[AC_MSG_ERROR([Could not determine size of $1])])])
|
2005-01-08 00:17:48 +03:00
|
|
|
|
2006-02-12 18:11:36 +03:00
|
|
|
unset happy ompi_conftest_h
|
|
|
|
rm -f conftest*])
|
2005-01-08 00:17:48 +03:00
|
|
|
|
2006-02-12 18:11:36 +03:00
|
|
|
$2=AS_VAR_GET(type_var)
|
|
|
|
AS_VAR_POPDEF([type_var])dnl
|
|
|
|
])dnl
|