MFEM v4.9.0
Finite element discretization library
Loading...
Searching...
No Matches
hip.hpp
Go to the documentation of this file.
1// Copyright (c) 2010-2025, Lawrence Livermore National Security, LLC. Produced
2// at the Lawrence Livermore National Laboratory. All Rights reserved. See files
3// LICENSE and NOTICE for details. LLNL-CODE-806117.
4//
5// This file is part of the MFEM library. For more information and source code
6// availability visit https://mfem.org.
7//
8// MFEM is free software; you can redistribute it and/or modify it under the
9// terms of the BSD-3 license. We welcome feedback and contributions, see file
10// CONTRIBUTING.md for details.
11
12#ifndef MFEM_HIP_HPP
13#define MFEM_HIP_HPP
14
15#include "../config/config.hpp"
16#include "error.hpp"
17
18// HIP block size used by MFEM.
19#define MFEM_HIP_BLOCKS 256
20
21#if defined(MFEM_USE_HIP) && defined(__HIP__)
22#define MFEM_USE_CUDA_OR_HIP
23#define MFEM_DEVICE __device__
24#define MFEM_HOST __host__
25#define MFEM_LAMBDA __host__ __device__
26// #define MFEM_HOST_DEVICE __host__ __device__ // defined in config/config.hpp
27#define MFEM_DEVICE_SYNC MFEM_GPU_CHECK(hipDeviceSynchronize())
28#define MFEM_STREAM_SYNC MFEM_GPU_CHECK(hipStreamSynchronize(0))
29// Define a HIP error check macro, MFEM_GPU_CHECK(x), where x returns/is of
30// type 'hipError_t'. This macro evaluates 'x' and raises an error if the
31// result is not hipSuccess.
32#define MFEM_GPU_CHECK(x) \
33 do { \
34 hipError_t mfem_err_internal_var_name = (x); \
35 if (mfem_err_internal_var_name != hipSuccess) { \
36 ::mfem::mfem_hip_error(mfem_err_internal_var_name, #x, _MFEM_FUNC_NAME, \
37 __FILE__, __LINE__); \
38 } \
39 } while (0)
40
41// Define the MFEM inner threading macros
42#if defined(__HIP_DEVICE_COMPILE__)
43#define MFEM_SHARED __shared__
44#define MFEM_SYNC_THREAD __syncthreads()
45#define MFEM_BLOCK_ID(k) hipBlockIdx_ ##k
46#define MFEM_THREAD_ID(k) hipThreadIdx_ ##k
47#define MFEM_THREAD_SIZE(k) hipBlockDim_ ##k
48#define MFEM_FOREACH_THREAD(i,k,N) \
49 for(int i=hipThreadIdx_ ##k; i<N; i+=hipBlockDim_ ##k)
50#define MFEM_FOREACH_THREAD_DIRECT(i,k,N) \
51 if(const int i=hipThreadIdx_ ##k; i<N)
52#endif // defined(__HIP_DEVICE_COMPILE__)
53#endif // defined(MFEM_USE_HIP) && defined(__HIP__)
54
55namespace mfem
56{
57
58#ifdef MFEM_USE_HIP
59// Function used by the macro MFEM_GPU_CHECK.
60void mfem_hip_error(hipError_t err, const char *expr, const char *func,
61 const char *file, int line);
62#endif
63
64/// Allocates device memory
65void* HipMemAlloc(void **d_ptr, size_t bytes);
66
67/// Allocates managed device memory
68void* HipMallocManaged(void **d_ptr, size_t bytes);
69
70/// Allocates page-locked (pinned) host memory
71void* HipMemAllocHostPinned(void **ptr, size_t bytes);
72
73/// Frees device memory
74void* HipMemFree(void *d_ptr);
75
76/// Frees page-locked (pinned) host memory and returns destination ptr.
77void* HipMemFreeHostPinned(void *ptr);
78
79/// Copies memory from Host to Device
80void* HipMemcpyHtoD(void *d_dst, const void *h_src, size_t bytes);
81
82/// Copies memory from Host to Device
83void* HipMemcpyHtoDAsync(void *d_dst, const void *h_src, size_t bytes);
84
85/// Copies memory from Device to Device
86void* HipMemcpyDtoD(void *d_dst, const void *d_src, size_t bytes);
87
88/// Copies memory from Device to Device
89void* HipMemcpyDtoDAsync(void *d_dst, const void *d_src, size_t bytes);
90
91/// Copies memory from Device to Host
92void* HipMemcpyDtoH(void *h_dst, const void *d_src, size_t bytes);
93
94/// Copies memory from Device to Host
95void* HipMemcpyDtoHAsync(void *h_dst, const void *d_src, size_t bytes);
96
97/// Check the error code returned by hipGetLastError(), aborting on error.
99
100/// Get the number of HIP devices
102
103} // namespace mfem
104
105#endif // MFEM_HIP_HPP
void * HipMemcpyDtoD(void *dst, const void *src, size_t bytes)
Copies memory from Device to Device.
Definition hip.cpp:132
void * HipMemcpyDtoDAsync(void *dst, const void *src, size_t bytes)
Copies memory from Device to Device.
Definition hip.cpp:147
void * HipMemAllocHostPinned(void **ptr, size_t bytes)
Allocates page-locked (pinned) host memory.
Definition hip.cpp:64
void * HipMemcpyHtoDAsync(void *dst, const void *src, size_t bytes)
Copies memory from Host to Device.
Definition hip.cpp:124
void HipCheckLastError()
Check the error code returned by hipGetLastError(), aborting on error.
Definition hip.cpp:178
void * HipMemcpyHtoD(void *dst, const void *src, size_t bytes)
Copies memory from Host to Device.
Definition hip.cpp:109
OutStream err(std::cerr)
Global stream used by the library for standard error output. Initially it uses the same std::streambu...
Definition globals.hpp:71
void * HipMemFree(void *dptr)
Frees device memory.
Definition hip.cpp:79
int HipGetDeviceCount()
Get the number of HIP devices.
Definition hip.cpp:185
void * HipMemcpyDtoH(void *dst, const void *src, size_t bytes)
Copies memory from Device to Host.
Definition hip.cpp:155
void * HipMemFreeHostPinned(void *ptr)
Frees page-locked (pinned) host memory and returns destination ptr.
Definition hip.cpp:94
void * HipMallocManaged(void **dptr, size_t bytes)
Allocates managed device memory.
Definition hip.cpp:49
void * HipMemcpyDtoHAsync(void *dst, const void *src, size_t bytes)
Copies memory from Device to Host.
Definition hip.cpp:170
void * HipMemAlloc(void **dptr, size_t bytes)
Allocates device memory.
Definition hip.cpp:34
void mfem_hip_error(hipError_t err, const char *expr, const char *func, const char *file, int line)
Definition hip.cpp:23