Actual source code: zfddaf90.c

  1: #include <petsc/private/f90impl.h>
  2: #include <petscdmcomposite.h>

  4: #if defined(PETSC_HAVE_FORTRAN_CAPS)
  5:   #define dmcompositegetaccessvpvp_     DMCOMPOSITEGETACCESSVPVP
  6:   #define dmcompositerestoreaccessvpvp_ DMCOMPOSITERESTOREACCESSVPVP
  7: #elif !defined(PETSC_HAVE_FORTRAN_UNDERSCORE)
  8:   #define dmcompositegetaccessvpvp_     dmcompositegetaccessvpvp
  9:   #define dmcompositerestoreaccessvpvp_ dmcompositerestoreaccessvpvp
 10: #endif

 12: PETSC_EXTERN void dmcompositegetaccessvpvp_(DM *dm, Vec *v, Vec *v1, F90Array1d *p1, Vec *v2, F90Array1d *p2, PetscErrorCode *ierr PETSC_F90_2PTR_PROTO(ptrd1) PETSC_F90_2PTR_PROTO(ptrd2))
 13: {
 14:   PetscScalar *pp1, *pp2;
 15:   PetscInt     np1, np2;
 16:   *ierr = DMCompositeGetEntries(*dm, 0, &np1, 0, &np2);
 17:   *ierr = DMCompositeGetAccess(*dm, *v, v1, &pp1, v2, &pp2);
 18:   *ierr = F90Array1dCreate(pp1, MPIU_SCALAR, 0, np1 - 1, p1 PETSC_F90_2PTR_PARAM(ptrd1));
 19:   *ierr = F90Array1dCreate(pp2, MPIU_SCALAR, 0, np2 - 1, p2 PETSC_F90_2PTR_PARAM(ptrd2));
 20: }

 22: PETSC_EXTERN void dmcompositerestoreaccessvpvp_(DM *dm, Vec *v, Vec *v1, F90Array1d *p1, Vec *v2, F90Array1d *p2, PetscErrorCode *ierr PETSC_F90_2PTR_PROTO(ptrd1) PETSC_F90_2PTR_PROTO(ptrd2))
 23: {
 24:   *ierr = DMCompositeRestoreAccess(*dm, *v, v1, 0, v2, 0);
 25:   *ierr = F90Array1dDestroy(p1, MPIU_SCALAR PETSC_F90_2PTR_PARAM(ptrd1));
 26:   *ierr = F90Array1dDestroy(p2, MPIU_SCALAR PETSC_F90_2PTR_PARAM(ptrd2));
 27: }