:orphan: # PetscBarrier Blocks until this routine is executed by all processors owning the object `obj`. ## Synopsis ``` #include "petscsys.h" PetscErrorCode PetscBarrier(PetscObject obj) ``` ## Input Parameter - ***obj -*** PETSc object (`Mat`, `Vec`, `IS`, `SNES` etc...) The object must be cast with a (`PetscObject`). `NULL` can be used to indicate the barrier should be across `PETSC_COMM_WORLD` ## Developer Note This routine calls `MPI_Barrier()` with the communicator of the `PetscObject` ## Fortran Note You may pass `PETSC_NULL_VEC` or any other PETSc null object, such as `PETSC_NULL_MAT`, to indicate the barrier should be across `PETSC_COMM_WORLD`. You can also pass in any PETSc object, `Vec`, `Mat`, etc ## Level intermediate ## Location src/sys/utils/pbarrier.c ## Examples src/dm/tutorials/ex22.c
src/snes/tutorials/ex63.c
src/tao/pde_constrained/tutorials/elliptic.c
src/tao/pde_constrained/tutorials/hyperbolic.c
src/tao/pde_constrained/tutorials/parabolic.c
src/vec/vec/tutorials/performance.c
--- [Edit on GitLab](https://gitlab.com/petsc/petsc/-/edit/release/src/sys/utils/pbarrier.c) [Index of all Sys routines](index.md) [Table of Contents for all manual pages](/manualpages/index.md) [Index of all manual pages](/manualpages/singleindex.md)