This makes sure that objects are leaving wait list only when they are processed 
by gpu.

Signed-off-by: Pauli Nieminen <[email protected]>
---
 src/mesa/drivers/dri/radeon/radeon_bo_drm.h    |   13 +++++++++++++
 src/mesa/drivers/dri/radeon/radeon_bo_legacy.c |    7 +++++++
 src/mesa/drivers/dri/radeon/radeon_dma.c       |   10 +++++++++-
 3 files changed, 29 insertions(+), 1 deletions(-)

diff --git a/src/mesa/drivers/dri/radeon/radeon_bo_drm.h 
b/src/mesa/drivers/dri/radeon/radeon_bo_drm.h
index 8789e3a..79ca505 100644
--- a/src/mesa/drivers/dri/radeon/radeon_bo_drm.h
+++ b/src/mesa/drivers/dri/radeon/radeon_bo_drm.h
@@ -73,6 +73,7 @@ struct radeon_bo_funcs {
                          uint32_t pitch);
     int (*bo_get_tiling)(struct radeon_bo *bo, uint32_t *tiling_flags,
                          uint32_t *pitch);
+    int (*bo_is_busy)(struct radeon_bo *bo, int *busy, int *domain);
 };
 
 struct radeon_bo_manager {
@@ -170,6 +171,16 @@ static inline int _radeon_bo_wait(struct radeon_bo *bo,
     return bo->bom->funcs->bo_wait(bo);
 }
 
+static inline int _radeon_bo_is_busy(struct radeon_bo *bo,
+                                     int *busy,
+                                    int *domain,
+                                     const char *file,
+                                     const char *func,
+                                     int line)
+{
+    return bo->bom->funcs->bo_is_busy(bo, busy, domain);
+}
+
 static inline int radeon_bo_set_tiling(struct radeon_bo *bo,
                                       uint32_t tiling_flags, uint32_t pitch)
 {
@@ -203,5 +214,7 @@ static inline int radeon_bo_is_static(struct radeon_bo *bo)
     _radeon_bo_debug(bo, opcode, __FILE__, __FUNCTION__, __LINE__)
 #define radeon_bo_wait(bo) \
     _radeon_bo_wait(bo, __FILE__, __func__, __LINE__)
+#define radeon_bo_is_busy(bo, busy, domain) \
+    _radeon_bo_is_busy(bo, busy, domain, __FILE__, __func__, __LINE__)
 
 #endif
diff --git a/src/mesa/drivers/dri/radeon/radeon_bo_legacy.c 
b/src/mesa/drivers/dri/radeon/radeon_bo_legacy.c
index b1cc155..ce05504 100644
--- a/src/mesa/drivers/dri/radeon/radeon_bo_legacy.c
+++ b/src/mesa/drivers/dri/radeon/radeon_bo_legacy.c
@@ -542,6 +542,12 @@ static int bo_unmap(struct radeon_bo *bo)
     return 0;
 }
 
+static int bo_is_busy(struct radeon_bo *bo, int *busy, int *domain)
+{
+  *domain = 0;
+  *busy = legacy_is_pending(bo);
+  return 0;
+}
 
 static int bo_is_static(struct radeon_bo *bo)
 {
@@ -559,6 +565,7 @@ static struct radeon_bo_funcs bo_legacy_funcs = {
     bo_is_static,
     NULL,
     NULL,
+    bo_is_busy
 };
 
 static int bo_vram_validate(struct radeon_bo *bo,
diff --git a/src/mesa/drivers/dri/radeon/radeon_dma.c 
b/src/mesa/drivers/dri/radeon/radeon_dma.c
index 40082d0..5ddf798 100644
--- a/src/mesa/drivers/dri/radeon/radeon_dma.c
+++ b/src/mesa/drivers/dri/radeon/radeon_dma.c
@@ -30,6 +30,7 @@ USE OR OTHER DEALINGS IN THE SOFTWARE.
 
 **************************************************************************/
 
+#include <errno.h>
 #include "radeon_common.h"
 #include "main/simple_list.h"
 
@@ -299,7 +300,14 @@ void radeonReturnDmaRegion(radeonContextPtr rmesa, int 
return_bytes)
 
 static int radeon_bo_is_idle(struct radeon_bo* bo)
 {
-       return bo->cref == 1;
+       int busy;
+       int domain;
+       int ret = radeon_bo_is_busy(bo, &busy, &domain);
+       if (ret == -EINVAL) {
+               WARN_ONCE("Your libdrm or kernel doesn't have support for busy 
query.\n"
+                       "This may cause small performance drop for you.\n");
+       }
+       return !busy;
 }
 
 void radeonReleaseDmaRegions(radeonContextPtr rmesa)
-- 
1.6.3.3


------------------------------------------------------------------------------
Let Crystal Reports handle the reporting - Free Crystal Reports 2008 30-Day 
trial. Simplify your report design, integration and deployment - and focus on 
what you do best, core application coding. Discover what's new with 
Crystal Reports now.  http://p.sf.net/sfu/bobj-july
_______________________________________________
Mesa3d-dev mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/mesa3d-dev

Reply via email to