Actual source code: petscsysbase.h
1: !
2: ! Manually maintained part of the base include file for Fortran use of PETSc.
3: ! Note: This file should contain only define statements
4: !
5: #if !defined (PETSCSYSBASEDEF_H)
6: #define PETSCSYSBASEDEF_H
7: #include "petscconf.h"
8: #if defined (PETSC_HAVE_MPIUNI)
9: #include "petsc/mpiuni/mpiunifdef.h"
10: #endif
11: #include "petscversion.h"
13: !
14: ! The real*8,complex*16 notatiton is used so that the
15: ! PETSc double/complex variables are not affected by
16: ! compiler options like -r4,-r8, that are sometimes invoked
17: ! by the user. NAG compiler does not like integer*4,real*8
19: #define integer8 integer(kind=selected_int_kind(10))
20: #define integer4 integer(kind=selected_int_kind(5))
21: #define integer2 integer(kind=selected_int_kind(3))
22: #define integer1 integer(kind=selected_int_kind(1))
23: #define PetscBool logical(kind=4)
25: #if (PETSC_SIZEOF_VOID_P == 8)
26: #define PetscOffset integer8
27: #define PetscFortranAddr integer8
28: #else
29: #define PetscOffset integer4
30: #define PetscFortranAddr integer4
31: #endif
33: #if defined(PETSC_USE_64BIT_INDICES)
34: #define PetscInt integer8
35: #else
36: #define PetscInt integer4
37: #endif
38: #define PetscInt64 integer8
40: #if defined(PETSC_USE_64BIT_BLAS_INDICES)
41: #define PetscBLASInt integer8
42: #else
43: #define PetscBLASInt integer4
44: #endif
45: #define PetscCuBLASInt integer4
46: #define PetscHipBLASInt integer4
48: !
49: ! Fortran does not support unsigned, though ISO_C_BINDING
50: ! supports INTEGER(KIND=C_SIZE_T). We don't use that here
51: ! only to avoid importing the module.
52: #if (PETSC_SIZEOF_SIZE_T == 8)
53: #define PetscSizeT integer8
54: #else
55: #define PetscSizeT integer4
56: #endif
57: !
58: #define MPI_Comm integer4
59: #define MPI_Group integer4
60: !
61: #define PetscEnum integer4
62: #define PetscVoid PetscFortranAddr
63: !
64: #define PetscFortranFloat real(kind=selected_real_kind(5))
65: #define PetscFortranDouble real(kind=selected_real_kind(10))
66: #define PetscFortranLongDouble real(kind=selected_real_kind(19))
67: #if defined(PETSC_USE_REAL_SINGLE)
68: #define PetscComplex complex(kind=selected_real_kind(5))
69: #elif defined(PETSC_USE_REAL_DOUBLE)
70: #define PetscComplex complex(kind=selected_real_kind(10))
71: #elif defined(PETSC_USE_REAL___FLOAT128)
72: #define PetscComplex complex(kind=selected_real_kind(20))
73: #endif
75: #if defined(PETSC_USE_COMPLEX)
76: #define PETSC_SCALAR PETSC_COMPLEX
77: #else
78: #if defined(PETSC_USE_REAL_SINGLE)
79: #define PETSC_SCALAR PETSC_FLOAT
80: #elif defined(PETSC_USE_REAL___FLOAT128)
81: #define PETSC_SCALAR PETSC___FLOAT128
82: #else
83: #define PETSC_SCALAR PETSC_DOUBLE
84: #endif
85: #endif
86: #if defined(PETSC_USE_REAL_SINGLE)
87: #define PETSC_REAL PETSC_FLOAT
88: #define PetscIntToReal(a) real(a)
89: #elif defined(PETSC_USE_REAL___FLOAT128)
90: #define PETSC_REAL PETSC___FLOAT128
91: #define PetscIntToReal(a) dble(a)
92: #else
93: #define PETSC_REAL PETSC_DOUBLE
94: #define PetscIntToReal(a) dble(a)
95: #endif
96: !
97: ! Macro for templating between real and complex
98: !
99: #if defined(PETSC_USE_COMPLEX)
100: #define PetscScalar PetscComplex
101: !
102: ! F90 uses real(), conjg() when KIND parameter is used.
103: !
104: #define PetscRealPart(a) real(a)
105: #define PetscConj(a) conjg(a)
106: #define PetscImaginaryPart(a) aimag(a)
107: #else
108: #if defined (PETSC_USE_REAL_SINGLE)
109: #define PetscScalar PetscFortranFloat
110: #elif defined(PETSC_USE_REAL___FLOAT128)
111: #define PetscScalar PetscFortranLongDouble
112: #elif defined(PETSC_USE_REAL_DOUBLE)
113: #define PetscScalar PetscFortranDouble
114: #endif
115: #define PetscRealPart(a) a
116: #define PetscConj(a) a
117: #define PetscImaginaryPart(a) 0.0
118: #endif
120: #if defined (PETSC_USE_REAL_SINGLE)
121: #define PetscReal PetscFortranFloat
122: #elif defined(PETSC_USE_REAL___FLOAT128)
123: #define PetscReal PetscFortranLongDouble
124: #elif defined(PETSC_USE_REAL_DOUBLE)
125: #define PetscReal PetscFortranDouble
126: #endif
128: #define PetscReal2d type(tPetscReal2d)
130: #define PetscObjectIsNull(obj) (obj%v == 0 .or. obj%v == -2 .or. obj%v == -3)
131: !
132: ! Macros for error checking
133: !
134: #define SETERRQ(c, ierr, s) call PetscError(c, ierr, 0, s); return
135: #define SETERRA(c, ierr, s) call PetscError(c, ierr, 0, s); call MPIU_Abort(c, ierr)
136: #if defined(PETSC_HAVE_FORTRAN_FREE_LINE_LENGTH_NONE)
137: #define CHKERRQ(ierr) if (ierr .ne. 0) then;call PetscErrorF(ierr,__LINE__,__FILE__);return;endif
138: #define CHKERRA(ierr) if (ierr .ne. 0) then;call PetscErrorF(ierr,__LINE__,__FILE__);call MPIU_Abort(PETSC_COMM_SELF,ierr);endif
139: #define CHKERRMPI(ierr) if (ierr .ne. 0) then;call PetscErrorMPI(ierr,__LINE__,__FILE__);return;endif
140: #define CHKERRMPIA(ierr) if (ierr .ne. 0) then;call PetscErrorMPI(ierr,__LINE__,__FILE__);call MPIU_Abort(PETSC_COMM_SELF,ierr);endif
141: #else
142: #define CHKERRQ(ierr) if (ierr .ne. 0) then;call PetscErrorF(ierr);return;endif
143: #define CHKERRA(ierr) if (ierr .ne. 0) then;call PetscErrorF(ierr);call MPIU_Abort(PETSC_COMM_SELF,ierr);endif
144: #define CHKERRMPI(ierr) if (ierr .ne. 0) then;call PetscErrorMPI(ierr);return;endif
145: #define CHKERRMPIA(ierr) if (ierr .ne. 0) then;call PetscErrorMPI(ierr);call MPIU_Abort(PETSC_COMM_SELF,ierr);endif
146: #endif
147: #define CHKMEMQ call chkmemfortran(__LINE__,__FILE__,ierr)
148: #define PetscCall(func) call func; CHKERRQ(ierr)
149: #define PetscCallMPI(func) call func; CHKERRMPI(ierr)
150: #define PetscCallA(func) call func; CHKERRA(ierr)
151: #define PetscCallMPIA(func) call func; CHKERRMPIA(ierr)
152: #define PetscCheckA(err, c, ierr, s) if (.not.(err)) then; SETERRA(c, ierr, s); endif
153: #define PetscCheck(err, c, ierr, s) if (.not.(err)) then; SETERRQ(c, ierr, s); endif
155: #if !defined(PetscFlush)
156: #if defined(PETSC_HAVE_FORTRAN_FLUSH)
157: #define PetscFlush(a) flush(a)
158: #elif defined(PETSC_HAVE_FORTRAN_FLUSH_)
159: #define PetscFlush(a) flush_(a)
160: #else
161: #define PetscFlush(a)
162: #endif
163: #endif
165: #define PetscEnumCase(e) case(e%v)
167: #define PetscObjectSpecificCast(sp,ob) sp%v = ob%v
169: #endif