# PCShellSetPostSolve
Sets routine to apply to the operators/vectors before a `KSPSolve()` is applied. This usually does something like scale the linear system in some application specific way. 
## Synopsis
```
#include "petscpc.h" 
PetscErrorCode PCShellSetPostSolve(PC pc, PetscErrorCode (*postsolve)(PC, KSP, Vec, Vec))
```
Logically Collective


## Input Parameters

- ***pc -*** the preconditioner context
- ***postsolve -*** the application-provided presolve routine



## Calling sequence of postsolve
```none
   PetscErrorCode postsolve(PC,KSP ksp,Vec b,Vec x)
```



- ***pc -*** the preconditioner, get the application context with `PCShellGetContext()`
- ***xin -*** input vector
- ***xout -*** output vector



## Note
the function MUST return an error code of 0 on success and nonzero on failure.




## See Also
 `PCSHELL`, `PCShellSetApplyRichardson()`, `PCShellSetSetUp()`, `PCShellSetApplyTranspose()`, `PCShellSetPreSolve()`, `PCShellSetContext()`

## Level
advanced

## Location
<A HREF="PETSC_DOC_OUT_ROOT_PLACEHOLDER/src/ksp/pc/impls/shell/shellpc.c.html#PCShellSetPostSolve">src/ksp/pc/impls/shell/shellpc.c</A>

## Implementations

<A HREF="PETSC_DOC_OUT_ROOT_PLACEHOLDER/src/ksp/pc/impls/shell/shellpc.c.html#PCShellSetPostSolve_Shell(PC pc, PetscErrorCode (*postsolve)">PCShellSetPostSolve_Shell(PC pc, PetscErrorCode (*postsolve) in src/ksp/pc/impls/shell/shellpc.c</A><BR>


---
[Edit on GitLab](https://gitlab.com/petsc/petsc/-/edit/release/src/ksp/pc/impls/shell/shellpc.c)


[Index of all PC routines](index.md)  
[Table of Contents for all manual pages](/docs/manualpages/index.md)  
[Index of all manual pages](/docs/manualpages/singleindex.md)  
