Thomas Schwinge | dced339 | 2017-01-31 15:32:58 +0100 | [diff] [blame] | 1 | /* The libgomp plugin API. |
| 2 | |
Thomas Koenig | b18a97e | 2021-09-13 19:49:49 +0200 | [diff] [blame] | 3 | Copyright (C) 2014-2021 Free Software Foundation, Inc. |
Thomas Schwinge | 41dbbb3 | 2015-01-15 21:11:12 +0100 | [diff] [blame] | 4 | |
| 5 | Contributed by Mentor Embedded. |
| 6 | |
| 7 | This file is part of the GNU Offloading and Multi Processing Library |
| 8 | (libgomp). |
| 9 | |
| 10 | Libgomp is free software; you can redistribute it and/or modify it |
| 11 | under the terms of the GNU General Public License as published by |
| 12 | the Free Software Foundation; either version 3, or (at your option) |
| 13 | any later version. |
| 14 | |
| 15 | Libgomp is distributed in the hope that it will be useful, but WITHOUT ANY |
| 16 | WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS |
| 17 | FOR A PARTICULAR PURPOSE. See the GNU General Public License for |
| 18 | more details. |
| 19 | |
| 20 | Under Section 7 of GPL version 3, you are granted additional |
| 21 | permissions described in the GCC Runtime Library Exception, version |
| 22 | 3.1, as published by the Free Software Foundation. |
| 23 | |
| 24 | You should have received a copy of the GNU General Public License and |
| 25 | a copy of the GCC Runtime Library Exception along with this program; |
| 26 | see the files COPYING3 and COPYING.RUNTIME respectively. If not, see |
| 27 | <http://www.gnu.org/licenses/>. */ |
| 28 | |
Thomas Schwinge | 41dbbb3 | 2015-01-15 21:11:12 +0100 | [diff] [blame] | 29 | #ifndef LIBGOMP_PLUGIN_H |
| 30 | #define LIBGOMP_PLUGIN_H 1 |
| 31 | |
Thomas Schwinge | dced339 | 2017-01-31 15:32:58 +0100 | [diff] [blame] | 32 | #include <stdbool.h> |
Thomas Schwinge | 41dbbb3 | 2015-01-15 21:11:12 +0100 | [diff] [blame] | 33 | #include <stddef.h> |
| 34 | #include <stdint.h> |
| 35 | |
| 36 | #ifdef __cplusplus |
| 37 | extern "C" { |
| 38 | #endif |
| 39 | |
| 40 | /* Capabilities of offloading devices. */ |
| 41 | #define GOMP_OFFLOAD_CAP_SHARED_MEM (1 << 0) |
| 42 | #define GOMP_OFFLOAD_CAP_NATIVE_EXEC (1 << 1) |
| 43 | #define GOMP_OFFLOAD_CAP_OPENMP_400 (1 << 2) |
| 44 | #define GOMP_OFFLOAD_CAP_OPENACC_200 (1 << 3) |
| 45 | |
| 46 | /* Type of offload target device. Keep in sync with include/gomp-constants.h. */ |
| 47 | enum offload_target_type |
| 48 | { |
| 49 | OFFLOAD_TARGET_TYPE_HOST = 2, |
Thomas Schwinge | b97e78b | 2015-08-10 18:48:26 +0200 | [diff] [blame] | 50 | /* OFFLOAD_TARGET_TYPE_HOST_NONSHM = 3 removed. */ |
Thomas Schwinge | 41dbbb3 | 2015-01-15 21:11:12 +0100 | [diff] [blame] | 51 | OFFLOAD_TARGET_TYPE_NVIDIA_PTX = 5, |
Martin Jambor | b2b4005 | 2016-01-19 11:35:10 +0100 | [diff] [blame] | 52 | OFFLOAD_TARGET_TYPE_INTEL_MIC = 6, |
Andrew Stubbs | fa49999 | 2019-11-13 12:38:04 +0000 | [diff] [blame] | 53 | OFFLOAD_TARGET_TYPE_HSA = 7, |
| 54 | OFFLOAD_TARGET_TYPE_GCN = 8 |
Thomas Schwinge | 41dbbb3 | 2015-01-15 21:11:12 +0100 | [diff] [blame] | 55 | }; |
| 56 | |
Chung-Lin Tang | 1f4c5b9 | 2019-05-13 13:32:00 +0000 | [diff] [blame] | 57 | /* Opaque type to represent plugin-dependent implementation of an |
| 58 | OpenACC asynchronous queue. */ |
| 59 | struct goacc_asyncqueue; |
| 60 | |
| 61 | /* Used to keep a list of active asynchronous queues. */ |
| 62 | struct goacc_asyncqueue_list |
| 63 | { |
| 64 | struct goacc_asyncqueue *aq; |
| 65 | struct goacc_asyncqueue_list *next; |
| 66 | }; |
| 67 | |
| 68 | typedef struct goacc_asyncqueue *goacc_aq; |
| 69 | typedef struct goacc_asyncqueue_list *goacc_aq_list; |
| 70 | |
Thomas Schwinge | 6fc0385 | 2020-01-10 23:24:36 +0100 | [diff] [blame] | 71 | |
| 72 | /* OpenACC 'acc_get_property' support. */ |
| 73 | |
| 74 | /* Device property values. Keep in sync with |
| 75 | 'libgomp/{openacc.h,openacc.f90}:acc_device_property_t'. */ |
| 76 | enum goacc_property |
| 77 | { |
| 78 | /* Mask to tell numeric and string values apart. */ |
| 79 | #define GOACC_PROPERTY_STRING_MASK 0x10000 |
| 80 | |
| 81 | /* Start from 1 to catch uninitialized use. */ |
| 82 | GOACC_PROPERTY_MEMORY = 1, |
| 83 | GOACC_PROPERTY_FREE_MEMORY = 2, |
| 84 | GOACC_PROPERTY_NAME = GOACC_PROPERTY_STRING_MASK | 1, |
| 85 | GOACC_PROPERTY_VENDOR = GOACC_PROPERTY_STRING_MASK | 2, |
| 86 | GOACC_PROPERTY_DRIVER = GOACC_PROPERTY_STRING_MASK | 3 |
| 87 | }; |
| 88 | |
| 89 | /* Container type for passing device properties. */ |
| 90 | union goacc_property_value |
| 91 | { |
| 92 | const char *ptr; |
| 93 | size_t val; |
| 94 | }; |
| 95 | |
| 96 | |
Ilya Verbin | a51df54 | 2015-04-06 12:40:28 +0000 | [diff] [blame] | 97 | /* Auxiliary struct, used for transferring pairs of addresses from plugin |
| 98 | to libgomp. */ |
| 99 | struct addr_pair |
Thomas Schwinge | 41dbbb3 | 2015-01-15 21:11:12 +0100 | [diff] [blame] | 100 | { |
Ilya Verbin | a51df54 | 2015-04-06 12:40:28 +0000 | [diff] [blame] | 101 | uintptr_t start; |
| 102 | uintptr_t end; |
Thomas Schwinge | 41dbbb3 | 2015-01-15 21:11:12 +0100 | [diff] [blame] | 103 | }; |
| 104 | |
Thomas Koenig | b18a97e | 2021-09-13 19:49:49 +0200 | [diff] [blame] | 105 | /* This symbol is to name a target side variable that holds the designated |
| 106 | 'device number' of the target device. The symbol needs to be available to |
| 107 | libgomp code and the offload plugin (which in the latter case must be |
| 108 | stringified). */ |
| 109 | #define GOMP_DEVICE_NUM_VAR __gomp_device_num |
| 110 | |
Thomas Schwinge | 41dbbb3 | 2015-01-15 21:11:12 +0100 | [diff] [blame] | 111 | /* Miscellaneous functions. */ |
| 112 | extern void *GOMP_PLUGIN_malloc (size_t) __attribute__ ((malloc)); |
| 113 | extern void *GOMP_PLUGIN_malloc_cleared (size_t) __attribute__ ((malloc)); |
| 114 | extern void *GOMP_PLUGIN_realloc (void *, size_t); |
Jakub Jelinek | e460634 | 2015-11-14 19:42:13 +0100 | [diff] [blame] | 115 | void GOMP_PLUGIN_target_task_completion (void *); |
Thomas Schwinge | 41dbbb3 | 2015-01-15 21:11:12 +0100 | [diff] [blame] | 116 | |
| 117 | extern void GOMP_PLUGIN_debug (int, const char *, ...) |
| 118 | __attribute__ ((format (printf, 2, 3))); |
| 119 | extern void GOMP_PLUGIN_error (const char *, ...) |
| 120 | __attribute__ ((format (printf, 1, 2))); |
| 121 | extern void GOMP_PLUGIN_fatal (const char *, ...) |
| 122 | __attribute__ ((noreturn, format (printf, 1, 2))); |
| 123 | |
Thomas Schwinge | dced339 | 2017-01-31 15:32:58 +0100 | [diff] [blame] | 124 | /* Prototypes for functions implemented by libgomp plugins. */ |
| 125 | extern const char *GOMP_OFFLOAD_get_name (void); |
| 126 | extern unsigned int GOMP_OFFLOAD_get_caps (void); |
| 127 | extern int GOMP_OFFLOAD_get_type (void); |
| 128 | extern int GOMP_OFFLOAD_get_num_devices (void); |
| 129 | extern bool GOMP_OFFLOAD_init_device (int); |
| 130 | extern bool GOMP_OFFLOAD_fini_device (int); |
| 131 | extern unsigned GOMP_OFFLOAD_version (void); |
| 132 | extern int GOMP_OFFLOAD_load_image (int, unsigned, const void *, |
| 133 | struct addr_pair **); |
| 134 | extern bool GOMP_OFFLOAD_unload_image (int, unsigned, const void *); |
| 135 | extern void *GOMP_OFFLOAD_alloc (int, size_t); |
| 136 | extern bool GOMP_OFFLOAD_free (int, void *); |
| 137 | extern bool GOMP_OFFLOAD_dev2host (int, void *, const void *, size_t); |
| 138 | extern bool GOMP_OFFLOAD_host2dev (int, void *, const void *, size_t); |
| 139 | extern bool GOMP_OFFLOAD_dev2dev (int, void *, const void *, size_t); |
| 140 | extern bool GOMP_OFFLOAD_can_run (void *); |
| 141 | extern void GOMP_OFFLOAD_run (int, void *, void *, void **); |
| 142 | extern void GOMP_OFFLOAD_async_run (int, void *, void *, void **, void *); |
Chung-Lin Tang | 1f4c5b9 | 2019-05-13 13:32:00 +0000 | [diff] [blame] | 143 | |
Thomas Schwinge | 345a8c1 | 2017-02-02 15:13:57 +0100 | [diff] [blame] | 144 | extern void GOMP_OFFLOAD_openacc_exec (void (*) (void *), size_t, void **, |
Chung-Lin Tang | 1f4c5b9 | 2019-05-13 13:32:00 +0000 | [diff] [blame] | 145 | void **, unsigned *, void *); |
Thomas Schwinge | dced339 | 2017-01-31 15:32:58 +0100 | [diff] [blame] | 146 | extern void *GOMP_OFFLOAD_openacc_create_thread_data (int); |
| 147 | extern void GOMP_OFFLOAD_openacc_destroy_thread_data (void *); |
Andrew Stubbs | d2903ce0 | 2019-11-13 12:37:59 +0000 | [diff] [blame] | 148 | extern struct goacc_asyncqueue *GOMP_OFFLOAD_openacc_async_construct (int); |
Chung-Lin Tang | 1f4c5b9 | 2019-05-13 13:32:00 +0000 | [diff] [blame] | 149 | extern bool GOMP_OFFLOAD_openacc_async_destruct (struct goacc_asyncqueue *); |
| 150 | extern int GOMP_OFFLOAD_openacc_async_test (struct goacc_asyncqueue *); |
| 151 | extern bool GOMP_OFFLOAD_openacc_async_synchronize (struct goacc_asyncqueue *); |
| 152 | extern bool GOMP_OFFLOAD_openacc_async_serialize (struct goacc_asyncqueue *, |
| 153 | struct goacc_asyncqueue *); |
| 154 | extern void GOMP_OFFLOAD_openacc_async_queue_callback (struct goacc_asyncqueue *, |
| 155 | void (*)(void *), void *); |
| 156 | extern void GOMP_OFFLOAD_openacc_async_exec (void (*) (void *), size_t, void **, |
| 157 | void **, unsigned *, void *, |
| 158 | struct goacc_asyncqueue *); |
| 159 | extern bool GOMP_OFFLOAD_openacc_async_dev2host (int, void *, const void *, size_t, |
| 160 | struct goacc_asyncqueue *); |
| 161 | extern bool GOMP_OFFLOAD_openacc_async_host2dev (int, void *, const void *, size_t, |
| 162 | struct goacc_asyncqueue *); |
Thomas Schwinge | 345a8c1 | 2017-02-02 15:13:57 +0100 | [diff] [blame] | 163 | extern void *GOMP_OFFLOAD_openacc_cuda_get_current_device (void); |
| 164 | extern void *GOMP_OFFLOAD_openacc_cuda_get_current_context (void); |
Chung-Lin Tang | 1f4c5b9 | 2019-05-13 13:32:00 +0000 | [diff] [blame] | 165 | extern void *GOMP_OFFLOAD_openacc_cuda_get_stream (struct goacc_asyncqueue *); |
| 166 | extern int GOMP_OFFLOAD_openacc_cuda_set_stream (struct goacc_asyncqueue *, |
| 167 | void *); |
Thomas Schwinge | 6fc0385 | 2020-01-10 23:24:36 +0100 | [diff] [blame] | 168 | extern union goacc_property_value |
| 169 | GOMP_OFFLOAD_openacc_get_property (int, enum goacc_property); |
Thomas Schwinge | dced339 | 2017-01-31 15:32:58 +0100 | [diff] [blame] | 170 | |
Thomas Schwinge | 41dbbb3 | 2015-01-15 21:11:12 +0100 | [diff] [blame] | 171 | #ifdef __cplusplus |
| 172 | } |
| 173 | #endif |
| 174 | |
| 175 | #endif |