From 047eb1a3840ca2d983ae2b6dd8bd51cf22a25943 Mon Sep 17 00:00:00 2001 From: Jason Volk Date: Wed, 17 Mar 2021 12:05:03 -0700 Subject: [PATCH] ircd::cl: Preempt callback; improve status checks, error code. --- ircd/cl.cc | 22 +++++++++++++++++++--- 1 file changed, 19 insertions(+), 3 deletions(-) diff --git a/ircd/cl.cc b/ircd/cl.cc index 3c54d9b55..6f40b2b35 100644 --- a/ircd/cl.cc +++ b/ircd/cl.cc @@ -900,6 +900,22 @@ ircd::cl::handle_offload() return; } + int status; try + { + char buf[4] {0}; + status = info(clGetEventInfo, p.event, CL_EVENT_COMMAND_EXECUTION_STATUS, buf); + } + catch(...) + { + status = -1; + } + + if(status < 0 || status == CL_COMPLETE) + { + handle_event(p.event, status, p.ctx); + return; + } + const auto res { clSetEventCallback(p.event, CL_COMPLETE, &handle_event, p.ctx) @@ -921,7 +937,7 @@ ircd::cl::handle_event(cl_event event, void *const priv) noexcept { - assert(status == CL_COMPLETE); + always_assert(status < 0 || status == CL_COMPLETE); // Prepare response to the main thread. The event pointer is anulled to // indicate completion. @@ -1024,13 +1040,13 @@ noexcept try cl_event(this->handle) }; - char status_buf[8] {0}; + char status_buf[4] {0}; const auto &status { info(clGetEventInfo, handle, CL_EVENT_COMMAND_EXECUTION_STATUS, status_buf) }; - if(status != CL_COMPLETE) + if(status >= 0 && status != CL_COMPLETE) handle_incomplete(*this, status); call(clReleaseEvent, cl_event(handle));