| //===-- Queue.td - Queue definitions for Offload -----------*- tablegen -*-===// |
| // |
| // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| // See https://llvm.org/LICENSE.txt for license information. |
| // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| // |
| //===----------------------------------------------------------------------===// |
| // |
| // This file contains Offload API definitions related to the queue handle |
| // |
| //===----------------------------------------------------------------------===// |
| |
| def : Function { |
| let name = "olCreateQueue"; |
| let desc = "Create a queue for the given device."; |
| let details = []; |
| let params = [ |
| Param<"ol_device_handle_t", "Device", "handle of the device", PARAM_IN>, |
| Param<"ol_queue_handle_t*", "Queue", "output pointer for the created queue", PARAM_OUT> |
| ]; |
| let returns = []; |
| } |
| |
| def : Function { |
| let name = "olDestroyQueue"; |
| let desc = "Destroy the queue and free all underlying resources."; |
| let details = [ |
| "Any work previously enqueued to the queue is still performed and any events generated for this queue remain valid." |
| ]; |
| let params = [ |
| Param<"ol_queue_handle_t", "Queue", "handle of the queue", PARAM_IN> |
| ]; |
| let returns = []; |
| } |
| |
| def : Function { |
| let name = "olSyncQueue"; |
| let desc = "Block the calling thread until the enqueued work on a queue is complete."; |
| let details = []; |
| let params = [ |
| Param<"ol_queue_handle_t", "Queue", "handle of the queue", PARAM_IN> |
| ]; |
| let returns = []; |
| } |
| |
| def : Function { |
| let name = "olWaitEvents"; |
| let desc = "Make any future work submitted to this queue wait until the provided events are complete."; |
| let details = [ |
| "All events in `Events` must complete before the queue is unblocked.", |
| "The input events can be from any queue on any device provided by the same platform as `Queue`.", |
| ]; |
| let params = [ |
| Param<"ol_queue_handle_t", "Queue", "handle of the queue", PARAM_IN>, |
| Param<"ol_event_handle_t *", "Events", "list of `NumEvents` events to wait for", PARAM_IN>, |
| Param<"size_t", "NumEvents", "size of `Events`", PARAM_IN>, |
| ]; |
| let returns = [ |
| Return<"OL_ERRC_INVALID_NULL_HANDLE", ["Any event handle in the list is NULL"]>, |
| ]; |
| } |
| |
| def : Enum { |
| let name = "ol_queue_info_t"; |
| let desc = "Supported queue info."; |
| let is_typed = 1; |
| let etors = [ |
| TaggedEtor<"DEVICE", "ol_device_handle_t", "The handle of the device associated with the queue.">, |
| TaggedEtor<"EMPTY", "bool", "True if the queue is known to be empty. May be unconditionally false if the device does not support status queries.">, |
| ]; |
| } |
| |
| def : Function { |
| let name = "olGetQueueInfo"; |
| let desc = "Queries the given property of the queue."; |
| let details = [ |
| "`olGetQueueInfoSize` can be used to query the storage size " |
| "required for the given query." |
| ]; |
| let params = [ |
| Param<"ol_queue_handle_t", "Queue", "handle of the queue", PARAM_IN>, |
| Param<"ol_queue_info_t", "PropName", "type of the info to retrieve", PARAM_IN>, |
| Param<"size_t", "PropSize", "the number of bytes pointed to by PropValue.", PARAM_IN>, |
| TypeTaggedParam<"void*", "PropValue", "array of bytes holding the info. " |
| "If Size is not equal to or greater to the real number of bytes needed to return the info " |
| "then the OL_ERRC_INVALID_SIZE error is returned and pPlatformInfo is not used.", PARAM_OUT, |
| TypeInfo<"PropName" , "PropSize">> |
| ]; |
| let returns = [ |
| Return<"OL_ERRC_INVALID_SIZE", [ |
| "`PropSize == 0`", |
| "If `PropSize` is less than the real number of bytes needed to return the info." |
| ]>, |
| Return<"OL_ERRC_INVALID_QUEUE"> |
| ]; |
| } |
| |
| def : Function { |
| let name = "olGetQueueInfoSize"; |
| let desc = "Returns the storage size of the given queue query."; |
| let details = []; |
| let params = [ |
| Param<"ol_queue_handle_t", "Queue", "handle of the queue", PARAM_IN>, |
| Param<"ol_queue_info_t", "PropName", "type of the info to query", PARAM_IN>, |
| Param<"size_t*", "PropSizeRet", "pointer to the number of bytes required to store the query", PARAM_OUT> |
| ]; |
| let returns = [ |
| Return<"OL_ERRC_INVALID_QUEUE"> |
| ]; |
| } |
| |
| def : FptrTypedef { |
| let name = "ol_host_function_cb_t"; |
| let desc = "Host function for use by `olLaunchHostFunction`."; |
| let params = [ |
| Param<"void *", "UserData", "user specified data passed into `olLaunchHostFunction`.", PARAM_IN>, |
| ]; |
| let return = "void"; |
| } |
| |
| def : Function { |
| let name = "olLaunchHostFunction"; |
| let desc = "Enqueue a callback function on the host."; |
| let details = [ |
| "The provided function will be called from the same process as the one that called `olLaunchHostFunction`.", |
| "The callback will not run until all previous work submitted to the queue has completed.", |
| "The callback must return before any work submitted to the queue after it is started.", |
| "The callback must not call any liboffload API functions or any backend specific functions (such as Cuda or HSA library functions).", |
| ]; |
| let params = [ |
| Param<"ol_queue_handle_t", "Queue", "handle of the queue", PARAM_IN>, |
| Param<"ol_host_function_cb_t", "Callback", "the callback function to call on the host", PARAM_IN>, |
| Param<"void *", "UserData", "a pointer that will be passed verbatim to the callback function", PARAM_IN_OPTIONAL>, |
| ]; |
| let returns = []; |
| } |