From af2a856caa84755d3b1a0a887d000ce7dc3221dd Mon Sep 17 00:00:00 2001 From: Younes Manton Date: Thu, 11 Dec 2008 17:55:16 -0500 Subject: nouveau: Add busy() query, determines if BOs can be mapped immediately. --- src/gallium/winsys/drm/nouveau/nouveau_bo.c | 34 ++++++++++++++++++++++++++ src/gallium/winsys/drm/nouveau/nouveau_drmif.h | 3 +++ 2 files changed, 37 insertions(+) (limited to 'src/gallium') diff --git a/src/gallium/winsys/drm/nouveau/nouveau_bo.c b/src/gallium/winsys/drm/nouveau/nouveau_bo.c index b5942994d94..76b98bed675 100644 --- a/src/gallium/winsys/drm/nouveau/nouveau_bo.c +++ b/src/gallium/winsys/drm/nouveau/nouveau_bo.c @@ -272,6 +272,40 @@ nouveau_bo_del(struct nouveau_bo **bo) nouveau_bo_del_cb(nvbo); } +int +nouveau_bo_busy(struct nouveau_bo *bo, uint32_t flags) +{ + struct nouveau_bo_priv *nvbo = nouveau_bo(bo); + struct nouveau_fence *fence; + + if (!nvbo) + return -EINVAL; + + /* If the buffer is pending it must be busy, unless + * both are RD, in which case we can allow access */ + if (nvbo->pending) { + if ((nvbo->pending->flags & NOUVEAU_BO_RDWR) == NOUVEAU_BO_RD && + (flags & NOUVEAU_BO_RDWR) == NOUVEAU_BO_RD) + return 0; + else + return 1; + } + + if (flags & NOUVEAU_BO_WR) + fence = nvbo->fence; + else + fence = nvbo->wr_fence; + + /* If the buffer is not pending and doesn't have a fence + * that conflicts with our flags then it can't be busy + */ + if (!fence) + return 0; + else + /* If the fence is signalled the buffer is not busy, else is busy */ + return !nouveau_fence(fence)->signalled; +} + int nouveau_bo_map(struct nouveau_bo *bo, uint32_t flags) { diff --git a/src/gallium/winsys/drm/nouveau/nouveau_drmif.h b/src/gallium/winsys/drm/nouveau/nouveau_drmif.h index dcd6a5eb0a4..5f72800676d 100644 --- a/src/gallium/winsys/drm/nouveau/nouveau_drmif.h +++ b/src/gallium/winsys/drm/nouveau/nouveau_drmif.h @@ -286,6 +286,9 @@ nouveau_bo_set_status(struct nouveau_bo *, uint32_t flags); extern void nouveau_bo_del(struct nouveau_bo **); +extern int +nouveau_bo_busy(struct nouveau_bo *bo, uint32_t flags); + extern int nouveau_bo_map(struct nouveau_bo *, uint32_t flags); -- cgit v1.2.3