xref: /petsc/src/ksp/pc/impls/bjacobi/ftn-custom/zbjacobif.c (revision af0996ce37bc06907c37d8d91773840993d61e62)
1*af0996ceSBarry Smith #include <petsc/private/fortranimpl.h>
2c6db04a5SJed Brown #include <petscksp.h>
3e54e4138SSatish Balay 
4e54e4138SSatish Balay #if defined(PETSC_HAVE_FORTRAN_CAPS)
5e54e4138SSatish Balay #define pcbjacobigetsubksp_        PCBJACOBIGETSUBKSP
6e54e4138SSatish Balay #elif !defined(PETSC_HAVE_FORTRAN_UNDERSCORE)
7e54e4138SSatish Balay #define pcbjacobigetsubksp_        pcbjacobigetsubksp
8e54e4138SSatish Balay #endif
9e54e4138SSatish Balay 
108cc058d9SJed Brown PETSC_EXTERN void PETSC_STDCALL pcbjacobigetsubksp_(PC *pc,PetscInt *n_local,PetscInt *first_local,KSP *ksp,PetscErrorCode *ierr)
11e54e4138SSatish Balay {
12e54e4138SSatish Balay   KSP      *tksp;
13e54e4138SSatish Balay   PetscInt i,nloc;
14e54e4138SSatish Balay   CHKFORTRANNULLINTEGER(n_local);
15e54e4138SSatish Balay   CHKFORTRANNULLINTEGER(first_local);
16de0953f6SBarry Smith   *ierr = PCBJacobiGetSubKSP(*pc,&nloc,first_local,&tksp); if (*ierr) return;
17e54e4138SSatish Balay   if (n_local) *n_local = nloc;
1812c1112bSBarry Smith   CHKFORTRANNULLOBJECT(ksp);
1912c1112bSBarry Smith   if (ksp) {
20e54e4138SSatish Balay     for (i=0; i<nloc; i++) {
21e54e4138SSatish Balay       ksp[i] = tksp[i];
22e54e4138SSatish Balay     }
23e54e4138SSatish Balay   }
2412c1112bSBarry Smith }
25