#include "zpetsc.h" #include "petscmat.h" #if defined(PETSC_HAVE_FORTRAN_CAPS) #define matmpibaijgetseqbaij_ MATMPIBAIJGETSEQBAIJ #define matcreatempibaij_ MATCREATEMPIBAIJ #define matmpibaijsetpreallocation_ MATMPIBAIJSETPREALLOCATION #elif !defined(PETSC_HAVE_FORTRAN_UNDERSCORE) #define matmpibaijgetseqbaij_ matmpibaijgetseqbaij #define matcreatempibaij_ matcreatempibaij #define matmpibaijsetpreallocation_ matmpibaijsetpreallocation #endif EXTERN_C_BEGIN void PETSC_STDCALL matmpibaijgetseqbaij_(Mat *A,Mat *Ad,Mat *Ao,PetscInt *ic,size_t *iic,PetscErrorCode *ierr) { PetscInt *i; *ierr = MatMPIBAIJGetSeqBAIJ(*A,Ad,Ao,&i);if (*ierr) return; *iic = PetscIntAddressToFortran(ic,i); } void PETSC_STDCALL matcreatempibaij_(MPI_Comm *comm,PetscInt *bs,PetscInt *m,PetscInt *n,PetscInt *M,PetscInt *N, PetscInt *d_nz,PetscInt *d_nnz,PetscInt *o_nz,PetscInt *o_nnz,Mat *newmat,PetscErrorCode *ierr) { CHKFORTRANNULLINTEGER(d_nnz); CHKFORTRANNULLINTEGER(o_nnz); *ierr = MatCreateMPIBAIJ((MPI_Comm)PetscToPointerComm(*comm), *bs,*m,*n,*M,*N,*d_nz,d_nnz,*o_nz,o_nnz,newmat); } void PETSC_STDCALL matmpibaijsetpreallocation_(Mat *mat,PetscInt *bs,PetscInt *d_nz,PetscInt *d_nnz,PetscInt *o_nz,PetscInt *o_nnz,PetscErrorCode *ierr) { CHKFORTRANNULLINTEGER(d_nnz); CHKFORTRANNULLINTEGER(o_nnz); *ierr = MatMPIBAIJSetPreallocation(*mat,*bs,*d_nz,d_nnz,*o_nz,o_nnz); } EXTERN_C_END