petsc-3.9.4 2018-09-11
Report Typos and Errors

VecCUDAGetArrayRead

Provides read access to the CUDA buffer inside a vector.

Synopsis

PETSC_EXTERN PetscErrorCode VecCUDAGetArrayRead(Vec v, const PetscScalar **a)
This function is analogous to VecGetArrayRead(): The pointer returned by this function points to a consistent view of the vector data. This may involve a copy operation of data from the host to the device if the data on the device is out of date. If the device memory hasn't been allocated previously it will be allocated as part of this function call. VecCUDAGetArrayRead() assumes that the user will not modify the vector data. This is analgogous to intent(in) in Fortran.

The CUDA device pointer has to be released by calling VecCUDARestoreArrayRead(). If the data on the host side was previously up to date it will remain so, i.e. data on both the device and the host is up to date. Accessing data on the host side does not incur a device to host data transfer.

Input Parameter

v -the vector

Output Parameter

a -the CUDA pointer.

Fortran note

This function is not currently available from Fortran.

See Also

VecCUDARestoreArrayRead(), VecCUDAGetArrayReadWrite(), VecCUDAGetArrayWrite(), VecGetArray(), VecGetArrayRead()

Level

intermediate

Location

src/vec/vec/impls/seq/seqcuda/veccuda2.cu

Examples

src/snes/examples/tutorials/ex47cu.cu.html

Index of all Vec routines
Table of Contents for all manual pages
Index of all manual pages