#include #if defined(PETSC_HAVE_FORTRAN_CAPS) #define petscinitializefortran_ PETSCINITIALIZEFORTRAN #define petscsetmoduleblock_ PETSCSETMODULEBLOCK #define petscsetfortranbasepointers_ PETSCSETFORTRANBASEPOINTERS #define petsc_null_function_ PETSC_NULL_FUNCTION #define petscsetmoduleblocknumeric_ PETSCSETMODULEBLOCKNUMERIC #define petscsetcomm_ PETSCSETCOMM #elif !defined(PETSC_HAVE_FORTRAN_UNDERSCORE) #define petscinitializefortran_ petscinitializefortran #define petscsetmoduleblock_ petscsetmoduleblock #define petscsetfortranbasepointers_ petscsetfortranbasepointers #define petsc_null_function_ petsc_null_function #define petscsetmoduleblocknumeric_ petscsetmoduleblocknumeric #define petscsetcomm_ petscsetcomm #endif #if defined(PETSC_HAVE_FORTRAN_UNDERSCORE_UNDERSCORE) #define petsc_null_function_ petsc_null_function__ #endif PETSC_EXTERN void PETSC_STDCALL petscsetmoduleblock_(); PETSC_EXTERN void PETSC_STDCALL petscsetmoduleblockmpi_(MPI_Fint*,MPI_Fint*,MPI_Fint*); PETSC_EXTERN void PETSC_STDCALL petscsetmoduleblocknumeric_(PetscReal*,PetscReal*,PetscReal*,PetscReal*,PetscReal*,PetscReal*,PetscReal*,PetscReal*); PETSC_EXTERN void PETSC_STDCALL petscsetcomm_(MPI_Fint*,MPI_Fint*); /*@C PetscInitializeFortran - Routine that should be called soon AFTER the call to PetscInitialize() if one is using a C main program that calls Fortran routines that in turn call PETSc routines. Collective on PETSC_COMM_WORLD Level: beginner Notes: PetscInitializeFortran() initializes some of the default viewers, communicators, etc. for use in the Fortran if a user's main program is written in C. PetscInitializeFortran() is NOT needed if a user's main program is written in Fortran; in this case, just calling PetscInitialize() in the main (Fortran) program is sufficient. .seealso: PetscInitialize() .keywords: Mixing C and Fortran, passing PETSc objects to Fortran @*/ PetscErrorCode PetscInitializeFortran(void) { MPI_Fint c1=0,c2=0; if (PETSC_COMM_WORLD) c1 = MPI_Comm_c2f(PETSC_COMM_WORLD); c2 = MPI_Comm_c2f(PETSC_COMM_SELF); petscsetmoduleblock_(); petscsetcomm_(&c1,&c2); #if defined(PETSC_USE_REAL___FLOAT128) { MPI_Fint freal,fscalar,fsum; freal = MPI_Type_c2f(MPIU_REAL); fscalar = MPI_Type_c2f(MPIU_SCALAR); fsum = MPI_Op_c2f(MPIU_SUM); petscsetmoduleblockmpi_(&freal,&fscalar,&fsum); } #endif { PetscReal pi = PETSC_PI; PetscReal maxreal = PETSC_MAX_REAL; PetscReal minreal = PETSC_MIN_REAL; PetscReal eps = PETSC_MACHINE_EPSILON; PetscReal seps = PETSC_SQRT_MACHINE_EPSILON; PetscReal small = PETSC_SMALL; PetscReal pinf = PETSC_INFINITY; PetscReal pninf = PETSC_NINFINITY; petscsetmoduleblocknumeric_(&pi,&maxreal,&minreal,&eps,&seps,&small,&pinf,&pninf); } return 0; } PETSC_EXTERN void PETSC_STDCALL petscinitializefortran_(int *ierr) { *ierr = PetscInitializeFortran(); } PETSC_EXTERN void PETSC_STDCALL petscsetfortranbasepointers_(char *fnull_character PETSC_MIXED_LEN(len), void *fnull_integer,void *fnull_scalar,void * fnull_double, void *fnull_real, void* fnull_truth,void (*fnull_function)(void) PETSC_END_LEN(len)) { PETSC_NULL_CHARACTER_Fortran = fnull_character; PETSC_NULL_INTEGER_Fortran = fnull_integer; PETSC_NULL_SCALAR_Fortran = fnull_scalar; PETSC_NULL_DOUBLE_Fortran = fnull_double; PETSC_NULL_REAL_Fortran = fnull_real; PETSC_NULL_BOOL_Fortran = fnull_truth; PETSC_NULL_FUNCTION_Fortran = fnull_function; } /* A valid address for the fortran variable PETSC_NULL_FUNCTION */ PETSC_EXTERN void petsc_null_function_(void) { return; }