xref: /libCEED/backends/hip/ceed-hip-common.c (revision da5de306636ec0d157763fe187cd5223e023ed1d)
1 // Copyright (c) 2017-2024, Lawrence Livermore National Security, LLC and other CEED contributors.
2 // All Rights Reserved. See the top-level LICENSE and NOTICE files for details.
3 //
4 // SPDX-License-Identifier: BSD-2-Clause
5 //
6 // This file is part of CEED:  http://github.com/ceed
7 
8 #include "ceed-hip-common.h"
9 
10 #include <ceed.h>
11 #include <ceed/backend.h>
12 #include <stdlib.h>
13 #include <string.h>
14 
15 //------------------------------------------------------------------------------
16 // Device information backend init
17 //------------------------------------------------------------------------------
18 int CeedInit_Hip(Ceed ceed, const char *resource) {
19   Ceed_Hip   *data;
20   const char *device_spec = strstr(resource, ":device_id=");
21   const int   device_id   = (device_spec) ? atoi(device_spec + 11) : -1;
22   int         current_device_id;
23 
24   CeedCallHip(ceed, hipGetDevice(&current_device_id));
25   if (device_id >= 0 && current_device_id != device_id) {
26     CeedCallHip(ceed, hipSetDevice(device_id));
27     current_device_id = device_id;
28   }
29 
30   CeedCallBackend(CeedGetData(ceed, &data));
31   data->device_id = current_device_id;
32   CeedCallHip(ceed, hipGetDeviceProperties(&data->device_prop, current_device_id));
33   data->opt_block_size = 256;
34   return CEED_ERROR_SUCCESS;
35 }
36 
37 //------------------------------------------------------------------------------
38 // Backend Destroy
39 //------------------------------------------------------------------------------
40 int CeedDestroy_Hip(Ceed ceed) {
41   Ceed_Hip *data;
42 
43   CeedCallBackend(CeedGetData(ceed, &data));
44   if (data->hipblas_handle) CeedCallHipblas(ceed, hipblasDestroy(data->hipblas_handle));
45   CeedCallBackend(CeedFree(&data));
46   return CEED_ERROR_SUCCESS;
47 }
48 
49 //------------------------------------------------------------------------------
50 // Memory transfer utilities
51 //------------------------------------------------------------------------------
52 static inline int CeedSetDeviceGenericArray_Hip(Ceed ceed, const void *source_array, CeedCopyMode copy_mode, size_t size_unit, CeedSize num_values,
53                                                 void *target_array_owned, void *target_array_borrowed, void *target_array) {
54   switch (copy_mode) {
55     case CEED_COPY_VALUES:
56       if (!*(void **)target_array) {
57         if (*(void **)target_array_borrowed) {
58           *(void **)target_array = *(void **)target_array_borrowed;
59         } else {
60           if (!*(void **)target_array_owned) CeedCallHip(ceed, hipMalloc(target_array_owned, size_unit * num_values));
61           *(void **)target_array = *(void **)target_array_owned;
62         }
63       }
64       if (source_array) CeedCallHip(ceed, hipMemcpy(*(void **)target_array, source_array, size_unit * num_values, hipMemcpyDeviceToDevice));
65       break;
66     case CEED_OWN_POINTER:
67       CeedCallHip(ceed, hipFree(*(void **)target_array_owned));
68       *(void **)target_array_owned    = (void *)source_array;
69       *(void **)target_array_borrowed = NULL;
70       *(void **)target_array          = *(void **)target_array_owned;
71       break;
72     case CEED_USE_POINTER:
73       CeedCallHip(ceed, hipFree(*(void **)target_array_owned));
74       *(void **)target_array_owned    = NULL;
75       *(void **)target_array_borrowed = (void *)source_array;
76       *(void **)target_array          = *(void **)target_array_borrowed;
77   }
78   return CEED_ERROR_SUCCESS;
79 }
80 
81 int CeedSetDeviceBoolArray_Hip(Ceed ceed, const bool *source_array, CeedCopyMode copy_mode, CeedSize num_values, const bool **target_array_owned,
82                                const bool **target_array_borrowed, const bool **target_array) {
83   CeedCallBackend(CeedSetDeviceGenericArray_Hip(ceed, source_array, copy_mode, sizeof(bool), num_values, target_array_owned, target_array_borrowed,
84                                                 target_array));
85   return CEED_ERROR_SUCCESS;
86 }
87 
88 int CeedSetDeviceCeedInt8Array_Hip(Ceed ceed, const CeedInt8 *source_array, CeedCopyMode copy_mode, CeedSize num_values,
89                                    const CeedInt8 **target_array_owned, const CeedInt8 **target_array_borrowed, const CeedInt8 **target_array) {
90   CeedCallBackend(CeedSetDeviceGenericArray_Hip(ceed, source_array, copy_mode, sizeof(CeedInt8), num_values, target_array_owned,
91                                                 target_array_borrowed, target_array));
92   return CEED_ERROR_SUCCESS;
93 }
94 
95 int CeedSetDeviceCeedIntArray_Hip(Ceed ceed, const CeedInt *source_array, CeedCopyMode copy_mode, CeedSize num_values,
96                                   const CeedInt **target_array_owned, const CeedInt **target_array_borrowed, const CeedInt **target_array) {
97   CeedCallBackend(CeedSetDeviceGenericArray_Hip(ceed, source_array, copy_mode, sizeof(CeedInt), num_values, target_array_owned, target_array_borrowed,
98                                                 target_array));
99   return CEED_ERROR_SUCCESS;
100 }
101 
102 int CeedSetDeviceCeedScalarArray_Hip(Ceed ceed, const CeedScalar *source_array, CeedCopyMode copy_mode, CeedSize num_values,
103                                      const CeedScalar **target_array_owned, const CeedScalar **target_array_borrowed,
104                                      const CeedScalar **target_array) {
105   CeedCallBackend(CeedSetDeviceGenericArray_Hip(ceed, source_array, copy_mode, sizeof(CeedScalar), num_values, target_array_owned,
106                                                 target_array_borrowed, target_array));
107   return CEED_ERROR_SUCCESS;
108 }
109 
110 //------------------------------------------------------------------------------
111