[Beignet] [PATCH 1/2] [opencl 1.2]fix event related bugs.
xionghu.luo at intel.com
xionghu.luo at intel.com
Mon Apr 28 13:27:24 PDT 2014
From: Luo <xionghu.luo at intel.com>
---
src/cl_alloc.c | 1 +
src/cl_event.c | 80 +++++++++++++++++++++++++++++++++-------------------------
2 files changed, 47 insertions(+), 34 deletions(-)
diff --git a/src/cl_alloc.c b/src/cl_alloc.c
index 20d5578..93d2e6a 100644
--- a/src/cl_alloc.c
+++ b/src/cl_alloc.c
@@ -71,6 +71,7 @@ cl_free(void *ptr)
return;
atomic_dec(&cl_alloc_n);
free(ptr);
+ ptr = NULL;
}
LOCAL size_t
diff --git a/src/cl_event.c b/src/cl_event.c
index 727ee1f..85e4041 100644
--- a/src/cl_event.c
+++ b/src/cl_event.c
@@ -260,12 +260,12 @@ void cl_event_new_enqueue_callback(cl_event event,
cl_int i;
GET_QUEUE_THREAD_GPGPU(data->queue);
- /* Allocate and inialize the structure itself */
+ /* Allocate and initialize the structure itself */
TRY_ALLOC_NO_ERR (cb, CALLOC(enqueue_callback));
cb->num_events = num_events_in_wait_list;
TRY_ALLOC_NO_ERR (cb->wait_list, CALLOC_ARRAY(cl_event, num_events_in_wait_list));
for(i=0; i<num_events_in_wait_list; i++)
- cb->wait_list[i] = event_wait_list[i];
+ cb->wait_list[i] = event_wait_list[i];
cb->event = event;
cb->next = NULL;
cb->wait_user_events = NULL;
@@ -276,12 +276,13 @@ void cl_event_new_enqueue_callback(cl_event event,
node = queue->wait_events[i]->waits_head;
if(node == NULL)
queue->wait_events[i]->waits_head = cb;
- else
- while((node != cb) && node->next)
- node = node->next;
- if(node == cb) //wait on dup user event
- continue;
- node->next = cb;
+ else{
+ while((node != cb) && node->next)
+ node = node->next;
+ if(node == cb) //wait on dup user event
+ continue;
+ node->next = cb;
+ }
/* Insert the user event to enqueue_callback's wait_user_events */
TRY_ALLOC_NO_ERR (u_ev, CALLOC(user_event));
@@ -291,7 +292,7 @@ void cl_event_new_enqueue_callback(cl_event event,
}
}
- /* Find out all user events that events in event_wait_list wait */
+ /* Find out all user events that in event_wait_list wait */
for(i=0; i<num_events_in_wait_list; i++) {
if(event_wait_list[i]->status <= CL_COMPLETE)
continue;
@@ -319,21 +320,25 @@ void cl_event_new_enqueue_callback(cl_event event,
while(user_events != NULL) {
/* Insert the enqueue_callback to user event's waits_tail */
node = user_events->event->waits_head;
- while((node != cb) && node->next)
- node = node->next;
- if(node == cb) { //wait on dup user event
- user_events = user_events->next;
- continue;
+ if(node == NULL)
+ event_wait_list[i]->waits_head = cb;
+ else{
+ while((node != cb) && node->next)
+ node = node->next;
+ if(node == cb) { //wait on dup user event
+ user_events = user_events->next;
+ continue;
+ }
+ node->next = cb;
}
- node->next = cb;
/* Insert the user event to enqueue_callback's wait_user_events */
TRY_ALLOC_NO_ERR (u_ev, CALLOC(user_event));
u_ev->event = user_events->event;
u_ev->next = cb->wait_user_events;
cb->wait_user_events = u_ev;
+ cl_command_queue_insert_event(event->queue, user_events->event);
user_events = user_events->next;
- cl_command_queue_insert_event(event->queue, event_wait_list[i]);
}
}
}
@@ -354,7 +359,7 @@ error:
cl_free(u_ev);
}
if(cb->wait_list)
- cl_free(cb->wait_list);
+ cl_free(cb->wait_list);
cl_free(cb);
}
goto exit;
@@ -363,7 +368,7 @@ error:
void cl_event_set_status(cl_event event, cl_int status)
{
user_callback *user_cb;
- user_event *u_ev, *u_ev_next;
+ user_event *u_ev;
cl_int ret, i;
cl_event evt;
@@ -387,11 +392,11 @@ void cl_event_set_status(cl_event event, cl_int status)
pthread_mutex_unlock(&event->ctx->event_lock);
for(i=0; i<event->enqueue_cb->num_events; i++)
- cl_event_delete(event->enqueue_cb->wait_list[i]);
+ cl_event_delete(event->enqueue_cb->wait_list[i]);
pthread_mutex_lock(&event->ctx->event_lock);
if(event->enqueue_cb->wait_list)
- cl_free(event->enqueue_cb->wait_list);
+ cl_free(event->enqueue_cb->wait_list);
cl_free(event->enqueue_cb);
event->enqueue_cb = NULL;
}
@@ -419,22 +424,29 @@ void cl_event_set_status(cl_event event, cl_int status)
/* Check all defer enqueue */
enqueue_callback *cb, *enqueue_cb = event->waits_head;
while(enqueue_cb) {
- /* Remove this user event in enqueue_cb */
- while(enqueue_cb->wait_user_events &&
- enqueue_cb->wait_user_events->event == event) {
- u_ev = enqueue_cb->wait_user_events;
- enqueue_cb->wait_user_events = enqueue_cb->wait_user_events->next;
- cl_free(u_ev);
- }
-
+ /* Remove this user event in enqueue_cb, update the header if needed. */
u_ev = enqueue_cb->wait_user_events;
+ user_event * u_prev = NULL;
+ user_event *tmp =NULL;
while(u_ev) {
- u_ev_next = u_ev->next;
- if(u_ev_next && u_ev_next->event == event) {
- u_ev->next = u_ev_next->next;
- cl_free(u_ev_next);
- } else
- u_ev->next = u_ev_next;
+ if(u_ev && u_ev->event == event) {
+ if(u_prev){
+ u_prev->next = u_ev->next;
+ }
+ tmp = u_ev;
+ u_ev = u_ev->next;
+ cl_free(tmp);
+ }else{
+ if(!u_prev){
+ enqueue_cb->wait_user_events = u_ev;
+ }
+ u_prev=u_ev;
+ u_ev = u_ev->next;
+ }
+ }
+
+ if(!u_prev){
+ enqueue_cb->wait_user_events = NULL;
}
/* Still wait on other user events */
--
1.8.1.2
More information about the Beignet
mailing list