diff options
| author | Zou Nan hai <nanhai.zou@intel.com> | 2006-12-13 15:27:17 +0800 | 
|---|---|---|
| committer | Keith Packard <keithp@neko.keithp.com> | 2007-01-06 15:18:23 -0800 | 
| commit | ef02f8be10a9f95788fee48bb9e7801dea0c2ba6 (patch) | |
| tree | 3e710c9bc81473e802870c34a5c491a7bbde1998 | |
| parent | 652ae2c3765a471f94ca7b7328a0d572182bb127 (diff) | |
i965: xdemos/glxthreads get: Assertion `block->fenced' failed (9201)
Signed-off-by: Keith Packard <keithp@neko.keithp.com>
| -rw-r--r-- | src/mesa/drivers/dri/i965/bufmgr.h | 2 | ||||
| -rw-r--r-- | src/mesa/drivers/dri/i965/bufmgr_fake.c | 16 | ||||
| -rw-r--r-- | src/mesa/drivers/dri/i965/intel_blit.c | 4 | 
3 files changed, 18 insertions, 4 deletions
| diff --git a/src/mesa/drivers/dri/i965/bufmgr.h b/src/mesa/drivers/dri/i965/bufmgr.h index 6932522d3d..e748c0d6d0 100644 --- a/src/mesa/drivers/dri/i965/bufmgr.h +++ b/src/mesa/drivers/dri/i965/bufmgr.h @@ -199,9 +199,11 @@ void *bmFindVirtual( struct intel_context *intel,   * For now they can stay, but will likely change/move before final:   */  unsigned bmSetFence( struct intel_context * ); +unsigned bmSetFenceLock( struct intel_context * );  unsigned bmLockAndFence( struct intel_context *intel );  int bmTestFence( struct intel_context *, unsigned fence );  void bmFinishFence( struct intel_context *, unsigned fence ); +void bmFinishFenceLock( struct intel_context *, unsigned fence );  void bm_fake_NotifyContendedLockTake( struct intel_context * ); diff --git a/src/mesa/drivers/dri/i965/bufmgr_fake.c b/src/mesa/drivers/dri/i965/bufmgr_fake.c index ed88ab3797..205dc722c0 100644 --- a/src/mesa/drivers/dri/i965/bufmgr_fake.c +++ b/src/mesa/drivers/dri/i965/bufmgr_fake.c @@ -338,7 +338,6 @@ static int evict_mru( struct intel_context *intel, GLuint *pool )  } -  static int check_fenced( struct intel_context *intel )  {     struct bufmgr *bm = intel->bm; @@ -1328,11 +1327,19 @@ unsigned bmSetFence( struct intel_context *intel )     return intel->bm->last_fence;  } +unsigned bmSetFenceLock( struct intel_context *intel ) +{ +  LOCK(intel->bm); +  bmSetFence(intel); +  UNLOCK(intel->bm); +}  unsigned bmLockAndFence( struct intel_context *intel )  {     if (intel->bm->need_fence) {        LOCK_HARDWARE(intel); +      LOCK(intel->bm);        bmSetFence(intel); +      UNLOCK(intel->bm);        UNLOCK_HARDWARE(intel);     } @@ -1350,7 +1357,12 @@ void bmFinishFence( struct intel_context *intel, unsigned fence )     check_fenced(intel);  } - +void bmFinishFenceLock( struct intel_context *intel, unsigned fence ) +{ +   LOCK(intel->bm); +   bmFinishFence(intel, fence); +   UNLOCK(intel->bm); +}  /* Specifically ignore texture memory sharing. diff --git a/src/mesa/drivers/dri/i965/intel_blit.c b/src/mesa/drivers/dri/i965/intel_blit.c index c8c5bf93c9..173d1d5b6c 100644 --- a/src/mesa/drivers/dri/i965/intel_blit.c +++ b/src/mesa/drivers/dri/i965/intel_blit.c @@ -66,7 +66,7 @@ void intelCopyBuffer( const __DRIdrawablePrivate *dPriv,     intelFlush( &intel->ctx ); -   bmFinishFence(intel, intel->last_swap_fence); +   bmFinishFenceLock(intel, intel->last_swap_fence);     /* The LOCK_HARDWARE is required for the cliprects.  Buffer offsets      * should work regardless. @@ -155,7 +155,7 @@ void intelCopyBuffer( const __DRIdrawablePrivate *dPriv,     intel_batchbuffer_flush( intel->batch );     intel->second_last_swap_fence = intel->last_swap_fence; -   intel->last_swap_fence = bmSetFence( intel ); +   intel->last_swap_fence = bmSetFenceLock( intel );     UNLOCK_HARDWARE( intel );     if (!rect) | 
