From: Kenneth Graunke Date: Tue, 16 Apr 2019 20:23:06 +0000 (-0700) Subject: iris: Make a resource_is_busy() helper X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=768b17a7ad12fa59de5e4be89029b579a5832baf;p=mesa.git iris: Make a resource_is_busy() helper This checks both "is it busy" and "do we have work queued up for it"? --- diff --git a/src/gallium/drivers/iris/iris_resource.c b/src/gallium/drivers/iris/iris_resource.c index 293f71aa1f9..ddff9296c60 100644 --- a/src/gallium/drivers/iris/iris_resource.c +++ b/src/gallium/drivers/iris/iris_resource.c @@ -878,6 +878,18 @@ iris_resource_get_handle(struct pipe_screen *pscreen, return false; } +static bool +resource_is_busy(struct iris_context *ice, + struct iris_resource *res) +{ + bool busy = iris_bo_busy(res->bo); + + for (int i = 0; i < IRIS_BATCH_COUNT; i++) + busy |= iris_batch_references(&ice->batches[i], res->bo); + + return busy; +} + static void iris_invalidate_resource(struct pipe_context *ctx, struct pipe_resource *resource) @@ -1331,10 +1343,7 @@ iris_transfer_map(struct pipe_context *ctx, } if (!(usage & PIPE_TRANSFER_UNSYNCHRONIZED)) { - map_would_stall = iris_bo_busy(res->bo); - - for (int i = 0; i < IRIS_BATCH_COUNT; i++) - map_would_stall |= iris_batch_references(&ice->batches[i], res->bo); + map_would_stall = resource_is_busy(ice, res); if (map_would_stall && (usage & PIPE_TRANSFER_DONTBLOCK) && (usage & PIPE_TRANSFER_MAP_DIRECTLY))