annotate include/hsa.h @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 1830386684a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* HSA runtime API 1.0.1 representation description.
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
2 Copyright (C) 2016-2020 Free Software Foundation, Inc.
111
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 This file is part of GCC.
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 GCC is free software; you can redistribute it and/or modify
kono
parents:
diff changeset
7 it under the terms of the GNU General Public License as published by
kono
parents:
diff changeset
8 the Free Software Foundation; either version 3, or (at your option)
kono
parents:
diff changeset
9 any later version.
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 GCC is distributed in the hope that it will be useful,
kono
parents:
diff changeset
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
kono
parents:
diff changeset
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
kono
parents:
diff changeset
14 GNU General Public License for more details.
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 Under Section 7 of GPL version 3, you are granted additional
kono
parents:
diff changeset
17 permissions described in the GCC Runtime Library Exception, version
kono
parents:
diff changeset
18 3.1, as published by the Free Software Foundation.
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 You should have received a copy of the GNU General Public License and
kono
parents:
diff changeset
21 a copy of the GCC Runtime Library Exception along with this program;
kono
parents:
diff changeset
22 see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
kono
parents:
diff changeset
23 <http://www.gnu.org/licenses/>.
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 The contents of the file was created by extracting data structures, enum,
kono
parents:
diff changeset
26 typedef and other definitions from HSA Runtime Programmer’s Reference Manual
kono
parents:
diff changeset
27 Version 1.0 (http://www.hsafoundation.com/standards/).
kono
parents:
diff changeset
28
kono
parents:
diff changeset
29 HTML version is provided on the following link:
kono
parents:
diff changeset
30 http://www.hsafoundation.com/html/Content/Runtime/Topics/Runtime_title_page.htm
kono
parents:
diff changeset
31 */
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 #ifndef _HSA_H
kono
parents:
diff changeset
34 #define _HSA_H 1
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 #define HSA_LARGE_MODEL 1
kono
parents:
diff changeset
37
kono
parents:
diff changeset
38 typedef struct hsa_signal_s { uint64_t handle; } hsa_signal_t;
kono
parents:
diff changeset
39 typedef enum {
kono
parents:
diff changeset
40 HSA_QUEUE_TYPE_MULTI = 0,
kono
parents:
diff changeset
41 HSA_QUEUE_TYPE_SINGLE = 1
kono
parents:
diff changeset
42 } hsa_queue_type_t;
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 typedef enum { HSA_PROFILE_BASE = 0, HSA_PROFILE_FULL = 1 } hsa_profile_t;
kono
parents:
diff changeset
45 typedef struct hsa_region_s { uint64_t handle; } hsa_region_t;
kono
parents:
diff changeset
46 typedef enum {
kono
parents:
diff changeset
47 HSA_EXECUTABLE_SYMBOL_INFO_TYPE = 0,
kono
parents:
diff changeset
48 HSA_EXECUTABLE_SYMBOL_INFO_NAME_LENGTH = 1,
kono
parents:
diff changeset
49 HSA_EXECUTABLE_SYMBOL_INFO_NAME = 2,
kono
parents:
diff changeset
50 HSA_EXECUTABLE_SYMBOL_INFO_MODULE_NAME_LENGTH = 3,
kono
parents:
diff changeset
51 HSA_EXECUTABLE_SYMBOL_INFO_MODULE_NAME = 4,
kono
parents:
diff changeset
52 HSA_EXECUTABLE_SYMBOL_INFO_AGENT = 20,
kono
parents:
diff changeset
53 HSA_EXECUTABLE_SYMBOL_INFO_VARIABLE_ADDRESS = 21,
kono
parents:
diff changeset
54 HSA_EXECUTABLE_SYMBOL_INFO_LINKAGE = 5,
kono
parents:
diff changeset
55 HSA_EXECUTABLE_SYMBOL_INFO_IS_DEFINITION = 17,
kono
parents:
diff changeset
56 HSA_EXECUTABLE_SYMBOL_INFO_VARIABLE_ALLOCATION = 6,
kono
parents:
diff changeset
57 HSA_EXECUTABLE_SYMBOL_INFO_VARIABLE_SEGMENT = 7,
kono
parents:
diff changeset
58 HSA_EXECUTABLE_SYMBOL_INFO_VARIABLE_ALIGNMENT = 8,
kono
parents:
diff changeset
59 HSA_EXECUTABLE_SYMBOL_INFO_VARIABLE_SIZE = 9,
kono
parents:
diff changeset
60 HSA_EXECUTABLE_SYMBOL_INFO_VARIABLE_IS_CONST = 10,
kono
parents:
diff changeset
61 HSA_EXECUTABLE_SYMBOL_INFO_KERNEL_OBJECT = 22,
kono
parents:
diff changeset
62 HSA_EXECUTABLE_SYMBOL_INFO_KERNEL_KERNARG_SEGMENT_SIZE = 11,
kono
parents:
diff changeset
63 HSA_EXECUTABLE_SYMBOL_INFO_KERNEL_KERNARG_SEGMENT_ALIGNMENT = 12,
kono
parents:
diff changeset
64 HSA_EXECUTABLE_SYMBOL_INFO_KERNEL_GROUP_SEGMENT_SIZE = 13,
kono
parents:
diff changeset
65 HSA_EXECUTABLE_SYMBOL_INFO_KERNEL_PRIVATE_SEGMENT_SIZE = 14,
kono
parents:
diff changeset
66 HSA_EXECUTABLE_SYMBOL_INFO_KERNEL_DYNAMIC_CALLSTACK = 15,
kono
parents:
diff changeset
67 HSA_EXECUTABLE_SYMBOL_INFO_INDIRECT_FUNCTION_OBJECT = 23,
kono
parents:
diff changeset
68 HSA_EXECUTABLE_SYMBOL_INFO_INDIRECT_FUNCTION_CALL_CONVENTION = 16
kono
parents:
diff changeset
69 } hsa_executable_symbol_info_t;
kono
parents:
diff changeset
70 typedef enum {
kono
parents:
diff changeset
71 HSA_REGION_GLOBAL_FLAG_KERNARG = 1,
kono
parents:
diff changeset
72 HSA_REGION_GLOBAL_FLAG_FINE_GRAINED = 2,
kono
parents:
diff changeset
73 HSA_REGION_GLOBAL_FLAG_COARSE_GRAINED = 4
kono
parents:
diff changeset
74 } hsa_region_global_flag_t;
kono
parents:
diff changeset
75 typedef struct hsa_code_object_s { uint64_t handle; } hsa_code_object_t;
kono
parents:
diff changeset
76 typedef enum {
kono
parents:
diff changeset
77 HSA_KERNEL_DISPATCH_PACKET_SETUP_WIDTH_DIMENSIONS = 2
kono
parents:
diff changeset
78 } hsa_kernel_dispatch_packet_setup_width_t;
kono
parents:
diff changeset
79 typedef enum {
kono
parents:
diff changeset
80 HSA_DEVICE_TYPE_CPU = 0,
kono
parents:
diff changeset
81 HSA_DEVICE_TYPE_GPU = 1,
kono
parents:
diff changeset
82 HSA_DEVICE_TYPE_DSP = 2
kono
parents:
diff changeset
83 } hsa_device_type_t;
kono
parents:
diff changeset
84 typedef enum {
kono
parents:
diff changeset
85 HSA_STATUS_SUCCESS = 0x0,
kono
parents:
diff changeset
86 HSA_STATUS_INFO_BREAK = 0x1,
kono
parents:
diff changeset
87 HSA_STATUS_ERROR = 0x1000,
kono
parents:
diff changeset
88 HSA_STATUS_ERROR_INVALID_ARGUMENT = 0x1001,
kono
parents:
diff changeset
89 HSA_STATUS_ERROR_INVALID_QUEUE_CREATION = 0x1002,
kono
parents:
diff changeset
90 HSA_STATUS_ERROR_INVALID_ALLOCATION = 0x1003,
kono
parents:
diff changeset
91 HSA_STATUS_ERROR_INVALID_AGENT = 0x1004,
kono
parents:
diff changeset
92 HSA_STATUS_ERROR_INVALID_REGION = 0x1005,
kono
parents:
diff changeset
93 HSA_STATUS_ERROR_INVALID_SIGNAL = 0x1006,
kono
parents:
diff changeset
94 HSA_STATUS_ERROR_INVALID_QUEUE = 0x1007,
kono
parents:
diff changeset
95 HSA_STATUS_ERROR_OUT_OF_RESOURCES = 0x1008,
kono
parents:
diff changeset
96 HSA_STATUS_ERROR_INVALID_PACKET_FORMAT = 0x1009,
kono
parents:
diff changeset
97 HSA_STATUS_ERROR_RESOURCE_FREE = 0x100A,
kono
parents:
diff changeset
98 HSA_STATUS_ERROR_NOT_INITIALIZED = 0x100B,
kono
parents:
diff changeset
99 HSA_STATUS_ERROR_REFCOUNT_OVERFLOW = 0x100C,
kono
parents:
diff changeset
100 HSA_STATUS_ERROR_INCOMPATIBLE_ARGUMENTS = 0x100D,
kono
parents:
diff changeset
101 HSA_STATUS_ERROR_INVALID_INDEX = 0x100E,
kono
parents:
diff changeset
102 HSA_STATUS_ERROR_INVALID_ISA = 0x100F,
kono
parents:
diff changeset
103 HSA_STATUS_ERROR_INVALID_ISA_NAME = 0x1017,
kono
parents:
diff changeset
104 HSA_STATUS_ERROR_INVALID_CODE_OBJECT = 0x1010,
kono
parents:
diff changeset
105 HSA_STATUS_ERROR_INVALID_EXECUTABLE = 0x1011,
kono
parents:
diff changeset
106 HSA_STATUS_ERROR_FROZEN_EXECUTABLE = 0x1012,
kono
parents:
diff changeset
107 HSA_STATUS_ERROR_INVALID_SYMBOL_NAME = 0x1013,
kono
parents:
diff changeset
108 HSA_STATUS_ERROR_VARIABLE_ALREADY_DEFINED = 0x1014,
kono
parents:
diff changeset
109 HSA_STATUS_ERROR_VARIABLE_UNDEFINED = 0x1015,
kono
parents:
diff changeset
110 HSA_STATUS_ERROR_EXCEPTION = 0x1016
kono
parents:
diff changeset
111 } hsa_status_t;
kono
parents:
diff changeset
112 typedef enum {
kono
parents:
diff changeset
113 HSA_EXTENSION_FINALIZER = 0,
kono
parents:
diff changeset
114 HSA_EXTENSION_IMAGES = 1
kono
parents:
diff changeset
115 } hsa_extension_t;
kono
parents:
diff changeset
116 typedef struct hsa_queue_s {
kono
parents:
diff changeset
117 hsa_queue_type_t type;
kono
parents:
diff changeset
118 uint32_t features;
kono
parents:
diff changeset
119
kono
parents:
diff changeset
120 #ifdef HSA_LARGE_MODEL
kono
parents:
diff changeset
121 void *base_address;
kono
parents:
diff changeset
122 #elif defined HSA_LITTLE_ENDIAN
kono
parents:
diff changeset
123 void *base_address;
kono
parents:
diff changeset
124 uint32_t reserved0;
kono
parents:
diff changeset
125 #else
kono
parents:
diff changeset
126 uint32_t reserved0;
kono
parents:
diff changeset
127 void *base_address;
kono
parents:
diff changeset
128 #endif
kono
parents:
diff changeset
129
kono
parents:
diff changeset
130 hsa_signal_t doorbell_signal;
kono
parents:
diff changeset
131 uint32_t size;
kono
parents:
diff changeset
132 uint32_t reserved1;
kono
parents:
diff changeset
133 uint64_t id;
kono
parents:
diff changeset
134 } hsa_queue_t;
kono
parents:
diff changeset
135 typedef struct hsa_agent_dispatch_packet_s {
kono
parents:
diff changeset
136 uint16_t header;
kono
parents:
diff changeset
137 uint16_t type;
kono
parents:
diff changeset
138 uint32_t reserved0;
kono
parents:
diff changeset
139
kono
parents:
diff changeset
140 #ifdef HSA_LARGE_MODEL
kono
parents:
diff changeset
141 void *return_address;
kono
parents:
diff changeset
142 #elif defined HSA_LITTLE_ENDIAN
kono
parents:
diff changeset
143 void *return_address;
kono
parents:
diff changeset
144 uint32_t reserved1;
kono
parents:
diff changeset
145 #else
kono
parents:
diff changeset
146 uint32_t reserved1;
kono
parents:
diff changeset
147 void *return_address;
kono
parents:
diff changeset
148 #endif
kono
parents:
diff changeset
149 uint64_t arg[4];
kono
parents:
diff changeset
150 uint64_t reserved2;
kono
parents:
diff changeset
151 hsa_signal_t completion_signal;
kono
parents:
diff changeset
152 } hsa_agent_dispatch_packet_t;
kono
parents:
diff changeset
153 typedef enum {
kono
parents:
diff changeset
154 HSA_CODE_SYMBOL_INFO_TYPE = 0,
kono
parents:
diff changeset
155 HSA_CODE_SYMBOL_INFO_NAME_LENGTH = 1,
kono
parents:
diff changeset
156 HSA_CODE_SYMBOL_INFO_NAME = 2,
kono
parents:
diff changeset
157 HSA_CODE_SYMBOL_INFO_MODULE_NAME_LENGTH = 3,
kono
parents:
diff changeset
158 HSA_CODE_SYMBOL_INFO_MODULE_NAME = 4,
kono
parents:
diff changeset
159 HSA_CODE_SYMBOL_INFO_LINKAGE = 5,
kono
parents:
diff changeset
160 HSA_CODE_SYMBOL_INFO_IS_DEFINITION = 17,
kono
parents:
diff changeset
161 HSA_CODE_SYMBOL_INFO_VARIABLE_ALLOCATION = 6,
kono
parents:
diff changeset
162 HSA_CODE_SYMBOL_INFO_VARIABLE_SEGMENT = 7,
kono
parents:
diff changeset
163 HSA_CODE_SYMBOL_INFO_VARIABLE_ALIGNMENT = 8,
kono
parents:
diff changeset
164 HSA_CODE_SYMBOL_INFO_VARIABLE_SIZE = 9,
kono
parents:
diff changeset
165 HSA_CODE_SYMBOL_INFO_VARIABLE_IS_CONST = 10,
kono
parents:
diff changeset
166 HSA_CODE_SYMBOL_INFO_KERNEL_KERNARG_SEGMENT_SIZE = 11,
kono
parents:
diff changeset
167 HSA_CODE_SYMBOL_INFO_KERNEL_KERNARG_SEGMENT_ALIGNMENT = 12,
kono
parents:
diff changeset
168 HSA_CODE_SYMBOL_INFO_KERNEL_GROUP_SEGMENT_SIZE = 13,
kono
parents:
diff changeset
169 HSA_CODE_SYMBOL_INFO_KERNEL_PRIVATE_SEGMENT_SIZE = 14,
kono
parents:
diff changeset
170 HSA_CODE_SYMBOL_INFO_KERNEL_DYNAMIC_CALLSTACK = 15,
kono
parents:
diff changeset
171 HSA_CODE_SYMBOL_INFO_INDIRECT_FUNCTION_CALL_CONVENTION = 16
kono
parents:
diff changeset
172 } hsa_code_symbol_info_t;
kono
parents:
diff changeset
173 typedef enum {
kono
parents:
diff changeset
174 HSA_QUEUE_FEATURE_KERNEL_DISPATCH = 1,
kono
parents:
diff changeset
175 HSA_QUEUE_FEATURE_AGENT_DISPATCH = 2
kono
parents:
diff changeset
176 } hsa_queue_feature_t;
kono
parents:
diff changeset
177 typedef enum {
kono
parents:
diff changeset
178 HSA_VARIABLE_ALLOCATION_AGENT = 0,
kono
parents:
diff changeset
179 HSA_VARIABLE_ALLOCATION_PROGRAM = 1
kono
parents:
diff changeset
180 } hsa_variable_allocation_t;
kono
parents:
diff changeset
181 typedef enum {
kono
parents:
diff changeset
182 HSA_FENCE_SCOPE_NONE = 0,
kono
parents:
diff changeset
183 HSA_FENCE_SCOPE_AGENT = 1,
kono
parents:
diff changeset
184 HSA_FENCE_SCOPE_SYSTEM = 2
kono
parents:
diff changeset
185 } hsa_fence_scope_t;
kono
parents:
diff changeset
186 typedef struct hsa_agent_s { uint64_t handle; } hsa_agent_t;
kono
parents:
diff changeset
187 typedef enum { HSA_CODE_OBJECT_TYPE_PROGRAM = 0 } hsa_code_object_type_t;
kono
parents:
diff changeset
188 typedef enum {
kono
parents:
diff changeset
189 HSA_SIGNAL_CONDITION_EQ = 0,
kono
parents:
diff changeset
190 HSA_SIGNAL_CONDITION_NE = 1,
kono
parents:
diff changeset
191 HSA_SIGNAL_CONDITION_LT = 2,
kono
parents:
diff changeset
192 HSA_SIGNAL_CONDITION_GTE = 3
kono
parents:
diff changeset
193 } hsa_signal_condition_t;
kono
parents:
diff changeset
194 typedef enum {
kono
parents:
diff changeset
195 HSA_EXECUTABLE_STATE_UNFROZEN = 0,
kono
parents:
diff changeset
196 HSA_EXECUTABLE_STATE_FROZEN = 1
kono
parents:
diff changeset
197 } hsa_executable_state_t;
kono
parents:
diff changeset
198 typedef enum {
kono
parents:
diff changeset
199 HSA_ENDIANNESS_LITTLE = 0,
kono
parents:
diff changeset
200 HSA_ENDIANNESS_BIG = 1
kono
parents:
diff changeset
201 } hsa_endianness_t;
kono
parents:
diff changeset
202 typedef enum {
kono
parents:
diff changeset
203 HSA_MACHINE_MODEL_SMALL = 0,
kono
parents:
diff changeset
204 HSA_MACHINE_MODEL_LARGE = 1
kono
parents:
diff changeset
205 } hsa_machine_model_t;
kono
parents:
diff changeset
206 typedef enum {
kono
parents:
diff changeset
207 HSA_AGENT_INFO_NAME = 0,
kono
parents:
diff changeset
208 HSA_AGENT_INFO_VENDOR_NAME = 1,
kono
parents:
diff changeset
209 HSA_AGENT_INFO_FEATURE = 2,
kono
parents:
diff changeset
210 HSA_AGENT_INFO_MACHINE_MODEL = 3,
kono
parents:
diff changeset
211 HSA_AGENT_INFO_PROFILE = 4,
kono
parents:
diff changeset
212 HSA_AGENT_INFO_DEFAULT_FLOAT_ROUNDING_MODE = 5,
kono
parents:
diff changeset
213 HSA_AGENT_INFO_BASE_PROFILE_DEFAULT_FLOAT_ROUNDING_MODES = 23,
kono
parents:
diff changeset
214 HSA_AGENT_INFO_FAST_F16_OPERATION = 24,
kono
parents:
diff changeset
215 HSA_AGENT_INFO_WAVEFRONT_SIZE = 6,
kono
parents:
diff changeset
216 HSA_AGENT_INFO_WORKGROUP_MAX_DIM = 7,
kono
parents:
diff changeset
217 HSA_AGENT_INFO_WORKGROUP_MAX_SIZE = 8,
kono
parents:
diff changeset
218 HSA_AGENT_INFO_GRID_MAX_DIM = 9,
kono
parents:
diff changeset
219 HSA_AGENT_INFO_GRID_MAX_SIZE = 10,
kono
parents:
diff changeset
220 HSA_AGENT_INFO_FBARRIER_MAX_SIZE = 11,
kono
parents:
diff changeset
221 HSA_AGENT_INFO_QUEUES_MAX = 12,
kono
parents:
diff changeset
222 HSA_AGENT_INFO_QUEUE_MIN_SIZE = 13,
kono
parents:
diff changeset
223 HSA_AGENT_INFO_QUEUE_MAX_SIZE = 14,
kono
parents:
diff changeset
224 HSA_AGENT_INFO_QUEUE_TYPE = 15,
kono
parents:
diff changeset
225 HSA_AGENT_INFO_NODE = 16,
kono
parents:
diff changeset
226 HSA_AGENT_INFO_DEVICE = 17,
kono
parents:
diff changeset
227 HSA_AGENT_INFO_CACHE_SIZE = 18,
kono
parents:
diff changeset
228 HSA_AGENT_INFO_ISA = 19,
kono
parents:
diff changeset
229 HSA_AGENT_INFO_EXTENSIONS = 20,
kono
parents:
diff changeset
230 HSA_AGENT_INFO_VERSION_MAJOR = 21,
kono
parents:
diff changeset
231 HSA_AGENT_INFO_VERSION_MINOR = 22
kono
parents:
diff changeset
232 } hsa_agent_info_t;
kono
parents:
diff changeset
233 typedef struct hsa_barrier_and_packet_s {
kono
parents:
diff changeset
234 uint16_t header;
kono
parents:
diff changeset
235 uint16_t reserved0;
kono
parents:
diff changeset
236 uint32_t reserved1;
kono
parents:
diff changeset
237 hsa_signal_t dep_signal[5];
kono
parents:
diff changeset
238 uint64_t reserved2;
kono
parents:
diff changeset
239 hsa_signal_t completion_signal;
kono
parents:
diff changeset
240 } hsa_barrier_and_packet_t;
kono
parents:
diff changeset
241 typedef struct hsa_dim3_s {
kono
parents:
diff changeset
242 uint32_t x;
kono
parents:
diff changeset
243 uint32_t y;
kono
parents:
diff changeset
244 uint32_t z;
kono
parents:
diff changeset
245 } hsa_dim3_t;
kono
parents:
diff changeset
246 typedef enum {
kono
parents:
diff changeset
247 HSA_ACCESS_PERMISSION_RO = 1,
kono
parents:
diff changeset
248 HSA_ACCESS_PERMISSION_WO = 2,
kono
parents:
diff changeset
249 HSA_ACCESS_PERMISSION_RW = 3
kono
parents:
diff changeset
250 } hsa_access_permission_t;
kono
parents:
diff changeset
251 typedef enum {
kono
parents:
diff changeset
252 HSA_AGENT_FEATURE_KERNEL_DISPATCH = 1,
kono
parents:
diff changeset
253 HSA_AGENT_FEATURE_AGENT_DISPATCH = 2
kono
parents:
diff changeset
254 } hsa_agent_feature_t;
kono
parents:
diff changeset
255 typedef enum {
kono
parents:
diff changeset
256 HSA_WAIT_STATE_BLOCKED = 0,
kono
parents:
diff changeset
257 HSA_WAIT_STATE_ACTIVE = 1
kono
parents:
diff changeset
258 } hsa_wait_state_t;
kono
parents:
diff changeset
259 typedef struct hsa_executable_s { uint64_t handle; } hsa_executable_t;
kono
parents:
diff changeset
260 typedef enum {
kono
parents:
diff changeset
261 HSA_REGION_SEGMENT_GLOBAL = 0,
kono
parents:
diff changeset
262 HSA_REGION_SEGMENT_READONLY = 1,
kono
parents:
diff changeset
263 HSA_REGION_SEGMENT_PRIVATE = 2,
kono
parents:
diff changeset
264 HSA_REGION_SEGMENT_GROUP = 3
kono
parents:
diff changeset
265 } hsa_region_segment_t;
kono
parents:
diff changeset
266 typedef enum {
kono
parents:
diff changeset
267 HSA_REGION_INFO_SEGMENT = 0,
kono
parents:
diff changeset
268 HSA_REGION_INFO_GLOBAL_FLAGS = 1,
kono
parents:
diff changeset
269 HSA_REGION_INFO_SIZE = 2,
kono
parents:
diff changeset
270 HSA_REGION_INFO_ALLOC_MAX_SIZE = 4,
kono
parents:
diff changeset
271 HSA_REGION_INFO_RUNTIME_ALLOC_ALLOWED = 5,
kono
parents:
diff changeset
272 HSA_REGION_INFO_RUNTIME_ALLOC_GRANULE = 6,
kono
parents:
diff changeset
273 HSA_REGION_INFO_RUNTIME_ALLOC_ALIGNMENT = 7
kono
parents:
diff changeset
274 } hsa_region_info_t;
kono
parents:
diff changeset
275 typedef enum {
kono
parents:
diff changeset
276 HSA_ISA_INFO_NAME_LENGTH = 0,
kono
parents:
diff changeset
277 HSA_ISA_INFO_NAME = 1,
kono
parents:
diff changeset
278 HSA_ISA_INFO_CALL_CONVENTION_COUNT = 2,
kono
parents:
diff changeset
279 HSA_ISA_INFO_CALL_CONVENTION_INFO_WAVEFRONT_SIZE = 3,
kono
parents:
diff changeset
280 HSA_ISA_INFO_CALL_CONVENTION_INFO_WAVEFRONTS_PER_COMPUTE_UNIT = 4
kono
parents:
diff changeset
281 } hsa_isa_info_t;
kono
parents:
diff changeset
282 typedef enum {
kono
parents:
diff changeset
283 HSA_VARIABLE_SEGMENT_GLOBAL = 0,
kono
parents:
diff changeset
284 HSA_VARIABLE_SEGMENT_READONLY = 1
kono
parents:
diff changeset
285 } hsa_variable_segment_t;
kono
parents:
diff changeset
286 typedef struct hsa_callback_data_s { uint64_t handle; } hsa_callback_data_t;
kono
parents:
diff changeset
287 typedef enum {
kono
parents:
diff changeset
288 HSA_SYMBOL_KIND_VARIABLE = 0,
kono
parents:
diff changeset
289 HSA_SYMBOL_KIND_KERNEL = 1,
kono
parents:
diff changeset
290 HSA_SYMBOL_KIND_INDIRECT_FUNCTION = 2
kono
parents:
diff changeset
291 } hsa_symbol_kind_t;
kono
parents:
diff changeset
292 typedef struct hsa_kernel_dispatch_packet_s {
kono
parents:
diff changeset
293 uint16_t header;
kono
parents:
diff changeset
294 uint16_t setup;
kono
parents:
diff changeset
295 uint16_t workgroup_size_x;
kono
parents:
diff changeset
296 uint16_t workgroup_size_y;
kono
parents:
diff changeset
297 uint16_t workgroup_size_z;
kono
parents:
diff changeset
298 uint16_t reserved0;
kono
parents:
diff changeset
299 uint32_t grid_size_x;
kono
parents:
diff changeset
300 uint32_t grid_size_y;
kono
parents:
diff changeset
301 uint32_t grid_size_z;
kono
parents:
diff changeset
302 uint32_t private_segment_size;
kono
parents:
diff changeset
303 uint32_t group_segment_size;
kono
parents:
diff changeset
304 uint64_t kernel_object;
kono
parents:
diff changeset
305
kono
parents:
diff changeset
306 #ifdef HSA_LARGE_MODEL
kono
parents:
diff changeset
307 void *kernarg_address;
kono
parents:
diff changeset
308 #elif defined HSA_LITTLE_ENDIAN
kono
parents:
diff changeset
309 void *kernarg_address;
kono
parents:
diff changeset
310 uint32_t reserved1;
kono
parents:
diff changeset
311 #else
kono
parents:
diff changeset
312 uint32_t reserved1;
kono
parents:
diff changeset
313 void *kernarg_address;
kono
parents:
diff changeset
314 #endif
kono
parents:
diff changeset
315 uint64_t reserved2;
kono
parents:
diff changeset
316 hsa_signal_t completion_signal;
kono
parents:
diff changeset
317 } hsa_kernel_dispatch_packet_t;
kono
parents:
diff changeset
318 typedef enum {
kono
parents:
diff changeset
319 HSA_PACKET_TYPE_VENDOR_SPECIFIC = 0,
kono
parents:
diff changeset
320 HSA_PACKET_TYPE_INVALID = 1,
kono
parents:
diff changeset
321 HSA_PACKET_TYPE_KERNEL_DISPATCH = 2,
kono
parents:
diff changeset
322 HSA_PACKET_TYPE_BARRIER_AND = 3,
kono
parents:
diff changeset
323 HSA_PACKET_TYPE_AGENT_DISPATCH = 4,
kono
parents:
diff changeset
324 HSA_PACKET_TYPE_BARRIER_OR = 5
kono
parents:
diff changeset
325 } hsa_packet_type_t;
kono
parents:
diff changeset
326 typedef enum {
kono
parents:
diff changeset
327 HSA_PACKET_HEADER_TYPE = 0,
kono
parents:
diff changeset
328 HSA_PACKET_HEADER_BARRIER = 8,
kono
parents:
diff changeset
329 HSA_PACKET_HEADER_ACQUIRE_FENCE_SCOPE = 9,
kono
parents:
diff changeset
330 HSA_PACKET_HEADER_RELEASE_FENCE_SCOPE = 11
kono
parents:
diff changeset
331 } hsa_packet_header_t;
kono
parents:
diff changeset
332 typedef struct hsa_isa_s { uint64_t handle; } hsa_isa_t;
kono
parents:
diff changeset
333 typedef enum {
kono
parents:
diff changeset
334 HSA_DEFAULT_FLOAT_ROUNDING_MODE_DEFAULT = 0,
kono
parents:
diff changeset
335 HSA_DEFAULT_FLOAT_ROUNDING_MODE_ZERO = 1,
kono
parents:
diff changeset
336 HSA_DEFAULT_FLOAT_ROUNDING_MODE_NEAR = 2
kono
parents:
diff changeset
337 } hsa_default_float_rounding_mode_t;
kono
parents:
diff changeset
338 typedef struct hsa_code_symbol_s { uint64_t handle; } hsa_code_symbol_t;
kono
parents:
diff changeset
339 typedef struct hsa_executable_symbol_s {
kono
parents:
diff changeset
340 uint64_t handle;
kono
parents:
diff changeset
341 } hsa_executable_symbol_t;
kono
parents:
diff changeset
342 #ifdef HSA_LARGE_MODEL
kono
parents:
diff changeset
343 typedef int64_t hsa_signal_value_t;
kono
parents:
diff changeset
344 #else
kono
parents:
diff changeset
345 typedef int32_t hsa_signal_value_t;
kono
parents:
diff changeset
346 #endif
kono
parents:
diff changeset
347 typedef enum {
kono
parents:
diff changeset
348 HSA_EXCEPTION_POLICY_BREAK = 1,
kono
parents:
diff changeset
349 HSA_EXCEPTION_POLICY_DETECT = 2
kono
parents:
diff changeset
350 } hsa_exception_policy_t;
kono
parents:
diff changeset
351 typedef enum {
kono
parents:
diff changeset
352 HSA_SYSTEM_INFO_VERSION_MAJOR = 0,
kono
parents:
diff changeset
353 HSA_SYSTEM_INFO_VERSION_MINOR = 1,
kono
parents:
diff changeset
354 HSA_SYSTEM_INFO_TIMESTAMP = 2,
kono
parents:
diff changeset
355 HSA_SYSTEM_INFO_TIMESTAMP_FREQUENCY = 3,
kono
parents:
diff changeset
356 HSA_SYSTEM_INFO_SIGNAL_MAX_WAIT = 4,
kono
parents:
diff changeset
357 HSA_SYSTEM_INFO_ENDIANNESS = 5,
kono
parents:
diff changeset
358 HSA_SYSTEM_INFO_MACHINE_MODEL = 6,
kono
parents:
diff changeset
359 HSA_SYSTEM_INFO_EXTENSIONS = 7
kono
parents:
diff changeset
360 } hsa_system_info_t;
kono
parents:
diff changeset
361 typedef enum {
kono
parents:
diff changeset
362 HSA_EXECUTABLE_INFO_PROFILE = 1,
kono
parents:
diff changeset
363 HSA_EXECUTABLE_INFO_STATE = 2
kono
parents:
diff changeset
364 } hsa_executable_info_t;
kono
parents:
diff changeset
365 typedef enum {
kono
parents:
diff changeset
366 HSA_KERNEL_DISPATCH_PACKET_SETUP_DIMENSIONS = 0
kono
parents:
diff changeset
367 } hsa_kernel_dispatch_packet_setup_t;
kono
parents:
diff changeset
368 typedef enum {
kono
parents:
diff changeset
369 HSA_PACKET_HEADER_WIDTH_TYPE = 8,
kono
parents:
diff changeset
370 HSA_PACKET_HEADER_WIDTH_BARRIER = 1,
kono
parents:
diff changeset
371 HSA_PACKET_HEADER_WIDTH_ACQUIRE_FENCE_SCOPE = 2,
kono
parents:
diff changeset
372 HSA_PACKET_HEADER_WIDTH_RELEASE_FENCE_SCOPE = 2
kono
parents:
diff changeset
373 } hsa_packet_header_width_t;
kono
parents:
diff changeset
374 typedef enum {
kono
parents:
diff changeset
375 HSA_CODE_OBJECT_INFO_VERSION = 0,
kono
parents:
diff changeset
376 HSA_CODE_OBJECT_INFO_TYPE = 1,
kono
parents:
diff changeset
377 HSA_CODE_OBJECT_INFO_ISA = 2,
kono
parents:
diff changeset
378 HSA_CODE_OBJECT_INFO_MACHINE_MODEL = 3,
kono
parents:
diff changeset
379 HSA_CODE_OBJECT_INFO_PROFILE = 4,
kono
parents:
diff changeset
380 HSA_CODE_OBJECT_INFO_DEFAULT_FLOAT_ROUNDING_MODE = 5
kono
parents:
diff changeset
381 } hsa_code_object_info_t;
kono
parents:
diff changeset
382 typedef struct hsa_barrier_or_packet_s {
kono
parents:
diff changeset
383 uint16_t header;
kono
parents:
diff changeset
384 uint16_t reserved0;
kono
parents:
diff changeset
385 uint32_t reserved1;
kono
parents:
diff changeset
386 hsa_signal_t dep_signal[5];
kono
parents:
diff changeset
387 uint64_t reserved2;
kono
parents:
diff changeset
388 hsa_signal_t completion_signal;
kono
parents:
diff changeset
389 } hsa_barrier_or_packet_t;
kono
parents:
diff changeset
390 typedef enum {
kono
parents:
diff changeset
391 HSA_SYMBOL_KIND_LINKAGE_MODULE = 0,
kono
parents:
diff changeset
392 HSA_SYMBOL_KIND_LINKAGE_PROGRAM = 1,
kono
parents:
diff changeset
393 } hsa_symbol_kind_linkage_t;
kono
parents:
diff changeset
394 hsa_status_t hsa_executable_validate(hsa_executable_t executable,
kono
parents:
diff changeset
395 uint32_t *result);
kono
parents:
diff changeset
396 uint64_t hsa_queue_add_write_index_acq_rel(const hsa_queue_t *queue,
kono
parents:
diff changeset
397 uint64_t value);
kono
parents:
diff changeset
398
kono
parents:
diff changeset
399 uint64_t hsa_queue_add_write_index_acquire(const hsa_queue_t *queue,
kono
parents:
diff changeset
400 uint64_t value);
kono
parents:
diff changeset
401
kono
parents:
diff changeset
402 uint64_t hsa_queue_add_write_index_relaxed(const hsa_queue_t *queue,
kono
parents:
diff changeset
403 uint64_t value);
kono
parents:
diff changeset
404
kono
parents:
diff changeset
405 uint64_t hsa_queue_add_write_index_release(const hsa_queue_t *queue,
kono
parents:
diff changeset
406 uint64_t value);
kono
parents:
diff changeset
407 hsa_status_t hsa_shut_down();
kono
parents:
diff changeset
408 void hsa_signal_add_acq_rel(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
409
kono
parents:
diff changeset
410 void hsa_signal_add_acquire(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
411
kono
parents:
diff changeset
412 void hsa_signal_add_relaxed(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
413
kono
parents:
diff changeset
414 void hsa_signal_add_release(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
415 hsa_status_t hsa_executable_readonly_variable_define(
kono
parents:
diff changeset
416 hsa_executable_t executable, hsa_agent_t agent, const char *variable_name,
kono
parents:
diff changeset
417 void *address);
kono
parents:
diff changeset
418 hsa_status_t hsa_agent_extension_supported(uint16_t extension,
kono
parents:
diff changeset
419 hsa_agent_t agent,
kono
parents:
diff changeset
420 uint16_t version_major,
kono
parents:
diff changeset
421 uint16_t version_minor,
kono
parents:
diff changeset
422 bool *result);
kono
parents:
diff changeset
423 hsa_signal_value_t hsa_signal_load_acquire(hsa_signal_t signal);
kono
parents:
diff changeset
424
kono
parents:
diff changeset
425 hsa_signal_value_t hsa_signal_load_relaxed(hsa_signal_t signal);
kono
parents:
diff changeset
426 hsa_status_t hsa_executable_get_info(hsa_executable_t executable,
kono
parents:
diff changeset
427 hsa_executable_info_t attribute,
kono
parents:
diff changeset
428 void *value);
kono
parents:
diff changeset
429 hsa_status_t hsa_iterate_agents(hsa_status_t (*callback)(hsa_agent_t agent,
kono
parents:
diff changeset
430 void *data),
kono
parents:
diff changeset
431 void *data);
kono
parents:
diff changeset
432 void hsa_signal_subtract_acq_rel(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
433
kono
parents:
diff changeset
434 void hsa_signal_subtract_acquire(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
435
kono
parents:
diff changeset
436 void hsa_signal_subtract_relaxed(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
437
kono
parents:
diff changeset
438 void hsa_signal_subtract_release(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
439 hsa_status_t
kono
parents:
diff changeset
440 hsa_executable_symbol_get_info(hsa_executable_symbol_t executable_symbol,
kono
parents:
diff changeset
441 hsa_executable_symbol_info_t attribute,
kono
parents:
diff changeset
442 void *value);
kono
parents:
diff changeset
443 void hsa_signal_xor_acq_rel(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
444
kono
parents:
diff changeset
445 void hsa_signal_xor_acquire(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
446
kono
parents:
diff changeset
447 void hsa_signal_xor_relaxed(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
448
kono
parents:
diff changeset
449 void hsa_signal_xor_release(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
450 hsa_status_t hsa_code_object_get_info(hsa_code_object_t code_object,
kono
parents:
diff changeset
451 hsa_code_object_info_t attribute,
kono
parents:
diff changeset
452 void *value);
kono
parents:
diff changeset
453 hsa_status_t hsa_code_object_deserialize(void *serialized_code_object,
kono
parents:
diff changeset
454 size_t serialized_code_object_size,
kono
parents:
diff changeset
455 const char *options,
kono
parents:
diff changeset
456 hsa_code_object_t *code_object);
kono
parents:
diff changeset
457 hsa_status_t hsa_status_string(hsa_status_t status, const char **status_string);
kono
parents:
diff changeset
458 hsa_status_t hsa_code_object_get_symbol(hsa_code_object_t code_object,
kono
parents:
diff changeset
459 const char *symbol_name,
kono
parents:
diff changeset
460 hsa_code_symbol_t *symbol);
kono
parents:
diff changeset
461 void hsa_signal_store_relaxed(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
462
kono
parents:
diff changeset
463 void hsa_signal_store_release(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
464 hsa_status_t hsa_signal_destroy(hsa_signal_t signal);
kono
parents:
diff changeset
465 hsa_status_t hsa_system_get_extension_table(uint16_t extension,
kono
parents:
diff changeset
466 uint16_t version_major,
kono
parents:
diff changeset
467 uint16_t version_minor,
kono
parents:
diff changeset
468 void *table);
kono
parents:
diff changeset
469 hsa_status_t hsa_agent_iterate_regions(
kono
parents:
diff changeset
470 hsa_agent_t agent,
kono
parents:
diff changeset
471 hsa_status_t (*callback)(hsa_region_t region, void *data), void *data);
kono
parents:
diff changeset
472 hsa_status_t hsa_executable_agent_global_variable_define(
kono
parents:
diff changeset
473 hsa_executable_t executable, hsa_agent_t agent, const char *variable_name,
kono
parents:
diff changeset
474 void *address);
kono
parents:
diff changeset
475 hsa_status_t hsa_queue_create(hsa_agent_t agent, uint32_t size,
kono
parents:
diff changeset
476 hsa_queue_type_t type,
kono
parents:
diff changeset
477 void (*callback)(hsa_status_t status,
kono
parents:
diff changeset
478 hsa_queue_t *source, void *data),
kono
parents:
diff changeset
479 void *data, uint32_t private_segment_size,
kono
parents:
diff changeset
480 uint32_t group_segment_size, hsa_queue_t **queue);
kono
parents:
diff changeset
481 hsa_status_t hsa_isa_compatible(hsa_isa_t code_object_isa, hsa_isa_t agent_isa,
kono
parents:
diff changeset
482 bool *result);
kono
parents:
diff changeset
483 hsa_status_t hsa_code_object_serialize(
kono
parents:
diff changeset
484 hsa_code_object_t code_object,
kono
parents:
diff changeset
485 hsa_status_t (*alloc_callback)(size_t size, hsa_callback_data_t data,
kono
parents:
diff changeset
486 void **address),
kono
parents:
diff changeset
487 hsa_callback_data_t callback_data, const char *options,
kono
parents:
diff changeset
488 void **serialized_code_object, size_t *serialized_code_object_size);
kono
parents:
diff changeset
489 hsa_status_t hsa_region_get_info(hsa_region_t region,
kono
parents:
diff changeset
490 hsa_region_info_t attribute, void *value);
kono
parents:
diff changeset
491 hsa_status_t hsa_executable_freeze(hsa_extension_t executable,
kono
parents:
diff changeset
492 const char *options);
kono
parents:
diff changeset
493 hsa_status_t hsa_system_extension_supported(uint16_t extension,
kono
parents:
diff changeset
494 uint16_t version_major,
kono
parents:
diff changeset
495 uint16_t version_minor,
kono
parents:
diff changeset
496 bool *result);
kono
parents:
diff changeset
497 hsa_signal_value_t hsa_signal_wait_acquire(hsa_signal_t signal,
kono
parents:
diff changeset
498 hsa_signal_condition_t condition,
kono
parents:
diff changeset
499 hsa_signal_value_t compare_value,
kono
parents:
diff changeset
500 uint64_t timeout_hint,
kono
parents:
diff changeset
501 hsa_wait_state_t wait_state_hint);
kono
parents:
diff changeset
502
kono
parents:
diff changeset
503 hsa_signal_value_t hsa_signal_wait_relaxed(hsa_signal_t signal,
kono
parents:
diff changeset
504 hsa_signal_condition_t condition,
kono
parents:
diff changeset
505 hsa_signal_value_t compare_value,
kono
parents:
diff changeset
506 uint64_t timeout_hint,
kono
parents:
diff changeset
507 hsa_wait_state_t wait_state_hint);
kono
parents:
diff changeset
508 hsa_status_t hsa_memory_copy(void *dst, const void *src, size_t size);
kono
parents:
diff changeset
509 hsa_status_t hsa_memory_free(void *ptr);
kono
parents:
diff changeset
510 hsa_status_t hsa_queue_destroy(hsa_queue_t *queue);
kono
parents:
diff changeset
511 hsa_status_t hsa_isa_from_name(const char *name, hsa_isa_t *isa);
kono
parents:
diff changeset
512 hsa_status_t hsa_isa_get_info(hsa_isa_t isa, hsa_isa_info_t attribute,
kono
parents:
diff changeset
513 uint32_t index, void *value);
kono
parents:
diff changeset
514 hsa_status_t hsa_signal_create(hsa_signal_value_t initial_value,
kono
parents:
diff changeset
515 uint32_t num_consumers,
kono
parents:
diff changeset
516 const hsa_agent_t *consumers,
kono
parents:
diff changeset
517 hsa_signal_t *signal);
kono
parents:
diff changeset
518 hsa_status_t hsa_code_symbol_get_info(hsa_code_symbol_t code_symbol,
kono
parents:
diff changeset
519 hsa_code_symbol_info_t attribute,
kono
parents:
diff changeset
520 void *value);
kono
parents:
diff changeset
521 hsa_signal_value_t hsa_signal_cas_acq_rel(hsa_signal_t signal,
kono
parents:
diff changeset
522 hsa_signal_value_t expected,
kono
parents:
diff changeset
523 hsa_signal_value_t value);
kono
parents:
diff changeset
524
kono
parents:
diff changeset
525 hsa_signal_value_t hsa_signal_cas_acquire(hsa_signal_t signal,
kono
parents:
diff changeset
526 hsa_signal_value_t expected,
kono
parents:
diff changeset
527 hsa_signal_value_t value);
kono
parents:
diff changeset
528
kono
parents:
diff changeset
529 hsa_signal_value_t hsa_signal_cas_relaxed(hsa_signal_t signal,
kono
parents:
diff changeset
530 hsa_signal_value_t expected,
kono
parents:
diff changeset
531 hsa_signal_value_t value);
kono
parents:
diff changeset
532
kono
parents:
diff changeset
533 hsa_signal_value_t hsa_signal_cas_release(hsa_signal_t signal,
kono
parents:
diff changeset
534 hsa_signal_value_t expected,
kono
parents:
diff changeset
535 hsa_signal_value_t value);
kono
parents:
diff changeset
536 hsa_status_t hsa_code_object_iterate_symbols(
kono
parents:
diff changeset
537 hsa_code_object_t code_object,
kono
parents:
diff changeset
538 hsa_status_t (*callback)(hsa_code_object_t code_object,
kono
parents:
diff changeset
539 hsa_code_symbol_t symbol, void *data),
kono
parents:
diff changeset
540 void *data);
kono
parents:
diff changeset
541 void hsa_queue_store_read_index_relaxed(const hsa_queue_t *queue,
kono
parents:
diff changeset
542 uint64_t value);
kono
parents:
diff changeset
543
kono
parents:
diff changeset
544 void hsa_queue_store_read_index_release(const hsa_queue_t *queue,
kono
parents:
diff changeset
545 uint64_t value);
kono
parents:
diff changeset
546 hsa_status_t hsa_memory_assign_agent(void *ptr, hsa_agent_t agent,
kono
parents:
diff changeset
547 hsa_access_permission_t access);
kono
parents:
diff changeset
548 hsa_status_t hsa_queue_inactivate(hsa_queue_t *queue);
kono
parents:
diff changeset
549 hsa_status_t hsa_executable_get_symbol(hsa_executable_t executable,
kono
parents:
diff changeset
550 const char *module_name,
kono
parents:
diff changeset
551 const char *symbol_name,
kono
parents:
diff changeset
552 hsa_agent_t agent,
kono
parents:
diff changeset
553 int32_t call_convention,
kono
parents:
diff changeset
554 hsa_executable_symbol_t *symbol);
kono
parents:
diff changeset
555 uint64_t hsa_queue_cas_write_index_acq_rel(const hsa_queue_t *queue,
kono
parents:
diff changeset
556 uint64_t expected, uint64_t value);
kono
parents:
diff changeset
557
kono
parents:
diff changeset
558 uint64_t hsa_queue_cas_write_index_acquire(const hsa_queue_t *queue,
kono
parents:
diff changeset
559 uint64_t expected, uint64_t value);
kono
parents:
diff changeset
560
kono
parents:
diff changeset
561 uint64_t hsa_queue_cas_write_index_relaxed(const hsa_queue_t *queue,
kono
parents:
diff changeset
562 uint64_t expected, uint64_t value);
kono
parents:
diff changeset
563
kono
parents:
diff changeset
564 uint64_t hsa_queue_cas_write_index_release(const hsa_queue_t *queue,
kono
parents:
diff changeset
565 uint64_t expected, uint64_t value);
kono
parents:
diff changeset
566 void hsa_signal_and_acq_rel(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
567
kono
parents:
diff changeset
568 void hsa_signal_and_acquire(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
569
kono
parents:
diff changeset
570 void hsa_signal_and_relaxed(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
571
kono
parents:
diff changeset
572 void hsa_signal_and_release(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
573 uint64_t hsa_queue_load_read_index_acquire(const hsa_queue_t *queue);
kono
parents:
diff changeset
574
kono
parents:
diff changeset
575 uint64_t hsa_queue_load_read_index_relaxed(const hsa_queue_t *queue);
kono
parents:
diff changeset
576 hsa_status_t hsa_executable_load_code_object(hsa_executable_t executable,
kono
parents:
diff changeset
577 hsa_agent_t agent,
kono
parents:
diff changeset
578 hsa_code_object_t code_object,
kono
parents:
diff changeset
579 const char *options);
kono
parents:
diff changeset
580 uint64_t hsa_queue_load_write_index_acquire(const hsa_queue_t *queue);
kono
parents:
diff changeset
581
kono
parents:
diff changeset
582 uint64_t hsa_queue_load_write_index_relaxed(const hsa_queue_t *queue);
kono
parents:
diff changeset
583 hsa_status_t hsa_agent_get_exception_policies(hsa_agent_t agent,
kono
parents:
diff changeset
584 hsa_profile_t profile,
kono
parents:
diff changeset
585 uint16_t *mask);
kono
parents:
diff changeset
586 hsa_status_t hsa_memory_deregister(void *ptr, size_t size);
kono
parents:
diff changeset
587 void hsa_signal_or_acq_rel(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
588
kono
parents:
diff changeset
589 void hsa_signal_or_acquire(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
590
kono
parents:
diff changeset
591 void hsa_signal_or_relaxed(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
592
kono
parents:
diff changeset
593 void hsa_signal_or_release(hsa_signal_t signal, hsa_signal_value_t value);
kono
parents:
diff changeset
594 hsa_status_t hsa_soft_queue_create(hsa_region_t region, uint32_t size,
kono
parents:
diff changeset
595 hsa_queue_type_t type, uint32_t features,
kono
parents:
diff changeset
596 hsa_signal_t doorbell_signal,
kono
parents:
diff changeset
597 hsa_queue_t **queue);
kono
parents:
diff changeset
598 hsa_status_t hsa_executable_iterate_symbols(
kono
parents:
diff changeset
599 hsa_executable_t executable,
kono
parents:
diff changeset
600 hsa_status_t (*callback)(hsa_executable_t executable,
kono
parents:
diff changeset
601 hsa_executable_symbol_t symbol, void *data),
kono
parents:
diff changeset
602 void *data);
kono
parents:
diff changeset
603 hsa_status_t hsa_memory_register(void *ptr, size_t size);
kono
parents:
diff changeset
604 void hsa_queue_store_write_index_relaxed(const hsa_queue_t *queue,
kono
parents:
diff changeset
605 uint64_t value);
kono
parents:
diff changeset
606
kono
parents:
diff changeset
607 void hsa_queue_store_write_index_release(const hsa_queue_t *queue,
kono
parents:
diff changeset
608 uint64_t value);
kono
parents:
diff changeset
609 hsa_status_t hsa_executable_global_variable_define(hsa_executable_t executable,
kono
parents:
diff changeset
610 const char *variable_name,
kono
parents:
diff changeset
611 void *address);
kono
parents:
diff changeset
612 hsa_status_t hsa_executable_destroy(hsa_executable_t executable);
kono
parents:
diff changeset
613 hsa_status_t hsa_code_object_destroy(hsa_code_object_t code_object);
kono
parents:
diff changeset
614 hsa_status_t hsa_memory_allocate(hsa_region_t region, size_t size, void **ptr);
kono
parents:
diff changeset
615 hsa_signal_value_t hsa_signal_exchange_acq_rel(hsa_signal_t signal,
kono
parents:
diff changeset
616 hsa_signal_value_t value);
kono
parents:
diff changeset
617
kono
parents:
diff changeset
618 hsa_signal_value_t hsa_signal_exchange_acquire(hsa_signal_t signal,
kono
parents:
diff changeset
619 hsa_signal_value_t value);
kono
parents:
diff changeset
620
kono
parents:
diff changeset
621 hsa_signal_value_t hsa_signal_exchange_relaxed(hsa_signal_t signal,
kono
parents:
diff changeset
622 hsa_signal_value_t value);
kono
parents:
diff changeset
623
kono
parents:
diff changeset
624 hsa_signal_value_t hsa_signal_exchange_release(hsa_signal_t signal,
kono
parents:
diff changeset
625 hsa_signal_value_t value);
kono
parents:
diff changeset
626 hsa_status_t hsa_agent_get_info(hsa_agent_t agent, hsa_agent_info_t attribute,
kono
parents:
diff changeset
627 void *value);
kono
parents:
diff changeset
628 hsa_status_t hsa_init();
kono
parents:
diff changeset
629 hsa_status_t hsa_system_get_info(hsa_system_info_t attribute, void *value);
kono
parents:
diff changeset
630 hsa_status_t hsa_executable_create(hsa_profile_t profile,
kono
parents:
diff changeset
631 hsa_executable_state_t executable_state,
kono
parents:
diff changeset
632 const char *options,
kono
parents:
diff changeset
633 hsa_executable_t *executable);
kono
parents:
diff changeset
634
kono
parents:
diff changeset
635 #endif /* _HSA_H */