From: Marek Olšák Date: Sat, 11 Feb 2017 19:51:41 +0000 (+0100) Subject: gallium/u_queue: add util_queue_get_thread_time_nano X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=626e4ef18f1ffc521ab3e6faef3173abedd52dbf;p=mesa.git gallium/u_queue: add util_queue_get_thread_time_nano Reviewed-by: Nicolai Hähnle --- diff --git a/src/gallium/auxiliary/util/u_queue.c b/src/gallium/auxiliary/util/u_queue.c index 838464fb9a6..4da5d8e9f8c 100644 --- a/src/gallium/auxiliary/util/u_queue.c +++ b/src/gallium/auxiliary/util/u_queue.c @@ -242,3 +242,13 @@ util_queue_add_job(struct util_queue *queue, pipe_condvar_signal(queue->has_queued_cond); pipe_mutex_unlock(queue->lock); } + +int64_t +util_queue_get_thread_time_nano(struct util_queue *queue, unsigned thread_index) +{ + /* Allow some flexibility by not raising an error. */ + if (thread_index >= queue->num_threads) + return 0; + + return pipe_thread_get_time_nano(queue->threads[thread_index]); +} diff --git a/src/gallium/auxiliary/util/u_queue.h b/src/gallium/auxiliary/util/u_queue.h index 59646cc298b..351315c5780 100644 --- a/src/gallium/auxiliary/util/u_queue.h +++ b/src/gallium/auxiliary/util/u_queue.h @@ -84,6 +84,8 @@ void util_queue_add_job(struct util_queue *queue, util_queue_execute_func cleanup); void util_queue_job_wait(struct util_queue_fence *fence); +int64_t util_queue_get_thread_time_nano(struct util_queue *queue, + unsigned thread_index); /* util_queue needs to be cleared to zeroes for this to work */ static inline bool