Actual source code: mcudahost.cu
1: #include <petscsys.h>
2: #include <petscdevice_cuda.h>
4: static PetscErrorCode PetscCUDAHostMalloc(size_t a, PetscBool, int, const char[], const char[], void **result)
5: {
6: PetscCallCUDA(cudaMallocHost(result, a));
7: return PETSC_SUCCESS;
8: }
10: static PetscErrorCode PetscCUDAHostFree(void *aa, int, const char[], const char[])
11: {
12: PetscCallCUDA(cudaFreeHost(aa));
13: return PETSC_SUCCESS;
14: }
16: static PetscErrorCode PetscCUDAHostRealloc(size_t, int, const char[], const char[], void **)
17: {
18: SETERRQ(PETSC_COMM_SELF, PETSC_ERR_MEM, "CUDA has no Realloc()");
19: }
21: static PetscErrorCode (*PetscMallocOld)(size_t, PetscBool, int, const char[], const char[], void **);
22: static PetscErrorCode (*PetscReallocOld)(size_t, int, const char[], const char[], void **);
23: static PetscErrorCode (*PetscFreeOld)(void *, int, const char[], const char[]);
25: /*@
26: PetscMallocSetCUDAHost - Set `PetscMalloc()` to use `CUDAHostMalloc()`
27: Switch the current malloc and free routines to the CUDA malloc and free routines
29: Not Collective
31: Level: developer
33: Note:
34: This provides a way to use the CUDA malloc and free routines temporarily. One
35: can switch back to the previous choice by calling `PetscMallocResetCUDAHost()`.
37: .seealso: `PetscCUDAHostMalloc()`, `PetscMallocResetCUDAHost()`, `PetscMallocSetHIPHost()`
38: @*/
39: PetscErrorCode PetscMallocSetCUDAHost(void)
40: {
41: PetscFunctionBegin;
42: /* Save the previous choice */
43: PetscMallocOld = PetscTrMalloc;
44: PetscReallocOld = PetscTrRealloc;
45: PetscFreeOld = PetscTrFree;
46: PetscTrMalloc = PetscCUDAHostMalloc;
47: PetscTrRealloc = PetscCUDAHostRealloc;
48: PetscTrFree = PetscCUDAHostFree;
49: PetscFunctionReturn(PETSC_SUCCESS);
50: }
52: /*@
53: PetscMallocResetCUDAHost - Reset the changes made by `PetscMallocSetCUDAHost()`
55: Not Collective
57: Level: developer
59: .seealso: `PetscCUDAHostMalloc()`, `PetscMallocSetCUDAHost()`
60: @*/
61: PetscErrorCode PetscMallocResetCUDAHost(void)
62: {
63: PetscFunctionBegin;
64: PetscTrMalloc = PetscMallocOld;
65: PetscTrRealloc = PetscReallocOld;
66: PetscTrFree = PetscFreeOld;
67: PetscFunctionReturn(PETSC_SUCCESS);
68: }