      SUBROUTINE  p_comm(  p, ptabN, ptabE, ptabS, ptabW, ptabAV, ptabAR, voisin  )
      USE numerics
      IMPLICIT  NONE
      INCLUDE 'comthd.h'
      INCLUDE 'p_comptr.h'
      REAL(rp),  DIMENSION(sx-1:ex+1,sy-1:ey+1,sz-1:ez+1),  INTENT(INOUT)  ::  p
      REAL(rp),  DIMENSION(sy:ey,sz:ez),  INTENT(OUT)  ::  ptabE
      REAL(rp),  DIMENSION(sy:ey,sz:ez),  INTENT(OUT)  ::  ptabW
      REAL(rp),  DIMENSION(sx:ex,sz:ez),  INTENT(OUT)  ::  ptabS
      REAL(rp),  DIMENSION(sx:ex,sz:ez),  INTENT(OUT)  ::  ptabN
      REAL(rp),  DIMENSION(sx:ex,sy:ey),  INTENT(OUT)  ::  ptabAV
      REAL(rp),  DIMENSION(sx:ex,sy:ey),  INTENT(OUT)  ::  ptabAR
      INTEGER,  PARAMETER  ::  NB_VOISINS  =  6
      INTEGER,  PARAMETER  ::  N=1,  E=2,  S=3,  W=4,  AV=5,  AR=6
      INTEGER,  DIMENSION(NB_VOISINS),  INTENT(IN)  ::  voisin
      END  SUBROUTINE  p_comm
