Actual source code: zmpisbaijf.c

  1: #include <petsc/private/fortranimpl.h>
  2: #include <petscmat.h>

  4: #if defined(PETSC_HAVE_FORTRAN_CAPS)
  5:   #define matcreatesbaij_              MATCREATESBAIJ
  6:   #define matmpisbaijsetpreallocation_ MATMPISBAIJSETPREALLOCATION
  7: #elif !defined(PETSC_HAVE_FORTRAN_UNDERSCORE)
  8:   #define matcreatesbaij_              matcreatesbaij
  9:   #define matmpisbaijsetpreallocation_ matmpisbaijsetpreallocation
 10: #endif

 12: PETSC_EXTERN void matcreatesbaij_(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)
 13: {
 14:   CHKFORTRANNULLINTEGER(d_nnz);
 15:   CHKFORTRANNULLINTEGER(o_nnz);
 16:   *ierr = MatCreateSBAIJ(MPI_Comm_f2c(*(MPI_Fint *)&*comm), *bs, *m, *n, *M, *N, *d_nz, d_nnz, *o_nz, o_nnz, newmat);
 17: }

 19: PETSC_EXTERN void matmpisbaijsetpreallocation_(Mat *mat, PetscInt *bs, PetscInt *d_nz, PetscInt *d_nnz, PetscInt *o_nz, PetscInt *o_nnz, PetscErrorCode *ierr)
 20: {
 21:   CHKFORTRANNULLINTEGER(d_nnz);
 22:   CHKFORTRANNULLINTEGER(o_nnz);
 23:   *ierr = MatMPISBAIJSetPreallocation(*mat, *bs, *d_nz, d_nnz, *o_nz, o_nnz);
 24: }