128 lines
5.1 KiB
TableGen
128 lines
5.1 KiB
TableGen
//===-- 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 olCreateQueue : Function {
|
|
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 olDestroyQueue : Function {
|
|
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 olSyncQueue : Function {
|
|
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 olWaitEvents : Function {
|
|
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 ol_queue_info_t : Enum {
|
|
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 olGetQueueInfo : Function {
|
|
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 olGetQueueInfoSize : Function {
|
|
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 ol_host_function_cb_t : FptrTypedef {
|
|
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 olLaunchHostFunction : Function {
|
|
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 = [];
|
|
}
|