1*b45d2f2cSJed Brown #include <petsc-private/fortranimpl.h> 2c6db04a5SJed Brown #include <petscmat.h> 3f4e70085SSatish Balay 4f4e70085SSatish Balay #if defined(PETSC_HAVE_FORTRAN_CAPS) 5f4e70085SSatish Balay #define matmpibaijgetseqbaij_ MATMPIBAIJGETSEQBAIJ 669b1f4b7SBarry Smith #define matcreatebaij_ MATCREATEBAIJ 7f4e70085SSatish Balay #define matmpibaijsetpreallocation_ MATMPIBAIJSETPREALLOCATION 8f4e70085SSatish Balay #elif !defined(PETSC_HAVE_FORTRAN_UNDERSCORE) 9f4e70085SSatish Balay #define matmpibaijgetseqbaij_ matmpibaijgetseqbaij 1069b1f4b7SBarry Smith #define matcreatebaij_ matcreatebaij 11f4e70085SSatish Balay #define matmpibaijsetpreallocation_ matmpibaijsetpreallocation 12f4e70085SSatish Balay #endif 13f4e70085SSatish Balay 14f4e70085SSatish Balay EXTERN_C_BEGIN 15f4e70085SSatish Balay 16f4e70085SSatish Balay void PETSC_STDCALL matmpibaijgetseqbaij_(Mat *A,Mat *Ad,Mat *Ao,PetscInt *ic,size_t *iic,PetscErrorCode *ierr) 17f4e70085SSatish Balay { 18f4e70085SSatish Balay PetscInt *i; 19f4e70085SSatish Balay *ierr = MatMPIBAIJGetSeqBAIJ(*A,Ad,Ao,&i);if (*ierr) return; 20f4e70085SSatish Balay *iic = PetscIntAddressToFortran(ic,i); 21f4e70085SSatish Balay } 22f4e70085SSatish Balay 2369b1f4b7SBarry Smith void PETSC_STDCALL matcreatebaij_(MPI_Comm *comm,PetscInt *bs,PetscInt *m,PetscInt *n,PetscInt *M,PetscInt *N, 24f4e70085SSatish Balay PetscInt *d_nz,PetscInt *d_nnz,PetscInt *o_nz,PetscInt *o_nnz,Mat *newmat,PetscErrorCode *ierr) 25f4e70085SSatish Balay { 26f4e70085SSatish Balay CHKFORTRANNULLINTEGER(d_nnz); 27f4e70085SSatish Balay CHKFORTRANNULLINTEGER(o_nnz); 2869b1f4b7SBarry Smith *ierr = MatCreateBAIJ(MPI_Comm_f2c(*(MPI_Fint *)&*comm),*bs,*m,*n,*M,*N,*d_nz,d_nnz,*o_nz,o_nnz,newmat); 29f4e70085SSatish Balay } 30f4e70085SSatish Balay 31f4e70085SSatish Balay void PETSC_STDCALL matmpibaijsetpreallocation_(Mat *mat,PetscInt *bs,PetscInt *d_nz,PetscInt *d_nnz,PetscInt *o_nz,PetscInt *o_nnz,PetscErrorCode *ierr) 32f4e70085SSatish Balay { 33f4e70085SSatish Balay CHKFORTRANNULLINTEGER(d_nnz); 34f4e70085SSatish Balay CHKFORTRANNULLINTEGER(o_nnz); 35f4e70085SSatish Balay *ierr = MatMPIBAIJSetPreallocation(*mat,*bs,*d_nz,d_nnz,*o_nz,o_nnz); 36f4e70085SSatish Balay } 37f4e70085SSatish Balay 38f4e70085SSatish Balay EXTERN_C_END 39