Morpheus 1.0.0
Dynamic matrix type and algorithms for sparse matrices
Loading...
Searching...
No Matches
HIP/Morpheus_Workspace.hpp
1
24#ifndef MORPHEUS_DENSEVECTOR_HIP_WORKSPACE_IMPL_HPP
25#define MORPHEUS_DENSEVECTOR_HIP_WORKSPACE_IMPL_HPP
26
27#include <Morpheus_Macros.hpp>
28#if defined(MORPHEUS_ENABLE_HIP)
29
30#include <impl/Morpheus_HIPUtils.hpp>
31
32#ifdef MORPHEUS_ENABLE_TPL_HIPBLAS
33#include <hipblas.h>
34#endif // MORPHEUS_ENABLE_TPL_HIPBLAS
35
36namespace Morpheus {
37namespace Impl {
38
40 public:
41 HIPWorkspace() : _workspace(nullptr), _nbytes(0) {}
42
43 ~HIPWorkspace() { _free(); }
44
45 template <typename ValueType>
46 void allocate(size_t N) {
47 size_t bytes = N * sizeof(ValueType);
48 if ((bytes > _nbytes) && (_nbytes > 0)) {
49 _free();
50 }
51 _malloc(bytes);
52 }
53
54 template <typename ValueType>
55 ValueType* data() {
56 return reinterpret_cast<ValueType*>(_workspace);
57 }
58
59 private:
60 void* _workspace;
61 size_t _nbytes;
62
63 void _malloc(size_t bytes) {
64 if (_workspace == nullptr) {
65 _nbytes = bytes;
66 if (hipSuccess != hipMalloc(&_workspace, bytes)) {
67 std::cout << "Malloc Failed on Device" << std::endl;
68 exit(EXIT_FAILURE);
69 }
70 }
71 }
72
73 void _free() {
74 if (_workspace != nullptr) {
75 if (hipSuccess == hipFree(_workspace)) {
76 _workspace = nullptr;
77 _nbytes = 0;
78 }
79 }
80 }
81};
82
83#ifdef MORPHEUS_ENABLE_TPL_HIPBLAS
84
86 public:
87 HIPblasWorkspace() : _handle(nullptr) {}
88
90 if (_handle != nullptr) {
91 if (hipblasDestroy(_handle) != HIPBLAS_STATUS_SUCCESS) {
92 _handle = nullptr;
93 }
94 }
95 }
96
97 void init() {
98 if (_handle == nullptr) {
99 if (hipblasCreate(&_handle) != HIPBLAS_STATUS_SUCCESS) {
100 printf("HIPBLAS initialization failed\n");
101 exit(EXIT_FAILURE);
102 }
103 hipblasSetPointerMode(_handle, HIPBLAS_POINTER_MODE_DEVICE);
104 }
105 }
106
107 hipblasHandle_t handle() { return _handle; }
108
109 private:
110 hipblasHandle_t _handle;
111};
112
113extern HIPblasWorkspace hipblasdotspace;
114
115#endif // MORPHEUS_ENABLE_TPL_HIPBLAS
116
117extern HIPWorkspace hipdotspace;
118
119} // namespace Impl
120} // namespace Morpheus
121
122#endif // MORPHEUS_ENABLE_HIP
123#endif // MORPHEUS_DENSEVECTOR_HIP_WORKSPACE_IMPL_HPP
Definition: HIP/Morpheus_Workspace.hpp:39
Definition: HIP/Morpheus_Workspace.hpp:85
Generic Morpheus interfaces.
Definition: dummy.cpp:24
A wrapper that checks if the provided type is a scalar type.
Definition: Morpheus_TypeTraits.hpp:85