diff options
Diffstat (limited to 'src/mesa/drivers/dri/intel')
29 files changed, 281 insertions, 1767 deletions
| diff --git a/src/mesa/drivers/dri/intel/intel_batchbuffer.c b/src/mesa/drivers/dri/intel/intel_batchbuffer.c index ca6e2fa5b1..f18fb91a88 100644 --- a/src/mesa/drivers/dri/intel/intel_batchbuffer.c +++ b/src/mesa/drivers/dri/intel/intel_batchbuffer.c @@ -80,7 +80,7 @@ intel_batchbuffer_reset(struct intel_batchbuffer *batch)        batch->buf = NULL;     } -   if (!batch->buffer && intel->ttm == GL_TRUE) +   if (!batch->buffer)        batch->buffer = malloc (intel->maxBatchSize);     batch->buf = dri_bo_alloc(intel->bufmgr, "batchbuffer", @@ -94,7 +94,6 @@ intel_batchbuffer_reset(struct intel_batchbuffer *batch)     batch->size = intel->maxBatchSize;     batch->ptr = batch->map;     batch->dirty_state = ~0; -   batch->cliprect_mode = IGNORE_CLIPRECTS;  }  struct intel_batchbuffer * @@ -129,13 +128,10 @@ intel_batchbuffer_free(struct intel_batchbuffer *batch)  /* TODO: Push this whole function into bufmgr.   */  static void -do_flush_locked(struct intel_batchbuffer *batch, -		GLuint used, GLboolean allow_unlock) +do_flush_locked(struct intel_batchbuffer *batch, GLuint used)  {     struct intel_context *intel = batch->intel;     int ret = 0; -   unsigned int num_cliprects = 0; -   struct drm_clip_rect *cliprects = NULL;     int x_off = 0, y_off = 0;     if (batch->buffer) @@ -146,31 +142,7 @@ do_flush_locked(struct intel_batchbuffer *batch,     batch->map = NULL;     batch->ptr = NULL; - -   if (batch->cliprect_mode == LOOP_CLIPRECTS) { -      intel_get_cliprects(intel, &cliprects, &num_cliprects, &x_off, &y_off); -   } -   /* Dispatch the batchbuffer, if it has some effect (nonzero cliprects). -    * Can't short-circuit like this once we have hardware contexts, but we -    * should always be in DRI2 mode by then anyway. -    */ -   if ((batch->cliprect_mode != LOOP_CLIPRECTS || -	num_cliprects != 0) && !intel->no_hw) { -      dri_bo_exec(batch->buf, used, cliprects, num_cliprects, -		  (x_off & 0xffff) | (y_off << 16)); -   } - -   if (batch->cliprect_mode == LOOP_CLIPRECTS && num_cliprects == 0) { -      if (allow_unlock) { -	 /* If we are not doing any actual user-visible rendering, -	  * do a sched_yield to keep the app from pegging the cpu while -	  * achieving nothing. -	  */ -         UNLOCK_HARDWARE(intel); -         sched_yield(); -         LOCK_HARDWARE(intel); -      } -   } +   dri_bo_exec(batch->buf, used, NULL, 0, (x_off & 0xffff) | (y_off << 16));     if (INTEL_DEBUG & DEBUG_BATCH) {        dri_bo_map(batch->buf, GL_FALSE); @@ -183,7 +155,6 @@ do_flush_locked(struct intel_batchbuffer *batch,     }     if (ret != 0) { -      UNLOCK_HARDWARE(intel);        exit(1);     }     intel->vtbl.new_batch(intel); @@ -196,15 +167,14 @@ _intel_batchbuffer_flush(struct intel_batchbuffer *batch, const char *file,     struct intel_context *intel = batch->intel;     GLuint used = batch->ptr - batch->map; -   if (intel->first_post_swapbuffers_batch == NULL) { +   if (!intel->using_dri2_swapbuffers && +       intel->first_post_swapbuffers_batch == NULL) {        intel->first_post_swapbuffers_batch = intel->batch->buf;        drm_intel_bo_reference(intel->first_post_swapbuffers_batch);     } -   if (used == 0) { -      batch->cliprect_mode = IGNORE_CLIPRECTS; +   if (used == 0)        return; -   }     if (INTEL_DEBUG & DEBUG_BATCH)        fprintf(stderr, "%s:%d: Batchbuffer flush with %db used\n", file, line, @@ -212,7 +182,7 @@ _intel_batchbuffer_flush(struct intel_batchbuffer *batch, const char *file,     batch->reserved_space = 0;     /* Emit a flush if the bufmgr doesn't do it for us. */ -   if (intel->always_flush_cache || !intel->ttm) { +   if (intel->always_flush_cache) {        intel_batchbuffer_emit_mi_flush(batch);        used = batch->ptr - batch->map;     } @@ -244,14 +214,15 @@ _intel_batchbuffer_flush(struct intel_batchbuffer *batch, const char *file,     if (intel->vtbl.finish_batch)        intel->vtbl.finish_batch(intel); +   /* Check that we didn't just wrap our batchbuffer at a bad time. */ +   assert(!intel->no_batch_wrap); +     batch->reserved_space = BATCH_RESERVED;     /* TODO: Just pass the relocation list and dma buffer up to the      * kernel.      */ -   LOCK_HARDWARE(intel); -   do_flush_locked(batch, used, GL_FALSE); -   UNLOCK_HARDWARE(intel); +   do_flush_locked(batch, used);     if (INTEL_DEBUG & DEBUG_SYNC) {        fprintf(stderr, "waiting for idle\n"); @@ -293,11 +264,10 @@ intel_batchbuffer_emit_reloc(struct intel_batchbuffer *batch,  void  intel_batchbuffer_data(struct intel_batchbuffer *batch, -                       const void *data, GLuint bytes, -		       enum cliprect_mode cliprect_mode) +                       const void *data, GLuint bytes)  {     assert((bytes & 3) == 0); -   intel_batchbuffer_require_space(batch, bytes, cliprect_mode); +   intel_batchbuffer_require_space(batch, bytes);     __memcpy(batch->ptr, data, bytes);     batch->ptr += bytes;  } @@ -314,7 +284,7 @@ intel_batchbuffer_emit_mi_flush(struct intel_batchbuffer *batch)     struct intel_context *intel = batch->intel;     if (intel->gen >= 4) { -      BEGIN_BATCH(4, IGNORE_CLIPRECTS); +      BEGIN_BATCH(4);        OUT_BATCH(_3DSTATE_PIPE_CONTROL |  		PIPE_CONTROL_INSTRUCTION_FLUSH |  		PIPE_CONTROL_WRITE_FLUSH | @@ -324,7 +294,7 @@ intel_batchbuffer_emit_mi_flush(struct intel_batchbuffer *batch)        OUT_BATCH(0); /* write data */        ADVANCE_BATCH();     } else { -      BEGIN_BATCH(1, IGNORE_CLIPRECTS); +      BEGIN_BATCH(1);        OUT_BATCH(MI_FLUSH);        ADVANCE_BATCH();     } diff --git a/src/mesa/drivers/dri/intel/intel_batchbuffer.h b/src/mesa/drivers/dri/intel/intel_batchbuffer.h index d4a94454dd..b052b724d8 100644 --- a/src/mesa/drivers/dri/intel/intel_batchbuffer.h +++ b/src/mesa/drivers/dri/intel/intel_batchbuffer.h @@ -10,35 +10,6 @@  #define BATCH_SZ 16384  #define BATCH_RESERVED 16 -enum cliprect_mode { -   /** -    * Batchbuffer contents may be looped over per cliprect, but do not -    * require it. -    */ -   IGNORE_CLIPRECTS, -   /** -    * Batchbuffer contents require looping over per cliprect at batch submit -    * time. -    * -    * This will be upgraded to NO_LOOP_CLIPRECTS when there's a single -    * constant cliprect, as in DRI2 or FBO rendering. -    */ -   LOOP_CLIPRECTS, -   /** -    * Batchbuffer contents contain drawing that should not be executed multiple -    * times. -    */ -   NO_LOOP_CLIPRECTS, -   /** -    * Batchbuffer contents contain drawing that already handles cliprects, such -    * as 2D drawing to front/back/depth that doesn't respect DRAWING_RECTANGLE. -    * -    * Equivalent behavior to NO_LOOP_CLIPRECTS, but may not persist in batch -    * outside of LOCK/UNLOCK.  This is upgraded to just NO_LOOP_CLIPRECTS when -    * there's a constant cliprect, as in DRI2 or FBO rendering. -    */ -   REFERENCES_CLIPRECTS -};  struct intel_batchbuffer  { @@ -51,8 +22,6 @@ struct intel_batchbuffer     GLubyte *map;     GLubyte *ptr; -   enum cliprect_mode cliprect_mode; -     GLuint size;     /** Tracking of BEGIN_BATCH()/OUT_BATCH()/ADVANCE_BATCH() debugging */ @@ -85,8 +54,7 @@ void intel_batchbuffer_reset(struct intel_batchbuffer *batch);   * intel_buffer_dword() calls.   */  void intel_batchbuffer_data(struct intel_batchbuffer *batch, -                            const void *data, GLuint bytes, -			    enum cliprect_mode cliprect_mode); +                            const void *data, GLuint bytes);  void intel_batchbuffer_release_space(struct intel_batchbuffer *batch,                                       GLuint bytes); @@ -121,36 +89,19 @@ intel_batchbuffer_emit_dword(struct intel_batchbuffer *batch, GLuint dword)  static INLINE void  intel_batchbuffer_require_space(struct intel_batchbuffer *batch, -                                GLuint sz, -				enum cliprect_mode cliprect_mode) +                                GLuint sz)  {     assert(sz < batch->size - 8);     if (intel_batchbuffer_space(batch) < sz)        intel_batchbuffer_flush(batch); - -   if ((cliprect_mode == LOOP_CLIPRECTS || -	cliprect_mode == REFERENCES_CLIPRECTS) && -       batch->intel->constant_cliprect) -      cliprect_mode = NO_LOOP_CLIPRECTS; - -   if (cliprect_mode != IGNORE_CLIPRECTS) { -      if (batch->cliprect_mode == IGNORE_CLIPRECTS) { -	 batch->cliprect_mode = cliprect_mode; -      } else { -	 if (batch->cliprect_mode != cliprect_mode) { -	    intel_batchbuffer_flush(batch); -	    batch->cliprect_mode = cliprect_mode; -	 } -      } -   }  }  /* Here are the crusty old macros, to be removed:   */  #define BATCH_LOCALS -#define BEGIN_BATCH(n, cliprect_mode) do {				\ -   intel_batchbuffer_require_space(intel->batch, (n)*4, cliprect_mode); \ +#define BEGIN_BATCH(n) do {				\ +   intel_batchbuffer_require_space(intel->batch, (n)*4); \     assert(intel->batch->emit.start_ptr == NULL);			\     intel->batch->emit.total = (n) * 4;					\     intel->batch->emit.start_ptr = intel->batch->ptr;			\ diff --git a/src/mesa/drivers/dri/intel/intel_blit.c b/src/mesa/drivers/dri/intel/intel_blit.c index 5b94d05966..72b6e1acb9 100644 --- a/src/mesa/drivers/dri/intel/intel_blit.c +++ b/src/mesa/drivers/dri/intel/intel_blit.c @@ -41,137 +41,6 @@  #define FILE_DEBUG_FLAG DEBUG_BLIT -/** - * Copy the back color buffer to the front color buffer.  - * Used for SwapBuffers(). - */ -void -intelCopyBuffer(const __DRIdrawablePrivate * dPriv, -                const drm_clip_rect_t * rect) -{ - -   struct intel_context *intel; -   const intelScreenPrivate *intelScreen; - -   DBG("%s\n", __FUNCTION__); - -   assert(dPriv); - -   intel = intelScreenContext(dPriv->driScreenPriv->private); -   if (!intel) -      return; - -   intelScreen = intel->intelScreen; - -   /* The LOCK_HARDWARE is required for the cliprects.  Buffer offsets -    * should work regardless. -    */ -   LOCK_HARDWARE(intel); - -   if (dPriv && dPriv->numClipRects) { -      struct intel_framebuffer *intel_fb = dPriv->driverPrivate; -      struct intel_region *src, *dst; -      int nbox = dPriv->numClipRects; -      drm_clip_rect_t *pbox = dPriv->pClipRects; -      int cpp; -      int src_pitch, dst_pitch; -      unsigned short src_x, src_y; -      int BR13, CMD; -      int i; -      dri_bo *aper_array[3]; - -      src = intel_get_rb_region(&intel_fb->Base, BUFFER_BACK_LEFT); -      dst = intel_get_rb_region(&intel_fb->Base, BUFFER_FRONT_LEFT); - -      src_pitch = src->pitch * src->cpp; -      dst_pitch = dst->pitch * dst->cpp; - -      cpp = src->cpp; - -      ASSERT(intel_fb); -      ASSERT(intel_fb->Base.Name == 0);    /* Not a user-created FBO */ -      ASSERT(src); -      ASSERT(dst); -      ASSERT(src->cpp == dst->cpp); - -      if (cpp == 2) { -	 BR13 = (0xCC << 16) | BR13_565; -	 CMD = XY_SRC_COPY_BLT_CMD; -      } -      else { -	 BR13 = (0xCC << 16) | BR13_8888; -	 CMD = XY_SRC_COPY_BLT_CMD | XY_BLT_WRITE_ALPHA | XY_BLT_WRITE_RGB; -      } - -      assert(src->tiling != I915_TILING_Y); -      assert(dst->tiling != I915_TILING_Y); -#ifndef I915 -      if (src->tiling != I915_TILING_NONE) { -	 CMD |= XY_SRC_TILED; -	 src_pitch /= 4; -      } -      if (dst->tiling != I915_TILING_NONE) { -	 CMD |= XY_DST_TILED; -	 dst_pitch /= 4; -      } -#endif -      /* do space/cliprects check before going any further */ -      intel_batchbuffer_require_space(intel->batch, 8 * 4, -				      REFERENCES_CLIPRECTS); -   again: -      aper_array[0] = intel->batch->buf; -      aper_array[1] = dst->buffer; -      aper_array[2] = src->buffer; - -      if (dri_bufmgr_check_aperture_space(aper_array, 3) != 0) { -	intel_batchbuffer_flush(intel->batch); -	goto again; -      } - -      for (i = 0; i < nbox; i++, pbox++) { -	 drm_clip_rect_t box = *pbox; - -	 if (rect) { -	    if (!intel_intersect_cliprects(&box, &box, rect)) -	       continue; -	 } - -	 if (box.x1 >= box.x2 || -	     box.y1 >= box.y2) -	    continue; - -	 assert(box.x1 < box.x2); -	 assert(box.y1 < box.y2); -	 src_x = box.x1 - dPriv->x + dPriv->backX; -	 src_y = box.y1 - dPriv->y + dPriv->backY; - -	 BEGIN_BATCH(8, REFERENCES_CLIPRECTS); -	 OUT_BATCH(CMD); -	 OUT_BATCH(BR13 | dst_pitch); -	 OUT_BATCH((box.y1 << 16) | box.x1); -	 OUT_BATCH((box.y2 << 16) | box.x2); - -	 OUT_RELOC(dst->buffer, -		   I915_GEM_DOMAIN_RENDER, I915_GEM_DOMAIN_RENDER, -		   0); -	 OUT_BATCH((src_y << 16) | src_x); -	 OUT_BATCH(src_pitch); -	 OUT_RELOC(src->buffer, -		   I915_GEM_DOMAIN_RENDER, 0, -		   0); -	 ADVANCE_BATCH(); -      } - -      /* Flush the rendering and the batch so that the results all land on the -       * screen in a timely fashion. -       */ -      intel_batchbuffer_emit_mi_flush(intel->batch); -      intel_batchbuffer_flush(intel->batch); -   } - -   UNLOCK_HARDWARE(intel); -} -  static GLuint translate_raster_op(GLenum logicop)  {     switch(logicop) { @@ -247,7 +116,6 @@ intelEmitCopyBlit(struct intel_context *intel,     } while (pass < 2);     if (pass >= 2) { -       LOCK_HARDWARE(intel);         dri_bo_map(dst_buffer, GL_TRUE);         dri_bo_map(src_buffer, GL_FALSE);         _mesa_copy_rect((GLubyte *)dst_buffer->virtual + dst_offset, @@ -261,12 +129,11 @@ intelEmitCopyBlit(struct intel_context *intel,         dri_bo_unmap(src_buffer);         dri_bo_unmap(dst_buffer); -       UNLOCK_HARDWARE(intel);         return GL_TRUE;     } -   intel_batchbuffer_require_space(intel->batch, 8 * 4, NO_LOOP_CLIPRECTS); +   intel_batchbuffer_require_space(intel->batch, 8 * 4);     DBG("%s src:buf(%p)/%d+%d %d,%d dst:buf(%p)/%d+%d %d,%d sz:%dx%d\n",         __FUNCTION__,         src_buffer, src_pitch, src_offset, src_x, src_y, @@ -311,7 +178,7 @@ intelEmitCopyBlit(struct intel_context *intel,     assert(dst_x < dst_x2);     assert(dst_y < dst_y2); -   BEGIN_BATCH(8, NO_LOOP_CLIPRECTS); +   BEGIN_BATCH(8);     OUT_BATCH(CMD);     OUT_BATCH(BR13 | (uint16_t)dst_pitch);     OUT_BATCH((dst_y << 16) | dst_x); @@ -369,8 +236,6 @@ intelClearWithBlit(GLcontext *ctx, GLbitfield mask)        skipBuffers = BUFFER_BIT_STENCIL;     } -   LOCK_HARDWARE(intel); -     intel_get_cliprects(intel, &cliprects, &num_cliprects, &x_off, &y_off);     if (num_cliprects) {        GLint cx, cy, cw, ch; @@ -498,10 +363,11 @@ intelClearWithBlit(GLcontext *ctx, GLbitfield mask)  		  switch (irb->Base.Format) {  		  case MESA_FORMAT_ARGB8888:  		  case MESA_FORMAT_XRGB8888: -		     clearVal = intel->ClearColor8888; +		     clearVal = PACK_COLOR_8888(clear[3], clear[0], +						clear[1], clear[2]);  		     break;  		  case MESA_FORMAT_RGB565: -		     clearVal = intel->ClearColor565; +		     clearVal = PACK_COLOR_565(clear[0], clear[1], clear[2]);  		     break;  		  case MESA_FORMAT_ARGB4444:  		     clearVal = PACK_COLOR_4444(clear[3], clear[0], @@ -526,7 +392,7 @@ intelClearWithBlit(GLcontext *ctx, GLbitfield mask)                 assert(x1 < x2);                 assert(y1 < y2); -               BEGIN_BATCH(6, REFERENCES_CLIPRECTS); +               BEGIN_BATCH(6);                 OUT_BATCH(CMD);                 OUT_BATCH(BR13);                 OUT_BATCH((y1 << 16) | x1); @@ -541,8 +407,6 @@ intelClearWithBlit(GLcontext *ctx, GLbitfield mask)           }        }     } - -   UNLOCK_HARDWARE(intel);  }  GLboolean @@ -584,8 +448,7 @@ intelEmitImmediateColorExpandBlit(struct intel_context *intel,     intel_batchbuffer_require_space( intel->batch,  				    (8 * 4) +  				    (3 * 4) + -				    dwords * 4, -				    REFERENCES_CLIPRECTS ); +				    dwords * 4 );     opcode = XY_SETUP_BLT_CMD;     if (cpp == 4) @@ -607,7 +470,7 @@ intelEmitImmediateColorExpandBlit(struct intel_context *intel,     if (dst_tiling != I915_TILING_NONE)        blit_cmd |= XY_DST_TILED; -   BEGIN_BATCH(8 + 3, REFERENCES_CLIPRECTS); +   BEGIN_BATCH(8 + 3);     OUT_BATCH(opcode);     OUT_BATCH(br13);     OUT_BATCH((0 << 16) | 0); /* clip x1, y1 */ @@ -626,8 +489,7 @@ intelEmitImmediateColorExpandBlit(struct intel_context *intel,     intel_batchbuffer_data( intel->batch,  			   src_bits, -			   dwords * 4, -			   REFERENCES_CLIPRECTS ); +			   dwords * 4 );     intel_batchbuffer_emit_mi_flush(intel->batch); diff --git a/src/mesa/drivers/dri/intel/intel_blit.h b/src/mesa/drivers/dri/intel/intel_blit.h index 240cb7cd1b..eb66fe0481 100644 --- a/src/mesa/drivers/dri/intel/intel_blit.h +++ b/src/mesa/drivers/dri/intel/intel_blit.h @@ -30,7 +30,7 @@  #include "intel_context.h" -extern void intelCopyBuffer(const __DRIdrawablePrivate * dpriv, +extern void intelCopyBuffer(const __DRIdrawable * dpriv,                              const drm_clip_rect_t * rect);  extern void intelClearWithBlit(GLcontext * ctx, GLbitfield mask); diff --git a/src/mesa/drivers/dri/intel/intel_buffers.c b/src/mesa/drivers/dri/intel/intel_buffers.c index 78ea6ebb6d..de75257349 100644 --- a/src/mesa/drivers/dri/intel/intel_buffers.c +++ b/src/mesa/drivers/dri/intel/intel_buffers.c @@ -100,33 +100,15 @@ intel_get_cliprects(struct intel_context *intel,  		    unsigned int *num_cliprects,  		    int *x_off, int *y_off)  { -   __DRIdrawablePrivate *dPriv = intel->driDrawable; +   intel->fboRect.x1 = 0; +   intel->fboRect.y1 = 0; +   intel->fboRect.x2 = intel->ctx.DrawBuffer->Width; +   intel->fboRect.y2 = intel->ctx.DrawBuffer->Height; -   if (intel->constant_cliprect) { -      /* FBO or DRI2 rendering, which can just use the fb's size. */ -      intel->fboRect.x1 = 0; -      intel->fboRect.y1 = 0; -      intel->fboRect.x2 = intel->ctx.DrawBuffer->Width; -      intel->fboRect.y2 = intel->ctx.DrawBuffer->Height; - -      *cliprects = &intel->fboRect; -      *num_cliprects = 1; -      *x_off = 0; -      *y_off = 0; -   } else if (intel->front_cliprects || dPriv->numBackClipRects == 0) { -      /* use the front clip rects */ -      *cliprects = dPriv->pClipRects; -      *num_cliprects = dPriv->numClipRects; -      *x_off = dPriv->x; -      *y_off = dPriv->y; -   } -   else { -      /* use the back clip rects */ -      *num_cliprects = dPriv->numBackClipRects; -      *cliprects = dPriv->pBackClipRects; -      *x_off = dPriv->backX; -      *y_off = dPriv->backY; -   } +   *cliprects = &intel->fboRect; +   *num_cliprects = 1; +   *x_off = 0; +   *y_off = 0;  } @@ -200,7 +182,6 @@ intel_draw_buffer(GLcontext * ctx, struct gl_framebuffer *fb)         || (fb->_NumColorDrawBuffers == 0)) {        /* writing to 0  */        colorRegions[0] = NULL; -      intel->constant_cliprect = GL_TRUE;     }     else if (fb->_NumColorDrawBuffers > 1) {         int i; @@ -210,34 +191,23 @@ intel_draw_buffer(GLcontext * ctx, struct gl_framebuffer *fb)             irb = intel_renderbuffer(fb->_ColorDrawBuffers[i]);             colorRegions[i] = irb ? irb->region : NULL;         } -       intel->constant_cliprect = GL_TRUE;     }     else {        /* Get the intel_renderbuffer for the single colorbuffer we're drawing -       * into, and set up cliprects if it's a DRI1 window front buffer. +       * into.         */        if (fb->Name == 0) { -	 intel->constant_cliprect = intel->driScreen->dri2.enabled;  	 /* drawing to window system buffer */ -	 if (fb->_ColorDrawBufferIndexes[0] == BUFFER_FRONT_LEFT) { -	    if (!intel->constant_cliprect && !intel->front_cliprects) -	       intel_batchbuffer_flush(intel->batch); -	    intel->front_cliprects = GL_TRUE; +	 if (fb->_ColorDrawBufferIndexes[0] == BUFFER_FRONT_LEFT)  	    colorRegions[0] = intel_get_rb_region(fb, BUFFER_FRONT_LEFT); -	 } -	 else { -	    if (!intel->constant_cliprect && intel->front_cliprects) -	       intel_batchbuffer_flush(intel->batch); -	    intel->front_cliprects = GL_FALSE; +	 else  	    colorRegions[0] = intel_get_rb_region(fb, BUFFER_BACK_LEFT); -	 }        }        else {  	 /* drawing to user-created FBO */  	 struct intel_renderbuffer *irb;  	 irb = intel_renderbuffer(fb->_ColorDrawBuffers[0]);  	 colorRegions[0] = (irb && irb->region) ? irb->region : NULL; -	 intel->constant_cliprect = GL_TRUE;        }     } @@ -289,6 +259,12 @@ intel_draw_buffer(GLcontext * ctx, struct gl_framebuffer *fb)        FALLBACK(intel, INTEL_FALLBACK_STENCIL_BUFFER, GL_FALSE);     } +   /* If we have a (packed) stencil buffer attached but no depth buffer, +    * we still need to set up the shared depth/stencil state so we can use it. +    */ +   if (depthRegion == NULL && irbStencil && irbStencil->region) +      depthRegion = irbStencil->region; +     /*      * Update depth and stencil test state      */ diff --git a/src/mesa/drivers/dri/intel/intel_clear.c b/src/mesa/drivers/dri/intel/intel_clear.c index 583976ff89..ca78681538 100644 --- a/src/mesa/drivers/dri/intel/intel_clear.c +++ b/src/mesa/drivers/dri/intel/intel_clear.c @@ -65,7 +65,7 @@ static void  intelClear(GLcontext *ctx, GLbitfield mask)  {     struct intel_context *intel = intel_context(ctx); -   const GLuint colorMask = *((GLuint *) & ctx->Color.ColorMask); +   const GLuint colorMask = *((GLuint *) & ctx->Color.ColorMask[0]);     GLbitfield tri_mask = 0;     GLbitfield blit_mask = 0;     GLbitfield swrast_mask = 0; diff --git a/src/mesa/drivers/dri/intel/intel_context.c b/src/mesa/drivers/dri/intel/intel_context.c index 6275df322a..3896bfa091 100644 --- a/src/mesa/drivers/dri/intel/intel_context.c +++ b/src/mesa/drivers/dri/intel/intel_context.c @@ -54,10 +54,8 @@  #include "intel_decode.h"  #include "intel_bufmgr.h"  #include "intel_screen.h" -#include "intel_swapbuffers.h"  #include "drirenderbuffer.h" -#include "vblank.h"  #include "utils.h"  #include "xmlpool.h"            /* for symbolic values of enum-type options */ @@ -67,12 +65,10 @@ int INTEL_DEBUG = (0);  #endif -#define DRIVER_DATE                     "20091221 2009Q4" +#define DRIVER_DATE                     "20091221 DEVELOPMENT"  #define DRIVER_DATE_GEM                 "GEM " DRIVER_DATE -static void intel_flush(GLcontext *ctx, GLboolean needs_mi_flush); -  static const GLubyte *  intelGetString(GLcontext * ctx, GLenum name)  { @@ -175,9 +171,7 @@ intelGetString(GLcontext * ctx, GLenum name)           break;        } -      (void) driGetRendererString(buffer, chipset,  -				  (intel->ttm) ? DRIVER_DATE_GEM : DRIVER_DATE, -				  0); +      (void) driGetRendererString(buffer, chipset, DRIVER_DATE_GEM, 0);        return (GLubyte *) buffer;     default: @@ -194,10 +188,11 @@ intel_bits_per_pixel(const struct intel_renderbuffer *rb)  void  intel_update_renderbuffers(__DRIcontext *context, __DRIdrawable *drawable)  { -   struct intel_framebuffer *intel_fb = drawable->driverPrivate; +   struct gl_framebuffer *fb = drawable->driverPrivate;     struct intel_renderbuffer *rb;     struct intel_region *region, *depth_region;     struct intel_context *intel = context->driverPrivate; +   struct intel_renderbuffer *front_rb, *back_rb, *depth_rb, *stencil_rb;     __DRIbuffer *buffers = NULL;     __DRIscreen *screen;     int i, count; @@ -213,26 +208,25 @@ intel_update_renderbuffers(__DRIcontext *context, __DRIdrawable *drawable)     if (screen->dri2.loader         && (screen->dri2.loader->base.version > 2)         && (screen->dri2.loader->getBuffersWithFormat != NULL)) { -      struct intel_renderbuffer *depth_rb; -      struct intel_renderbuffer *stencil_rb; + +      front_rb = intel_get_renderbuffer(fb, BUFFER_FRONT_LEFT); +      back_rb = intel_get_renderbuffer(fb, BUFFER_BACK_LEFT); +      depth_rb = intel_get_renderbuffer(fb, BUFFER_DEPTH); +      stencil_rb = intel_get_renderbuffer(fb, BUFFER_STENCIL);        i = 0;        if ((intel->is_front_buffer_rendering ||  	   intel->is_front_buffer_reading || -	   !intel_fb->color_rb[1]) -	   && intel_fb->color_rb[0]) { +	   !back_rb) && front_rb) {  	 attachments[i++] = __DRI_BUFFER_FRONT_LEFT; -	 attachments[i++] = intel_bits_per_pixel(intel_fb->color_rb[0]); +	 attachments[i++] = intel_bits_per_pixel(front_rb);        } -      if (intel_fb->color_rb[1]) { +      if (back_rb) {  	 attachments[i++] = __DRI_BUFFER_BACK_LEFT; -	 attachments[i++] = intel_bits_per_pixel(intel_fb->color_rb[1]); +	 attachments[i++] = intel_bits_per_pixel(back_rb);        } -      depth_rb = intel_get_renderbuffer(&intel_fb->Base, BUFFER_DEPTH); -      stencil_rb = intel_get_renderbuffer(&intel_fb->Base, BUFFER_STENCIL); -        if ((depth_rb != NULL) && (stencil_rb != NULL)) {  	 attachments[i++] = __DRI_BUFFER_DEPTH_STENCIL;  	 attachments[i++] = intel_bits_per_pixel(depth_rb); @@ -253,13 +247,13 @@ intel_update_renderbuffers(__DRIcontext *context, __DRIdrawable *drawable)  						      drawable->loaderPrivate);     } else if (screen->dri2.loader) {        i = 0; -      if (intel_fb->color_rb[0]) +      if (intel_get_renderbuffer(fb, BUFFER_FRONT_LEFT))  	 attachments[i++] = __DRI_BUFFER_FRONT_LEFT; -      if (intel_fb->color_rb[1]) +      if (intel_get_renderbuffer(fb, BUFFER_BACK_LEFT))  	 attachments[i++] = __DRI_BUFFER_BACK_LEFT; -      if (intel_get_renderbuffer(&intel_fb->Base, BUFFER_DEPTH)) +      if (intel_get_renderbuffer(fb, BUFFER_DEPTH))  	 attachments[i++] = __DRI_BUFFER_DEPTH; -      if (intel_get_renderbuffer(&intel_fb->Base, BUFFER_STENCIL)) +      if (intel_get_renderbuffer(fb, BUFFER_STENCIL))  	 attachments[i++] = __DRI_BUFFER_STENCIL;        buffers = (*screen->dri2.loader->getBuffers)(drawable, @@ -292,32 +286,32 @@ intel_update_renderbuffers(__DRIcontext *context, __DRIdrawable *drawable)     for (i = 0; i < count; i++) {         switch (buffers[i].attachment) {         case __DRI_BUFFER_FRONT_LEFT: -	   rb = intel_fb->color_rb[0]; +	   rb = intel_get_renderbuffer(fb, BUFFER_FRONT_LEFT);  	   region_name = "dri2 front buffer";  	   break;         case __DRI_BUFFER_FAKE_FRONT_LEFT: -	   rb = intel_fb->color_rb[0]; +	   rb = intel_get_renderbuffer(fb, BUFFER_FRONT_LEFT);  	   region_name = "dri2 fake front buffer";  	   break;         case __DRI_BUFFER_BACK_LEFT: -	   rb = intel_fb->color_rb[1]; +	   rb = intel_get_renderbuffer(fb, BUFFER_BACK_LEFT);  	   region_name = "dri2 back buffer";  	   break;         case __DRI_BUFFER_DEPTH: -	   rb = intel_get_renderbuffer(&intel_fb->Base, BUFFER_DEPTH); +	   rb = intel_get_renderbuffer(fb, BUFFER_DEPTH);  	   region_name = "dri2 depth buffer";  	   break;         case __DRI_BUFFER_DEPTH_STENCIL: -	   rb = intel_get_renderbuffer(&intel_fb->Base, BUFFER_DEPTH); +	   rb = intel_get_renderbuffer(fb, BUFFER_DEPTH);  	   region_name = "dri2 depth / stencil buffer";  	   break;         case __DRI_BUFFER_STENCIL: -	   rb = intel_get_renderbuffer(&intel_fb->Base, BUFFER_STENCIL); +	   rb = intel_get_renderbuffer(fb, BUFFER_STENCIL);  	   region_name = "dri2 stencil buffer";  	   break; @@ -364,7 +358,7 @@ intel_update_renderbuffers(__DRIcontext *context, __DRIdrawable *drawable)         intel_region_release(®ion);         if (buffers[i].attachment == __DRI_BUFFER_DEPTH_STENCIL) { -	  rb = intel_get_renderbuffer(&intel_fb->Base, BUFFER_STENCIL); +	  rb = intel_get_renderbuffer(fb, BUFFER_STENCIL);  	  if (rb != NULL) {  	     struct intel_region *stencil_region = NULL; @@ -381,6 +375,7 @@ intel_update_renderbuffers(__DRIcontext *context, __DRIdrawable *drawable)         }     } +   drawable->validBuffers = GL_TRUE;     driUpdateFramebufferSize(&intel->ctx, drawable);  } @@ -392,9 +387,6 @@ intel_viewport(GLcontext *ctx, GLint x, GLint y, GLsizei w, GLsizei h)      void (*old_viewport)(GLcontext *ctx, GLint x, GLint y,  			 GLsizei w, GLsizei h); -    if (!driContext->driScreenPriv->dri2.enabled) -	return; -      if (!intel->meta.internal_viewport_call && ctx->DrawBuffer->Name == 0) {         /* If we're rendering to the fake front buffer, make sure all the pending  	* drawing has landed on the real front buffer.  Otherwise when we @@ -413,7 +405,6 @@ intel_viewport(GLcontext *ctx, GLint x, GLint y, GLsizei w, GLsizei h)      old_viewport = ctx->Driver.Viewport;      ctx->Driver.Viewport = NULL;      intel->driDrawable = driContext->driDrawablePriv; -    intelWindowMoved(intel);      intel_draw_buffer(ctx, intel->ctx.DrawBuffer);      ctx->Driver.Viewport = old_viewport;  } @@ -468,7 +459,7 @@ intelInvalidateState(GLcontext * ctx, GLuint new_state)        intel->vtbl.invalidate_state( intel, new_state );  } -static void +void  intel_flush(GLcontext *ctx, GLboolean needs_mi_flush)  {     struct intel_context *intel = intel_context(ctx); @@ -479,13 +470,6 @@ intel_flush(GLcontext *ctx, GLboolean needs_mi_flush)     if (intel->gen < 4)        INTEL_FIREVERTICES(intel); -   /* Emit a flush so that any frontbuffer rendering that might have occurred -    * lands onscreen in a timely manner, even if the X Server doesn't trigger -    * a flush for us. -    */ -   if (!intel->driScreen->dri2.enabled && needs_mi_flush) -      intel_batchbuffer_emit_mi_flush(intel->batch); -     if (intel->batch->map != intel->batch->ptr)        intel_batchbuffer_flush(intel->batch); @@ -537,7 +521,8 @@ intel_glFlush(GLcontext *ctx)      * and getting our hands on that doesn't seem worth it, so we just us the      * first batch we emitted after the last swap.      */ -   if (intel->first_post_swapbuffers_batch != NULL) { +   if (!intel->using_dri2_swapbuffers && +       intel->first_post_swapbuffers_batch != NULL) {        drm_intel_bo_wait_rendering(intel->first_post_swapbuffers_batch);        drm_intel_bo_unreference(intel->first_post_swapbuffers_batch);        intel->first_post_swapbuffers_batch = NULL; @@ -591,15 +576,15 @@ intelInitDriverFunctions(struct dd_function_table *functions)  GLboolean  intelInitContext(struct intel_context *intel,                   const __GLcontextModes * mesaVis, -                 __DRIcontextPrivate * driContextPriv, +                 __DRIcontext * driContextPriv,                   void *sharedContextPrivate,                   struct dd_function_table *functions)  {     GLcontext *ctx = &intel->ctx;     GLcontext *shareCtx = (GLcontext *) sharedContextPrivate; -   __DRIscreenPrivate *sPriv = driContextPriv->driScreenPriv; +   __DRIscreen *sPriv = driContextPriv->driScreenPriv;     intelScreenPrivate *intelScreen = (intelScreenPrivate *) sPriv->private; -   int fthrottle_mode; +   int bo_reuse_mode;     if (!_mesa_initialize_context(&intel->ctx, mesaVis, shareCtx,                                   functions, (void *) intel)) { @@ -610,20 +595,28 @@ intelInitContext(struct intel_context *intel,     driContextPriv->driverPrivate = intel;     intel->intelScreen = intelScreen;     intel->driScreen = sPriv; -   intel->sarea = intelScreen->sarea;     intel->driContext = driContextPriv; +   intel->driFd = sPriv->fd; -   if (IS_965(intel->intelScreen->deviceID)) +   if (IS_965(intel->intelScreen->deviceID)) {        intel->gen = 4; -   else if (IS_9XX(intel->intelScreen->deviceID)) +   } else if (IS_9XX(intel->intelScreen->deviceID)) {        intel->gen = 3; -   else +      if (IS_945(intel->intelScreen->deviceID)) { +	 intel->is_945 = GL_TRUE; +      } +   } else {        intel->gen = 2; +   } -   /* Dri stuff */ -   intel->hHWContext = driContextPriv->hHWContext; -   intel->driFd = sPriv->fd; -   intel->driHwLock = sPriv->lock; +   if (IS_IGDNG(intel->intelScreen->deviceID)) { +      intel->is_ironlake = GL_TRUE; +      intel->needs_ff_sync = GL_TRUE; +      intel->has_luminance_srgb = GL_TRUE; +   } else if (IS_G4X(intel->intelScreen->deviceID)) { +      intel->has_luminance_srgb = GL_TRUE; +      intel->is_g4x = GL_TRUE; +   }     driParseConfigFiles(&intel->optionCache, &intelScreen->optionCache,                         intel->driScreen->myNum, @@ -634,18 +627,14 @@ intelInitContext(struct intel_context *intel,        intel->maxBatchSize = BATCH_SZ;     intel->bufmgr = intelScreen->bufmgr; -   intel->ttm = intelScreen->ttm; -   if (intel->ttm) { -      int bo_reuse_mode; -      bo_reuse_mode = driQueryOptioni(&intel->optionCache, "bo_reuse"); -      switch (bo_reuse_mode) { -      case DRI_CONF_BO_REUSE_DISABLED: -	 break; -      case DRI_CONF_BO_REUSE_ALL: -	 intel_bufmgr_gem_enable_reuse(intel->bufmgr); -	 break; -      } +   bo_reuse_mode = driQueryOptioni(&intel->optionCache, "bo_reuse"); +   switch (bo_reuse_mode) { +   case DRI_CONF_BO_REUSE_DISABLED: +      break; +   case DRI_CONF_BO_REUSE_ALL: +      intel_bufmgr_gem_enable_reuse(intel->bufmgr); +      break;     }     /* This doesn't yet catch all non-conformant rendering, but it's a @@ -731,14 +720,6 @@ intelInitContext(struct intel_context *intel,     intel->RenderIndex = ~0; -   fthrottle_mode = driQueryOptioni(&intel->optionCache, "fthrottle_mode"); -   intel->irqsEmitted = 0; - -   intel->do_irqs = (intel->intelScreen->irq_active && -                     fthrottle_mode == DRI_CONF_FTHROTTLE_IRQS); - -   intel->do_usleeps = (fthrottle_mode == DRI_CONF_FTHROTTLE_USLEEPS); -     if (intel->gen >= 4 && !intel->intelScreen->irq_active) {        _mesa_printf("IRQs not active.  Exiting\n");        exit(1); @@ -750,9 +731,6 @@ intelInitContext(struct intel_context *intel,     if (INTEL_DEBUG & DEBUG_BUFMGR)        dri_bufmgr_set_debug(intel->bufmgr, GL_TRUE); -   if (!sPriv->dri2.enabled) -      intel_recreate_static_regions(intel); -     intel->batch = intel_batchbuffer_alloc(intel);     intel_fbo_init(intel); @@ -801,7 +779,7 @@ intelInitContext(struct intel_context *intel,  }  void -intelDestroyContext(__DRIcontextPrivate * driContextPriv) +intelDestroyContext(__DRIcontext * driContextPriv)  {     struct intel_context *intel =        (struct intel_context *) driContextPriv->driverPrivate; @@ -848,57 +826,6 @@ intelDestroyContext(__DRIcontextPrivate * driContextPriv)            */        } -      /* XXX In intelMakeCurrent() below, the context's static regions are  -       * referenced inside the frame buffer; it's listed as a hack, -       * with a comment of "XXX FBO temporary fix-ups!", but -       * as long as it's there, we should release the regions here. -       * The do/while loop around the block is used to allow the -       * "continue" statements inside the block to exit the block, -       * to avoid many layers of "if" constructs. -       */ -      do { -         __DRIdrawablePrivate * driDrawPriv = intel->driDrawable; -         struct intel_framebuffer *intel_fb; -         struct intel_renderbuffer *irbDepth, *irbStencil; -         if (!driDrawPriv) { -            /* We're already detached from the drawable; exit this block. */ -            continue; -         } -         intel_fb = (struct intel_framebuffer *) driDrawPriv->driverPrivate; -         if (!intel_fb) { -            /* The frame buffer is already gone; exit this block. */ -            continue; -         } -         irbDepth = intel_get_renderbuffer(&intel_fb->Base, BUFFER_DEPTH); -         irbStencil = intel_get_renderbuffer(&intel_fb->Base, BUFFER_STENCIL); - -         /* If the regions of the frame buffer still match the regions -          * of the context, release them.  If they've changed somehow, -          * leave them alone. -          */ -         if (intel_fb->color_rb[0] && intel_fb->color_rb[0]->region == intel->front_region) { -	    intel_renderbuffer_set_region(intel_fb->color_rb[0], NULL); -         } -         if (intel_fb->color_rb[1] && intel_fb->color_rb[1]->region == intel->back_region) { -	    intel_renderbuffer_set_region(intel_fb->color_rb[1], NULL); -         } - -         if (irbDepth && irbDepth->region == intel->depth_region) { -	    intel_renderbuffer_set_region(irbDepth, NULL); -         } -         /* Usually, the stencil buffer is the same as the depth buffer; -          * but they're handled separately in MakeCurrent, so we'll -          * handle them separately here. -          */ -         if (irbStencil && irbStencil->region == intel->depth_region) { -	    intel_renderbuffer_set_region(irbStencil, NULL); -         } -      } while (0); - -      intel_region_release(&intel->front_region); -      intel_region_release(&intel->back_region); -      intel_region_release(&intel->depth_region); -        driDestroyOptionCache(&intel->optionCache);        /* free the Mesa context */ @@ -910,7 +837,7 @@ intelDestroyContext(__DRIcontextPrivate * driContextPriv)  }  GLboolean -intelUnbindContext(__DRIcontextPrivate * driContextPriv) +intelUnbindContext(__DRIcontext * driContextPriv)  {     struct intel_context *intel =        (struct intel_context *) driContextPriv->driverPrivate; @@ -924,11 +851,10 @@ intelUnbindContext(__DRIcontextPrivate * driContextPriv)  }  GLboolean -intelMakeCurrent(__DRIcontextPrivate * driContextPriv, -                 __DRIdrawablePrivate * driDrawPriv, -                 __DRIdrawablePrivate * driReadPriv) +intelMakeCurrent(__DRIcontext * driContextPriv, +                 __DRIdrawable * driDrawPriv, +                 __DRIdrawable * driReadPriv)  { -   __DRIscreenPrivate *psp = driDrawPriv->driScreenPriv;     struct intel_context *intel;     GET_CURRENT_CONTEXT(curCtx); @@ -946,41 +872,12 @@ intelMakeCurrent(__DRIcontextPrivate * driContextPriv,     }     if (driContextPriv) { -      struct intel_framebuffer *intel_fb = -	 (struct intel_framebuffer *) driDrawPriv->driverPrivate; -      GLframebuffer *readFb = (GLframebuffer *) driReadPriv->driverPrivate; +      struct gl_framebuffer *fb = driDrawPriv->driverPrivate; +      struct gl_framebuffer *readFb = driReadPriv->driverPrivate; -      if (driContextPriv->driScreenPriv->dri2.enabled) {      -          intel_update_renderbuffers(driContextPriv, driDrawPriv); -          if (driDrawPriv != driReadPriv) -              intel_update_renderbuffers(driContextPriv, driReadPriv); -      } else { -          /* XXX FBO temporary fix-ups!  These are released in  -           * intelDextroyContext(), above.  Changes here should be -           * reflected there. -           */ -          /* if the renderbuffers don't have regions, init them from the context */ -         struct intel_renderbuffer *irbDepth -            = intel_get_renderbuffer(&intel_fb->Base, BUFFER_DEPTH); -         struct intel_renderbuffer *irbStencil -            = intel_get_renderbuffer(&intel_fb->Base, BUFFER_STENCIL); - -         if (intel_fb->color_rb[0]) { -	    intel_renderbuffer_set_region(intel_fb->color_rb[0], -					  intel->front_region); -         } -         if (intel_fb->color_rb[1]) { -	    intel_renderbuffer_set_region(intel_fb->color_rb[1], -					  intel->back_region); -         } - -         if (irbDepth) { -	    intel_renderbuffer_set_region(irbDepth, intel->depth_region); -         } -         if (irbStencil) { -	    intel_renderbuffer_set_region(irbStencil, intel->depth_region); -         } -      } +      intel_update_renderbuffers(driContextPriv, driDrawPriv); +      if (driDrawPriv != driReadPriv) +	 intel_update_renderbuffers(driContextPriv, driReadPriv);        /* set GLframebuffer size to match window, if needed */        driUpdateFramebufferSize(&intel->ctx, driDrawPriv); @@ -989,37 +886,10 @@ intelMakeCurrent(__DRIcontextPrivate * driContextPriv,  	 driUpdateFramebufferSize(&intel->ctx, driReadPriv);        } -      _mesa_make_current(&intel->ctx, &intel_fb->Base, readFb); - +      _mesa_make_current(&intel->ctx, fb, readFb);        intel->driReadDrawable = driReadPriv; - -      if (intel->driDrawable != driDrawPriv) { -         if (driDrawPriv->swap_interval == (unsigned)-1) { -            int i; - -            driDrawPriv->vblFlags = (intel->intelScreen->irq_active != 0) -               ? driGetDefaultVBlankFlags(&intel->optionCache) -               : VBLANK_FLAG_NO_IRQ; - -            /* Prevent error printf if one crtc is disabled, this will -             * be properly calculated in intelWindowMoved() next. -             */ -            driDrawPriv->vblFlags = intelFixupVblank(intel, driDrawPriv); - -            (*psp->systemTime->getUST) (&intel_fb->swap_ust); -            driDrawableInitVBlank(driDrawPriv); -            intel_fb->vbl_waited = driDrawPriv->vblSeq; - -            for (i = 0; i < 2; i++) { -               if (intel_fb->color_rb[i]) -                  intel_fb->color_rb[i]->vbl_pending = driDrawPriv->vblSeq; -            } -         } -         intel->driDrawable = driDrawPriv; -         intelWindowMoved(intel); -      } - -      intel_draw_buffer(&intel->ctx, &intel_fb->Base); +      intel->driDrawable = driDrawPriv; +      intel_draw_buffer(&intel->ctx, fb);     }     else {        _mesa_make_current(NULL, NULL, NULL); @@ -1027,143 +897,3 @@ intelMakeCurrent(__DRIcontextPrivate * driContextPriv,     return GL_TRUE;  } - -static void -intelContendedLock(struct intel_context *intel, GLuint flags) -{ -   __DRIdrawablePrivate *dPriv = intel->driDrawable; -   __DRIscreenPrivate *sPriv = intel->driScreen; -   volatile drm_i915_sarea_t *sarea = intel->sarea; -   int me = intel->hHWContext; - -   drmGetLock(intel->driFd, intel->hHWContext, flags); - -   if (INTEL_DEBUG & DEBUG_LOCK) -      _mesa_printf("%s - got contended lock\n", __progname); - -   /* If the window moved, may need to set a new cliprect now. -    * -    * NOTE: This releases and regains the hw lock, so all state -    * checking must be done *after* this call: -    */ -   if (dPriv) -       DRI_VALIDATE_DRAWABLE_INFO(sPriv, dPriv); - -   if (sarea && sarea->ctxOwner != me) { -      if (INTEL_DEBUG & DEBUG_BUFMGR) { -	 fprintf(stderr, "Lost Context: sarea->ctxOwner %x me %x\n", -		 sarea->ctxOwner, me); -      } -      sarea->ctxOwner = me; -   } - -   /* If the last consumer of the texture memory wasn't us, notify the fake -    * bufmgr and record the new owner.  We should have the memory shared -    * between contexts of a single fake bufmgr, but this will at least make -    * things correct for now. -    */ -   if (!intel->ttm && sarea->texAge != intel->hHWContext) { -      sarea->texAge = intel->hHWContext; -      intel_bufmgr_fake_contended_lock_take(intel->bufmgr); -      if (INTEL_DEBUG & DEBUG_BATCH) -	 intel_decode_context_reset(); -      if (INTEL_DEBUG & DEBUG_BUFMGR) -	 fprintf(stderr, "Lost Textures: sarea->texAge %x hw context %x\n", -		 sarea->ctxOwner, intel->hHWContext); -   } - -   /* Drawable changed? -    */ -   if (dPriv && intel->lastStamp != dPriv->lastStamp) { -       intelWindowMoved(intel); -       intel->lastStamp = dPriv->lastStamp; -   } -} - - -_glthread_DECLARE_STATIC_MUTEX(lockMutex); - -/* Lock the hardware and validate our state.   - */ -void LOCK_HARDWARE( struct intel_context *intel ) -{ -    __DRIdrawable *dPriv = intel->driDrawable; -    __DRIscreen *sPriv = intel->driScreen; -    char __ret = 0; -    struct intel_framebuffer *intel_fb = NULL; -    struct intel_renderbuffer *intel_rb = NULL; - -    intel->locked++; -    if (intel->locked >= 2) -       return; - -    if (!sPriv->dri2.enabled) -       _glthread_LOCK_MUTEX(lockMutex); - -    if (intel->driDrawable) { -       intel_fb = intel->driDrawable->driverPrivate; - -       if (intel_fb) -	  intel_rb = -	     intel_get_renderbuffer(&intel_fb->Base, -				    intel_fb->Base._ColorDrawBufferIndexes[0]); -    } - -    if (intel_rb && dPriv->vblFlags && -	!(dPriv->vblFlags & VBLANK_FLAG_NO_IRQ) && -	(intel_fb->vbl_waited - intel_rb->vbl_pending) > (1<<23)) { -	drmVBlank vbl; - -	vbl.request.type = DRM_VBLANK_ABSOLUTE; - -	if ( dPriv->vblFlags & VBLANK_FLAG_SECONDARY ) { -	    vbl.request.type |= DRM_VBLANK_SECONDARY; -	} - -	vbl.request.sequence = intel_rb->vbl_pending; -	drmWaitVBlank(intel->driFd, &vbl); -	intel_fb->vbl_waited = vbl.reply.sequence; -    } - -    if (!sPriv->dri2.enabled) { -	DRM_CAS(intel->driHwLock, intel->hHWContext, -		(DRM_LOCK_HELD|intel->hHWContext), __ret); - -	if (__ret) -	    intelContendedLock( intel, 0 ); -    } - - -    if (INTEL_DEBUG & DEBUG_LOCK) -      _mesa_printf("%s - locked\n", __progname); -} - - -/* Unlock the hardware using the global current context  - */ -void UNLOCK_HARDWARE( struct intel_context *intel ) -{ -    __DRIscreen *sPriv = intel->driScreen; - -   intel->locked--; -   if (intel->locked > 0) -      return; - -   assert(intel->locked == 0); - -   if (!sPriv->dri2.enabled) { -      DRM_UNLOCK(intel->driFd, intel->driHwLock, intel->hHWContext); -      _glthread_UNLOCK_MUTEX(lockMutex); -   } - -   if (INTEL_DEBUG & DEBUG_LOCK) -      _mesa_printf("%s - unlocked\n", __progname); - -   /** -    * Nothing should be left in batch outside of LOCK/UNLOCK which references -    * cliprects. -    */ -   if (intel->batch->cliprect_mode == REFERENCES_CLIPRECTS) -      intel_batchbuffer_flush(intel->batch); -} - diff --git a/src/mesa/drivers/dri/intel/intel_context.h b/src/mesa/drivers/dri/intel/intel_context.h index 1afec09a34..57c3391130 100644 --- a/src/mesa/drivers/dri/intel/intel_context.h +++ b/src/mesa/drivers/dri/intel/intel_context.h @@ -107,7 +107,6 @@ struct intel_context        void (*finish_batch) (struct intel_context * intel);        void (*new_batch) (struct intel_context * intel);        void (*emit_invarient_state) (struct intel_context * intel); -      void (*note_fence) (struct intel_context *intel, GLuint fence);        void (*update_texture_state) (struct intel_context * intel);        void (*render_start) (struct intel_context * intel); @@ -135,14 +134,6 @@ struct intel_context                                  struct intel_region * draw_region,                                  struct intel_region * depth_region); -      void (*meta_draw_quad)(struct intel_context *intel, -			     GLfloat x0, GLfloat x1, -			     GLfloat y0, GLfloat y1, -			     GLfloat z, -			     GLuint color, /* ARGB32 */ -			     GLfloat s0, GLfloat s1, -			     GLfloat t0, GLfloat t1); -        void (*meta_color_mask) (struct intel_context * intel, GLboolean);        void (*meta_stencil_replace) (struct intel_context * intel, @@ -184,20 +175,18 @@ struct intel_context      * Generation number of the hardware: 2 is 8xx, 3 is 9xx pre-965, 4 is 965.      */     int gen; +   GLboolean needs_ff_sync; +   GLboolean is_ironlake; +   GLboolean is_g4x; +   GLboolean is_945; +   GLboolean has_luminance_srgb; -   struct intel_region *front_region; -   struct intel_region *back_region; -   struct intel_region *depth_region; - -   /** -    * This value indicates that the kernel memory manager is being used -    * instead of the fake client-side memory manager. -    */ -   GLboolean ttm; +   int urb_size;     struct intel_batchbuffer *batch;     drm_intel_bo *first_post_swapbuffers_batch;     GLboolean no_batch_wrap; +   GLboolean using_dri2_swapbuffers;     struct     { @@ -217,10 +206,6 @@ struct intel_context     char *prevLockFile;     int prevLockLine; -   GLuint ClearColor565; -   GLuint ClearColor8888; - -     /* Offsets of fields within the current vertex:      */     GLuint coloroffset; @@ -237,6 +222,7 @@ struct intel_context     GLboolean hw_stipple;     GLboolean depth_buffer_is_float;     GLboolean no_rast; +   GLboolean no_hw;     GLboolean always_flush_batch;     GLboolean always_flush_cache; @@ -262,19 +248,6 @@ struct intel_context     intel_tri_func draw_tri;     /** -    * Set to true if a single constant cliprect should be used in the -    * batchbuffer.  Otherwise, cliprects must be calculated at batchbuffer -    * flush time while the lock is held. -    */ -   GLboolean constant_cliprect; - -   /** -    * In !constant_cliprect mode, set to true if the front cliprects should be -    * used instead of back. -    */ -   GLboolean front_cliprects; - -   /**      * Set if rendering has occured to the drawable's front buffer.      *      * This is used in the DRI2 case to detect that glFlush should also copy @@ -302,48 +275,23 @@ struct intel_context     GLboolean use_early_z;     drm_clip_rect_t fboRect;     /**< cliprect for FBO rendering */ -   int perf_boxes; - -   GLuint do_usleeps; -   int do_irqs; -   GLuint irqsEmitted; - -   GLboolean scissor;     drm_clip_rect_t draw_rect;     drm_clip_rect_t scissor_rect; -   drm_context_t hHWContext; -   drmLock *driHwLock;     int driFd; -   __DRIcontextPrivate *driContext; -   __DRIdrawablePrivate *driDrawable; -   __DRIdrawablePrivate *driReadDrawable; -   __DRIscreenPrivate *driScreen; +   __DRIcontext *driContext; +   __DRIdrawable *driDrawable; +   __DRIdrawable *driReadDrawable; +   __DRIscreen *driScreen;     intelScreenPrivate *intelScreen; -   volatile drm_i915_sarea_t *sarea; - -   GLuint lastStamp; - -   GLboolean no_hw;     /**      * Configuration cache      */     driOptionCache optionCache; - -   int64_t swap_ust; -   int64_t swap_missed_ust; - -   GLuint swap_count; -   GLuint swap_missed_count;  }; -/* These are functions now: - */ -void LOCK_HARDWARE( struct intel_context *intel ); -void UNLOCK_HARDWARE( struct intel_context *intel ); -  extern char *__progname; @@ -374,29 +322,6 @@ do {						\  } while (0)  /* ================================================================ - * Color packing: - */ - -#define INTEL_PACKCOLOR4444(r,g,b,a) \ -  ((((a) & 0xf0) << 8) | (((r) & 0xf0) << 4) | ((g) & 0xf0) | ((b) >> 4)) - -#define INTEL_PACKCOLOR1555(r,g,b,a) \ -  ((((r) & 0xf8) << 7) | (((g) & 0xf8) << 2) | (((b) & 0xf8) >> 3) | \ -    ((a) ? 0x8000 : 0)) - -#define INTEL_PACKCOLOR565(r,g,b) \ -  ((((r) & 0xf8) << 8) | (((g) & 0xfc) << 3) | (((b) & 0xf8) >> 3)) - -#define INTEL_PACKCOLOR8888(r,g,b,a) \ -  ((a<<24) | (r<<16) | (g<<8) | b) - -#define INTEL_PACKCOLOR(format, r,  g,  b, a)		\ -(format == DV_PF_555 ? INTEL_PACKCOLOR1555(r,g,b,a) :	\ - (format == DV_PF_565 ? INTEL_PACKCOLOR565(r,g,b) :	\ -  (format == DV_PF_8888 ? INTEL_PACKCOLOR8888(r,g,b,a) :	\ -   0))) - -/* ================================================================   * From linux kernel i386 header files, copes with odd sizes better   * than COPY_DWORDS would:   * XXX Put this in src/mesa/main/imports.h ??? @@ -481,14 +406,13 @@ extern int INTEL_DEBUG;  extern GLboolean intelInitContext(struct intel_context *intel,                                    const __GLcontextModes * mesaVis, -                                  __DRIcontextPrivate * driContextPriv, +                                  __DRIcontext * driContextPriv,                                    void *sharedContextPrivate,                                    struct dd_function_table *functions); -extern void intelGetLock(struct intel_context *intel, GLuint flags); -  extern void intelFinish(GLcontext * ctx);  extern void intelFlush(GLcontext * ctx); +extern void intel_flush(GLcontext * ctx, GLboolean needs_mi_flush);  extern void intelInitDriverFunctions(struct dd_function_table *functions); diff --git a/src/mesa/drivers/dri/intel/intel_extensions.c b/src/mesa/drivers/dri/intel/intel_extensions.c index 48cdae509e..6fdd22b9e9 100644 --- a/src/mesa/drivers/dri/intel/intel_extensions.c +++ b/src/mesa/drivers/dri/intel/intel_extensions.c @@ -79,6 +79,7 @@ static const struct dri_extension card_extensions[] = {     { "GL_ARB_half_float_pixel",           NULL },     { "GL_ARB_map_buffer_range",           GL_ARB_map_buffer_range_functions },     { "GL_ARB_multitexture",               NULL }, +   { "GL_ARB_pixel_buffer_object",      NULL },     { "GL_ARB_point_parameters",           GL_ARB_point_parameters_functions },     { "GL_ARB_point_sprite",               NULL },     { "GL_ARB_shader_objects",             GL_ARB_shader_objects_functions }, @@ -104,6 +105,8 @@ static const struct dri_extension card_extensions[] = {     { "GL_EXT_blend_logic_op",             NULL },     { "GL_EXT_blend_subtract",             NULL },     { "GL_EXT_cull_vertex",                GL_EXT_cull_vertex_functions }, +   { "GL_EXT_framebuffer_blit",         GL_EXT_framebuffer_blit_functions }, +   { "GL_EXT_framebuffer_object",       GL_EXT_framebuffer_object_functions },     { "GL_EXT_fog_coord",                  GL_EXT_fog_coord_functions },     { "GL_EXT_gpu_program_parameters",     GL_EXT_gpu_program_parameters_functions },     { "GL_EXT_packed_depth_stencil",       NULL }, @@ -151,6 +154,7 @@ static const struct dri_extension brw_extensions[] = {     { "GL_ARB_fragment_program_shadow",    NULL },     { "GL_ARB_fragment_shader",            NULL },     { "GL_ARB_framebuffer_object",         GL_ARB_framebuffer_object_functions}, +   { "GL_ARB_half_float_vertex",          NULL },     { "GL_ARB_occlusion_query",            GL_ARB_occlusion_query_functions },     { "GL_ARB_point_sprite", 		  NULL },     { "GL_ARB_seamless_cube_map",          NULL }, @@ -175,14 +179,6 @@ static const struct dri_extension arb_oq_extensions[] = {     { NULL, NULL }  }; - -static const struct dri_extension ttm_extensions[] = { -   { "GL_ARB_pixel_buffer_object",      NULL }, -   { "GL_EXT_framebuffer_blit",         GL_EXT_framebuffer_blit_functions }, -   { "GL_EXT_framebuffer_object",       GL_EXT_framebuffer_object_functions }, -   { NULL, NULL } -}; -  static const struct dri_extension fragment_shader_extensions[] = {     { "GL_ARB_fragment_shader",            NULL },     { NULL, NULL } @@ -201,14 +197,10 @@ intelInitExtensions(GLcontext *ctx)      */     driInitExtensions(ctx, card_extensions, GL_FALSE); -   if (intel->ttm) -      driInitExtensions(ctx, ttm_extensions, GL_FALSE); - -   if (IS_965(intel->intelScreen->deviceID)) +   if (intel->gen >= 4)        driInitExtensions(ctx, brw_extensions, GL_FALSE); -   if (IS_915(intel->intelScreen->deviceID) -       || IS_945(intel->intelScreen->deviceID)) { +   if (intel->gen == 3) {        driInitExtensions(ctx, i915_extensions, GL_FALSE);        if (driQueryOptionb(&intel->optionCache, "fragment_shader")) diff --git a/src/mesa/drivers/dri/intel/intel_extensions.h b/src/mesa/drivers/dri/intel/intel_extensions.h index 1d1c97a4a9..e78e07356e 100644 --- a/src/mesa/drivers/dri/intel/intel_extensions.h +++ b/src/mesa/drivers/dri/intel/intel_extensions.h @@ -32,5 +32,8 @@  extern void  intelInitExtensions(GLcontext *ctx); +extern void +intelFlushDrawable(__DRIdrawable *drawable); +  #endif diff --git a/src/mesa/drivers/dri/intel/intel_fbo.c b/src/mesa/drivers/dri/intel/intel_fbo.c index 608f75b824..d58ffd95fa 100644 --- a/src/mesa/drivers/dri/intel/intel_fbo.c +++ b/src/mesa/drivers/dri/intel/intel_fbo.c @@ -222,7 +222,6 @@ static void  intel_resize_buffers(GLcontext *ctx, struct gl_framebuffer *fb,  		     GLuint width, GLuint height)  { -   struct intel_framebuffer *intel_fb = (struct intel_framebuffer*)fb;     int i;     _mesa_resize_framebuffer(ctx, fb, width, height); @@ -233,9 +232,10 @@ intel_resize_buffers(GLcontext *ctx, struct gl_framebuffer *fb,        return;     } +     /* Make sure all window system renderbuffers are up to date */ -   for (i = 0; i < 2; i++) { -      struct gl_renderbuffer *rb = &intel_fb->color_rb[i]->Base; +   for (i = BUFFER_FRONT_LEFT; i <= BUFFER_BACK_RIGHT; i++) { +      struct gl_renderbuffer *rb = fb->Attachment[i].Renderbuffer;        /* only resize if size is changing */        if (rb && (rb->Width != width || rb->Height != height)) { @@ -398,8 +398,6 @@ static GLboolean  intel_update_wrapper(GLcontext *ctx, struct intel_renderbuffer *irb,   		     struct gl_texture_image *texImage)  { -   gl_format texFormat; -     if (texImage->TexFormat == MESA_FORMAT_ARGB8888) {        irb->Base.DataType = GL_UNSIGNED_BYTE;        DBG("Render to RGBA8 texture OK\n"); @@ -429,14 +427,13 @@ intel_update_wrapper(GLcontext *ctx, struct intel_renderbuffer *irb,        DBG("Render to DEPTH_STENCIL texture OK\n");     }     else { -      DBG("Render to texture BAD FORMAT %d\n", texImage->TexFormat); +      DBG("Render to texture BAD FORMAT %s\n", +	  _mesa_get_format_name(texImage->TexFormat));        return GL_FALSE;     }     irb->Base.Format = texImage->TexFormat; -   texFormat = texImage->TexFormat; -     irb->Base.InternalFormat = texImage->InternalFormat;     irb->Base._BaseFormat = _mesa_base_fbo_format(ctx, irb->Base.InternalFormat);     irb->Base.Width = texImage->Width; @@ -594,11 +591,21 @@ intel_validate_framebuffer(GLcontext *ctx, struct gl_framebuffer *fb)        intel_get_renderbuffer(fb, BUFFER_STENCIL);     int i; -   if (stencilRb && stencilRb != depthRb) { -      /* we only support combined depth/stencil buffers, not separate -       * stencil buffers. -       */ -      fb->_Status = GL_FRAMEBUFFER_UNSUPPORTED_EXT; +   if (depthRb && stencilRb && stencilRb != depthRb) { +      if (ctx->DrawBuffer->Attachment[BUFFER_DEPTH].Type == GL_TEXTURE && +	  ctx->DrawBuffer->Attachment[BUFFER_STENCIL].Type == GL_TEXTURE && +	  (ctx->DrawBuffer->Attachment[BUFFER_DEPTH].Texture->Name == +	   ctx->DrawBuffer->Attachment[BUFFER_STENCIL].Texture->Name)) { +	 /* OK */ +      } else { +	 /* we only support combined depth/stencil buffers, not separate +	  * stencil buffers. +	  */ +	 DBG("Only supports combined depth/stencil (found %s, %s)\n", +	     depthRb ? _mesa_get_format_name(depthRb->Base.Format): "NULL", +	     stencilRb ? _mesa_get_format_name(stencilRb->Base.Format): "NULL"); +	 fb->_Status = GL_FRAMEBUFFER_UNSUPPORTED_EXT; +      }     }     for (i = 0; i < ctx->Const.MaxDrawBuffers; i++) { @@ -609,6 +616,7 @@ intel_validate_framebuffer(GLcontext *ctx, struct gl_framebuffer *fb)  	 continue;        if (irb == NULL) { +	 DBG("software rendering renderbuffer\n");  	 fb->_Status = GL_FRAMEBUFFER_UNSUPPORTED_EXT;  	 continue;        } diff --git a/src/mesa/drivers/dri/intel/intel_fbo.h b/src/mesa/drivers/dri/intel/intel_fbo.h index fa43077d6a..586dbbbb25 100644 --- a/src/mesa/drivers/dri/intel/intel_fbo.h +++ b/src/mesa/drivers/dri/intel/intel_fbo.h @@ -34,27 +34,6 @@  struct intel_context;  /** - * Intel framebuffer, derived from gl_framebuffer. - */ -struct intel_framebuffer -{ -   struct gl_framebuffer Base; - -   struct intel_renderbuffer *color_rb[2]; - -   /* VBI -    */ -   GLuint vbl_waited; - -   int64_t swap_ust; -   int64_t swap_missed_ust; - -   GLuint swap_count; -   GLuint swap_missed_count; -}; - - -/**   * Intel renderbuffer, derived from gl_renderbuffer.   */  struct intel_renderbuffer @@ -62,8 +41,6 @@ struct intel_renderbuffer     struct gl_renderbuffer Base;     struct intel_region *region; -   GLuint vbl_pending;   /**< vblank sequence number of pending flip */ -     uint8_t *span_cache;     unsigned long span_cache_offset;  }; @@ -121,7 +98,7 @@ intel_fbo_init(struct intel_context *intel);  extern void -intel_flip_renderbuffers(struct intel_framebuffer *intel_fb); +intel_flip_renderbuffers(struct gl_framebuffer *fb);  static INLINE struct intel_region * diff --git a/src/mesa/drivers/dri/intel/intel_mipmap_tree.c b/src/mesa/drivers/dri/intel/intel_mipmap_tree.c index abb3024bfb..82e4150c6a 100644 --- a/src/mesa/drivers/dri/intel/intel_mipmap_tree.c +++ b/src/mesa/drivers/dri/intel/intel_mipmap_tree.c @@ -87,7 +87,7 @@ intel_miptree_create_internal(struct intel_context *intel,     mt->pitch = 0;  #ifdef I915 -   if (IS_945(intel->intelScreen->deviceID)) +   if (intel->is_945)        ok = i945_miptree_layout(intel, mt, tiling);     else        ok = i915_miptree_layout(intel, mt, tiling); @@ -224,16 +224,12 @@ int intel_miptree_pitch_align (struct intel_context *intel,     if (!mt->compressed) {        int pitch_align; -      if (intel->ttm) { -	 /* XXX: Align pitch to multiple of 64 bytes for now to allow -	  * render-to-texture to work in all cases. This should probably be -	  * replaced at some point by some scheme to only do this when really -	  * necessary. -	  */ -	 pitch_align = 64; -      } else { -	 pitch_align = 4; -      } +      /* XXX: Align pitch to multiple of 64 bytes for now to allow +       * render-to-texture to work in all cases. This should probably be +       * replaced at some point by some scheme to only do this when really +       * necessary. +       */ +      pitch_align = 64;        if (tiling == I915_TILING_X)  	 pitch_align = 512; diff --git a/src/mesa/drivers/dri/intel/intel_pixel.c b/src/mesa/drivers/dri/intel/intel_pixel.c index f4e7d4b56e..cb088e4032 100644 --- a/src/mesa/drivers/dri/intel/intel_pixel.c +++ b/src/mesa/drivers/dri/intel/intel_pixel.c @@ -81,10 +81,10 @@ intel_check_blit_fragment_ops(GLcontext * ctx, GLboolean src_alpha_is_one)        return GL_FALSE;     } -   if (!(ctx->Color.ColorMask[0] && -	 ctx->Color.ColorMask[1] && -	 ctx->Color.ColorMask[2] && -	 ctx->Color.ColorMask[3])) { +   if (!(ctx->Color.ColorMask[0][0] && +	 ctx->Color.ColorMask[0][1] && +	 ctx->Color.ColorMask[0][2] && +	 ctx->Color.ColorMask[0][3])) {        DBG("fallback due to color masking\n");        return GL_FALSE;     } diff --git a/src/mesa/drivers/dri/intel/intel_pixel_bitmap.c b/src/mesa/drivers/dri/intel/intel_pixel_bitmap.c index 6bb497baa0..b27766ee6f 100644 --- a/src/mesa/drivers/dri/intel/intel_pixel_bitmap.c +++ b/src/mesa/drivers/dri/intel/intel_pixel_bitmap.c @@ -226,16 +226,13 @@ do_blit_bitmap( GLcontext *ctx,     UNCLAMPED_FLOAT_TO_UBYTE(ubcolor[3], tmpColor[3]);     if (dst->cpp == 2) -      color = INTEL_PACKCOLOR565(ubcolor[0], ubcolor[1], ubcolor[2]); +      color = PACK_COLOR_565(ubcolor[0], ubcolor[1], ubcolor[2]);     else -      color = INTEL_PACKCOLOR8888(ubcolor[0], ubcolor[1], -				  ubcolor[2], ubcolor[3]); +      color = PACK_COLOR_8888(ubcolor[3], ubcolor[0], ubcolor[1], ubcolor[2]);     if (!intel_check_blit_fragment_ops(ctx, tmpColor[3] == 1.0F))        return GL_FALSE; -   LOCK_HARDWARE(intel); -     intel_get_cliprects(intel, &cliprects, &num_cliprects, &x_off, &y_off);     if (num_cliprects != 0) {        GLuint i; @@ -323,7 +320,6 @@ do_blit_bitmap( GLcontext *ctx,        }     }  out: -   UNLOCK_HARDWARE(intel);     if (INTEL_DEBUG & DEBUG_SYNC)        intel_batchbuffer_flush(intel->batch); @@ -502,6 +498,7 @@ intel_texture_bitmap(GLcontext * ctx,     meta_restore_fragment_program(&intel->meta);     meta_restore_vertex_program(&intel->meta); +   _mesa_ActiveTextureARB(GL_TEXTURE0_ARB + old_active_texture);     _mesa_PopClientAttrib();     _mesa_PopAttrib(); diff --git a/src/mesa/drivers/dri/intel/intel_pixel_copy.c b/src/mesa/drivers/dri/intel/intel_pixel_copy.c index 622aaa22d6..e002516cdd 100644 --- a/src/mesa/drivers/dri/intel/intel_pixel_copy.c +++ b/src/mesa/drivers/dri/intel/intel_pixel_copy.c @@ -35,28 +35,33 @@  #include "intel_buffers.h"  #include "intel_regions.h"  #include "intel_pixel.h" +#include "intel_fbo.h"  #define FILE_DEBUG_FLAG DEBUG_PIXEL  static struct intel_region *  copypix_src_region(struct intel_context *intel, GLenum type)  { +   struct intel_renderbuffer *depth; + +   depth = (struct intel_renderbuffer *) +      &intel->ctx.DrawBuffer->Attachment[BUFFER_DEPTH].Renderbuffer; +     switch (type) {     case GL_COLOR:        return intel_readbuf_region(intel);     case GL_DEPTH: -      /* Don't think this is really possible execpt at 16bpp, when we have no stencil. -       */ -      if (intel->depth_region && intel->depth_region->cpp == 2) -         return intel->depth_region; +      /* Don't think this is really possible execpt at 16bpp, when we +       * have no stencil. */ +      if (depth && depth->region->cpp == 2) +         return depth->region;     case GL_STENCIL: -      /* Don't think this is really possible.  -       */ +      /* Don't think this is really possible. */        break;     case GL_DEPTH_STENCIL_EXT:        /* Does it matter whether it is stencil/depth or depth/stencil?         */ -      return intel->depth_region; +      return depth->region;     default:        break;     } @@ -83,10 +88,10 @@ intel_check_copypixel_blit_fragment_ops(GLcontext * ctx)              ctx->Depth.Test ||              ctx->Fog.Enabled ||              ctx->Stencil._Enabled || -            !ctx->Color.ColorMask[0] || -            !ctx->Color.ColorMask[1] || -            !ctx->Color.ColorMask[2] || -            !ctx->Color.ColorMask[3] || +            !ctx->Color.ColorMask[0][0] || +            !ctx->Color.ColorMask[0][1] || +            !ctx->Color.ColorMask[0][2] || +            !ctx->Color.ColorMask[0][3] ||              ctx->Texture._EnabledUnits ||  	    ctx->FragmentProgram._Enabled ||  	    ctx->Color.BlendEnabled); @@ -134,8 +139,6 @@ do_blit_copypixels(GLcontext * ctx,     intelFlush(&intel->ctx); -   LOCK_HARDWARE(intel); -     intel_get_cliprects(intel, &cliprects, &num_cliprects, &x_off, &y_off);     if (num_cliprects != 0) {        GLint delta_x; @@ -214,13 +217,11 @@ do_blit_copypixels(GLcontext * ctx,  				ctx->Color.ColorLogicOpEnabled ?  				ctx->Color.LogicOp : GL_COPY)) {  	    DBG("%s: blit failure\n", __FUNCTION__); -	    UNLOCK_HARDWARE(intel);  	    return GL_FALSE;  	 }        }     }  out: -   UNLOCK_HARDWARE(intel);     intel_check_front_buffer_rendering(intel); diff --git a/src/mesa/drivers/dri/intel/intel_pixel_draw.c b/src/mesa/drivers/dri/intel/intel_pixel_draw.c index 3a35634db0..7e82c5b8aa 100644 --- a/src/mesa/drivers/dri/intel/intel_pixel_draw.c +++ b/src/mesa/drivers/dri/intel/intel_pixel_draw.c @@ -66,7 +66,6 @@ intel_stencil_drawpixels(GLcontext * ctx,     GLfloat vertices[4][2];     struct intel_renderbuffer *irb;     struct intel_renderbuffer *depth_irb; -   struct gl_renderbuffer *rb;     struct gl_pixelstore_attrib old_unpack;     GLstencil *stencil_pixels;     int row, y1, y2; @@ -167,7 +166,6 @@ intel_stencil_drawpixels(GLcontext * ctx,      */     depth_irb = intel_get_renderbuffer(ctx->DrawBuffer, BUFFER_DEPTH);     irb = intel_create_renderbuffer(MESA_FORMAT_ARGB8888); -   rb = &irb->Base;     irb->Base.Width = depth_irb->Base.Width;     irb->Base.Height = depth_irb->Base.Height;     intel_renderbuffer_set_region(irb, depth_irb->region); diff --git a/src/mesa/drivers/dri/intel/intel_pixel_read.c b/src/mesa/drivers/dri/intel/intel_pixel_read.c index 01a057051e..7611ba8650 100644 --- a/src/mesa/drivers/dri/intel/intel_pixel_read.c +++ b/src/mesa/drivers/dri/intel/intel_pixel_read.c @@ -76,7 +76,7 @@ do_texture_readpixels(GLcontext * ctx,     struct intel_context *intel = intel_context(ctx);     intelScreenPrivate *screen = intel->intelScreen;     GLint pitch = pack->RowLength ? pack->RowLength : width; -   __DRIdrawablePrivate *dPriv = intel->driDrawable; +   __DRIdrawable *dPriv = intel->driDrawable;     int textureFormat;     GLenum glTextureFormat;     int destFormat, depthFormat, destPitch; @@ -104,15 +104,12 @@ do_texture_readpixels(GLcontext * ctx,        return GL_FALSE;     } -   LOCK_HARDWARE(intel); -     if (intel->driDrawable->numClipRects) {        intel->vtbl.install_meta_state(intel);        intel->vtbl.meta_no_depth_write(intel);        intel->vtbl.meta_no_stencil_write(intel);        if (!driClipRectToFramebuffer(ctx->ReadBuffer, &x, &y, &width, &height)) { -         UNLOCK_HARDWARE(intel);           SET_STATE(i830, state);           if (INTEL_DEBUG & DEBUG_PIXEL)              fprintf(stderr, "%s: cliprect failed\n", __FUNCTION__); @@ -149,7 +146,6 @@ do_texture_readpixels(GLcontext * ctx,        intel->vtbl.leave_meta_state(intel);     } -   UNLOCK_HARDWARE(intel);     intel_region_wait_fence(ctx, dest_region);   /* required by GL */     return GL_TRUE; @@ -223,7 +219,6 @@ do_blit_readpixels(GLcontext * ctx,      * fire with lock held to guarentee cliprects are correct.      */     intelFlush(&intel->ctx); -   LOCK_HARDWARE(intel);     if (intel->driReadDrawable->numClipRects) {        GLboolean all = (width * height * src->cpp == dst->Base.Size && @@ -232,7 +227,7 @@ do_blit_readpixels(GLcontext * ctx,        dri_bo *dst_buffer = intel_bufferobj_buffer(intel, dst,  						  all ? INTEL_WRITE_FULL :  						  INTEL_WRITE_PART); -      __DRIdrawablePrivate *dPriv = intel->driReadDrawable; +      __DRIdrawable *dPriv = intel->driReadDrawable;        int nbox = dPriv->numClipRects;        drm_clip_rect_t *box = dPriv->pClipRects;        drm_clip_rect_t rect; @@ -260,12 +255,10 @@ do_blit_readpixels(GLcontext * ctx,  				rect.y2 - src_rect.y2,  				rect.x2 - rect.x1, rect.y2 - rect.y1,  				GL_COPY)) { -	    UNLOCK_HARDWARE(intel);  	    return GL_FALSE;  	 }        }     } -   UNLOCK_HARDWARE(intel);     if (INTEL_DEBUG & DEBUG_PIXEL)        _mesa_printf("%s - DONE\n", __FUNCTION__); diff --git a/src/mesa/drivers/dri/intel/intel_regions.c b/src/mesa/drivers/dri/intel/intel_regions.c index d13516ae8e..f415589c5d 100644 --- a/src/mesa/drivers/dri/intel/intel_regions.c +++ b/src/mesa/drivers/dri/intel/intel_regions.c @@ -361,14 +361,12 @@ intel_region_data(struct intel_context *intel,           intel_region_cow(intel, dst);     } -   LOCK_HARDWARE(intel);     _mesa_copy_rect(intel_region_map(intel, dst) + dst_offset,                     dst->cpp,                     dst->pitch,                     dstx, dsty, width, height, src, src_pitch, srcx, srcy);     intel_region_unmap(intel, dst); -   UNLOCK_HARDWARE(intel);  }  /* Copy rectangular sub-regions. Need better logic about when to @@ -484,7 +482,6 @@ intel_region_cow(struct intel_context *intel, struct intel_region *region)     /* Now blit from the texture buffer to the new buffer:       */ -   LOCK_HARDWARE(intel);     ok = intelEmitCopyBlit(intel,                            region->cpp,                            region->pitch, pbo->buffer, 0, region->tiling, @@ -493,7 +490,6 @@ intel_region_cow(struct intel_context *intel, struct intel_region *region)                            region->pitch, region->height,                            GL_COPY);     assert(ok); -   UNLOCK_HARDWARE(intel);  }  dri_bo * @@ -509,125 +505,3 @@ intel_region_buffer(struct intel_context *intel,     return region->buffer;  } - -static struct intel_region * -intel_recreate_static(struct intel_context *intel, -		      const char *name, -		      struct intel_region *region, -		      intelRegion *region_desc) -{ -   intelScreenPrivate *intelScreen = intel->intelScreen; -   int ret; - -   if (region == NULL) { -      region = calloc(sizeof(*region), 1); -      region->refcount = 1; -      _DBG("%s creating new region %p\n", __FUNCTION__, region); -   } -   else { -      _DBG("%s %p\n", __FUNCTION__, region); -   } - -   if (intel->ctx.Visual.rgbBits == 24) -      region->cpp = 4; -   else -      region->cpp = intel->ctx.Visual.rgbBits / 8; -   region->pitch = intelScreen->pitch; -   region->width = intelScreen->width; -   region->height = intelScreen->height; - -   if (region->buffer != NULL) { -      dri_bo_unreference(region->buffer); -      region->buffer = NULL; -   } - -   if (intel->ttm) { -      assert(region_desc->bo_handle != -1); -      region->buffer = intel_bo_gem_create_from_name(intel->bufmgr, -						     name, -						     region_desc->bo_handle); - -      ret = dri_bo_get_tiling(region->buffer, ®ion->tiling, -			      ®ion->bit_6_swizzle); -      if (ret != 0) { -	 fprintf(stderr, "Couldn't get tiling of buffer %d (%s): %s\n", -		 region_desc->bo_handle, name, strerror(-ret)); -	 intel_region_release(®ion); -	 return NULL; -      } -   } else { -      if (region->classic_map != NULL) { -	 drmUnmap(region->classic_map, -		  region->pitch * region->cpp * region->height); -	 region->classic_map = NULL; -      } -      ret = drmMap(intel->driFd, region_desc->handle, -		   region->pitch * region->cpp * region->height, -		   ®ion->classic_map); -      if (ret != 0) { -	 fprintf(stderr, "Failed to drmMap %s buffer\n", name); -	 free(region); -	 return NULL; -      } - -      region->buffer = intel_bo_fake_alloc_static(intel->bufmgr, -						  name, -						  region_desc->offset, -						  region->pitch * region->cpp * -						  region->height, -						  region->classic_map); - -      /* The sarea just gives us a boolean for whether it's tiled or not, -       * instead of which tiling mode it is.  Guess. -       */ -      if (region_desc->tiled) { -	 if (intel->gen >= 4 && region_desc == &intelScreen->depth) -	    region->tiling = I915_TILING_Y; -	 else -	    region->tiling = I915_TILING_X; -      } else { -	 region->tiling = I915_TILING_NONE; -      } - -      region->bit_6_swizzle = I915_BIT_6_SWIZZLE_NONE; -   } - -   assert(region->buffer != NULL); - -   return region; -} - -/** - * Create intel_region structs to describe the static front, back, and depth - * buffers created by the xserver. - * - * Although FBO's mean we now no longer use these as render targets in - * all circumstances, they won't go away until the back and depth - * buffers become private, and the front buffer will remain even then. - * - * Note that these don't allocate video memory, just describe - * allocations alread made by the X server. - */ -void -intel_recreate_static_regions(struct intel_context *intel) -{ -   intelScreenPrivate *intelScreen = intel->intelScreen; - -   intel->front_region = -      intel_recreate_static(intel, "front", -			    intel->front_region, -			    &intelScreen->front); - -   intel->back_region = -      intel_recreate_static(intel, "back", -			    intel->back_region, -			    &intelScreen->back); - -   /* Still assumes front.cpp == depth.cpp.  We can kill this when we move to -    * private buffers. -    */ -   intel->depth_region = -      intel_recreate_static(intel, "depth", -			    intel->depth_region, -			    &intelScreen->depth); -} diff --git a/src/mesa/drivers/dri/intel/intel_screen.c b/src/mesa/drivers/dri/intel/intel_screen.c index f3de7d1464..96e7f2885a 100644 --- a/src/mesa/drivers/dri/intel/intel_screen.c +++ b/src/mesa/drivers/dri/intel/intel_screen.c @@ -31,7 +31,6 @@  #include "main/renderbuffer.h"  #include "utils.h" -#include "vblank.h"  #include "xmlpool.h"  #include "intel_batchbuffer.h" @@ -39,7 +38,7 @@  #include "intel_bufmgr.h"  #include "intel_chipset.h"  #include "intel_fbo.h" -#include "intel_swapbuffers.h" +#include "intel_regions.h"  #include "intel_screen.h"  #include "intel_tex.h" @@ -54,7 +53,6 @@  PUBLIC const char __driConfigOptions[] =     DRI_CONF_BEGIN     DRI_CONF_SECTION_PERFORMANCE -      DRI_CONF_FTHROTTLE_MODE(DRI_CONF_FTHROTTLE_IRQS)        DRI_CONF_VBLANK_MODE(DRI_CONF_VBLANK_ALWAYS_SYNC)        /* Options correspond to DRI_CONF_BO_REUSE_DISABLED,         * DRI_CONF_BO_REUSE_ALL @@ -96,157 +94,64 @@ PUBLIC const char __driConfigOptions[] =     DRI_CONF_SECTION_END  DRI_CONF_END; -const GLuint __driNConfigOptions = 12; +const GLuint __driNConfigOptions = 11;  #ifdef USE_NEW_INTERFACE  static PFNGLXCREATECONTEXTMODES create_context_modes = NULL;  #endif /*USE_NEW_INTERFACE */ -/** - * Map all the memory regions described by the screen. - * \return GL_TRUE if success, GL_FALSE if error. - */ -GLboolean -intelMapScreenRegions(__DRIscreenPrivate * sPriv) -{ -   intelScreenPrivate *intelScreen = (intelScreenPrivate *) sPriv->private; - -   if (0) -      _mesa_printf("TEX 0x%08x ", intelScreen->tex.handle); -   if (intelScreen->tex.size != 0) { -      if (drmMap(sPriv->fd, -		 intelScreen->tex.handle, -		 intelScreen->tex.size, -		 (drmAddress *) & intelScreen->tex.map) != 0) { -	 intelUnmapScreenRegions(intelScreen); -	 return GL_FALSE; -      } -   } - -   return GL_TRUE; -} - -void -intelUnmapScreenRegions(intelScreenPrivate * intelScreen) -{ -   if (intelScreen->tex.map) { -      drmUnmap(intelScreen->tex.map, intelScreen->tex.size); -      intelScreen->tex.map = NULL; -   } -} +static const __DRItexOffsetExtension intelTexOffsetExtension = { +   { __DRI_TEX_OFFSET }, +   intelSetTexOffset, +}; +static const __DRItexBufferExtension intelTexBufferExtension = { +    { __DRI_TEX_BUFFER, __DRI_TEX_BUFFER_VERSION }, +   intelSetTexBuffer, +   intelSetTexBuffer2, +};  static void -intelPrintDRIInfo(intelScreenPrivate * intelScreen, -                  __DRIscreenPrivate * sPriv, I830DRIPtr gDRIPriv) +intelDRI2Flush(__DRIdrawable *drawable)  { -   fprintf(stderr, "*** Front size:   0x%x  offset: 0x%x  pitch: %d\n", -           intelScreen->front.size, intelScreen->front.offset, -           intelScreen->pitch); -   fprintf(stderr, "*** Back size:    0x%x  offset: 0x%x  pitch: %d\n", -           intelScreen->back.size, intelScreen->back.offset, -           intelScreen->pitch); -   fprintf(stderr, "*** Depth size:   0x%x  offset: 0x%x  pitch: %d\n", -           intelScreen->depth.size, intelScreen->depth.offset, -           intelScreen->pitch); -   fprintf(stderr, "*** Texture size: 0x%x  offset: 0x%x\n", -           intelScreen->tex.size, intelScreen->tex.offset); -   fprintf(stderr, "*** Memory : 0x%x\n", gDRIPriv->mem); -} +   struct intel_context *intel = drawable->driContextPriv->driverPrivate; +   if (intel->gen < 4) +      INTEL_FIREVERTICES(intel); -static void -intelPrintSAREA(const drm_i915_sarea_t * sarea) -{ -   fprintf(stderr, "SAREA: sarea width %d  height %d\n", sarea->width, -           sarea->height); -   fprintf(stderr, "SAREA: pitch: %d\n", sarea->pitch); -   fprintf(stderr, -           "SAREA: front offset: 0x%08x  size: 0x%x  handle: 0x%x tiled: %d\n", -           sarea->front_offset, sarea->front_size, -           (unsigned) sarea->front_handle, sarea->front_tiled); -   fprintf(stderr, -           "SAREA: back  offset: 0x%08x  size: 0x%x  handle: 0x%x tiled: %d\n", -           sarea->back_offset, sarea->back_size, -           (unsigned) sarea->back_handle, sarea->back_tiled); -   fprintf(stderr, "SAREA: depth offset: 0x%08x  size: 0x%x  handle: 0x%x tiled: %d\n", -           sarea->depth_offset, sarea->depth_size, -           (unsigned) sarea->depth_handle, sarea->depth_tiled); -   fprintf(stderr, "SAREA: tex   offset: 0x%08x  size: 0x%x  handle: 0x%x\n", -           sarea->tex_offset, sarea->tex_size, (unsigned) sarea->tex_handle); +   if (intel->batch->map != intel->batch->ptr) +      intel_batchbuffer_flush(intel->batch);  } - -/** - * A number of the screen parameters are obtained/computed from - * information in the SAREA.  This function updates those parameters. - */  static void -intelUpdateScreenFromSAREA(intelScreenPrivate * intelScreen, -                           drm_i915_sarea_t * sarea) +intelDRI2FlushInvalidate(__DRIdrawable *drawable)  { -   intelScreen->width = sarea->width; -   intelScreen->height = sarea->height; -   intelScreen->pitch = sarea->pitch; - -   intelScreen->front.offset = sarea->front_offset; -   intelScreen->front.handle = sarea->front_handle; -   intelScreen->front.size = sarea->front_size; -   intelScreen->front.tiled = sarea->front_tiled; - -   intelScreen->back.offset = sarea->back_offset; -   intelScreen->back.handle = sarea->back_handle; -   intelScreen->back.size = sarea->back_size; -   intelScreen->back.tiled = sarea->back_tiled; - -   intelScreen->depth.offset = sarea->depth_offset; -   intelScreen->depth.handle = sarea->depth_handle; -   intelScreen->depth.size = sarea->depth_size; -   intelScreen->depth.tiled = sarea->depth_tiled; +   struct intel_context *intel = drawable->driContextPriv->driverPrivate; -   if (intelScreen->driScrnPriv->ddx_version.minor >= 9) { -      intelScreen->front.bo_handle = sarea->front_bo_handle; -      intelScreen->back.bo_handle = sarea->back_bo_handle; -      intelScreen->depth.bo_handle = sarea->depth_bo_handle; -   } else { -      intelScreen->front.bo_handle = -1; -      intelScreen->back.bo_handle = -1; -      intelScreen->depth.bo_handle = -1; -   } +   intel->using_dri2_swapbuffers = GL_TRUE; -   intelScreen->tex.offset = sarea->tex_offset; -   intelScreen->logTextureGranularity = sarea->log_tex_granularity; -   intelScreen->tex.handle = sarea->tex_handle; -   intelScreen->tex.size = sarea->tex_size; +   intelDRI2Flush(drawable); +   drawable->validBuffers = GL_FALSE; -   if (0) -      intelPrintSAREA(sarea); +   intel_update_renderbuffers(intel->driContext, drawable);  } -static const __DRItexOffsetExtension intelTexOffsetExtension = { -   { __DRI_TEX_OFFSET }, -   intelSetTexOffset, -}; - -static const __DRItexBufferExtension intelTexBufferExtension = { -    { __DRI_TEX_BUFFER, __DRI_TEX_BUFFER_VERSION }, -   intelSetTexBuffer, -   intelSetTexBuffer2, +static const struct __DRI2flushExtensionRec intelFlushExtension = { +    { __DRI2_FLUSH, __DRI2_FLUSH_VERSION }, +    intelDRI2Flush, +    intelDRI2FlushInvalidate,  };  static const __DRIextension *intelScreenExtensions[] = {      &driReadDrawableExtension, -    &driCopySubBufferExtension.base, -    &driSwapControlExtension.base, -    &driFrameTrackingExtension.base, -    &driMediaStreamCounterExtension.base,      &intelTexOffsetExtension.base,      &intelTexBufferExtension.base, +    &intelFlushExtension.base,      NULL  };  static GLboolean -intel_get_param(__DRIscreenPrivate *psp, int param, int *value) +intel_get_param(__DRIscreen *psp, int param, int *value)  {     int ret;     struct drm_i915_getparam gp; @@ -263,68 +168,12 @@ intel_get_param(__DRIscreenPrivate *psp, int param, int *value)     return GL_TRUE;  } -static GLboolean intelInitDriver(__DRIscreenPrivate *sPriv) -{ -   intelScreenPrivate *intelScreen; -   I830DRIPtr gDRIPriv = (I830DRIPtr) sPriv->pDevPriv; -   drm_i915_sarea_t *sarea; - -   if (sPriv->devPrivSize != sizeof(I830DRIRec)) { -      fprintf(stderr, -              "\nERROR!  sizeof(I830DRIRec) does not match passed size from device driver\n"); -      return GL_FALSE; -   } - -   /* Allocate the private area */ -   intelScreen = (intelScreenPrivate *) CALLOC(sizeof(intelScreenPrivate)); -   if (!intelScreen) { -      fprintf(stderr, "\nERROR!  Allocating private area failed\n"); -      return GL_FALSE; -   } -   /* parse information in __driConfigOptions */ -   driParseOptionInfo(&intelScreen->optionCache, -                      __driConfigOptions, __driNConfigOptions); - -   intelScreen->driScrnPriv = sPriv; -   sPriv->private = (void *) intelScreen; -   sarea = (drm_i915_sarea_t *) -      (((GLubyte *) sPriv->pSAREA) + gDRIPriv->sarea_priv_offset); -   intelScreen->sarea = sarea; - -   intelScreen->deviceID = gDRIPriv->deviceID; - -   intelUpdateScreenFromSAREA(intelScreen, sarea); - -   if (!intelMapScreenRegions(sPriv)) { -      fprintf(stderr, "\nERROR!  mapping regions\n"); -      _mesa_free(intelScreen); -      sPriv->private = NULL; -      return GL_FALSE; -   } - -   if (0) -      intelPrintDRIInfo(intelScreen, sPriv, gDRIPriv); - -   intelScreen->drmMinor = sPriv->drm_version.minor; - -   /* Determine if IRQs are active? */ -   if (!intel_get_param(sPriv, I915_PARAM_IRQ_ACTIVE, -			&intelScreen->irq_active)) -      return GL_FALSE; - -   sPriv->extensions = intelScreenExtensions; - -   return GL_TRUE; -} - -  static void -intelDestroyScreen(__DRIscreenPrivate * sPriv) +intelDestroyScreen(__DRIscreen * sPriv)  {     intelScreenPrivate *intelScreen = (intelScreenPrivate *) sPriv->private;     dri_bufmgr_destroy(intelScreen->bufmgr); -   intelUnmapScreenRegions(intelScreen);     driDestroyOptionInfo(&intelScreen->optionCache);     FREE(intelScreen); @@ -336,10 +185,12 @@ intelDestroyScreen(__DRIscreenPrivate * sPriv)   * This is called when we need to set up GL rendering to a new X window.   */  static GLboolean -intelCreateBuffer(__DRIscreenPrivate * driScrnPriv, -                  __DRIdrawablePrivate * driDrawPriv, +intelCreateBuffer(__DRIscreen * driScrnPriv, +                  __DRIdrawable * driDrawPriv,                    const __GLcontextModes * mesaVis, GLboolean isPixmap)  { +   struct intel_renderbuffer *rb; +     if (isPixmap) {        return GL_FALSE;          /* not implemented */     } @@ -348,12 +199,12 @@ intelCreateBuffer(__DRIscreenPrivate * driScrnPriv,                               mesaVis->depthBits != 24);        gl_format rgbFormat; -      struct intel_framebuffer *intel_fb = CALLOC_STRUCT(intel_framebuffer); +      struct gl_framebuffer *fb = CALLOC_STRUCT(gl_framebuffer); -      if (!intel_fb) +      if (!fb)  	 return GL_FALSE; -      _mesa_initialize_framebuffer(&intel_fb->Base, mesaVis); +      _mesa_initialize_framebuffer(fb, mesaVis);        if (mesaVis->redBits == 5)  	 rgbFormat = MESA_FORMAT_RGB565; @@ -363,16 +214,12 @@ intelCreateBuffer(__DRIscreenPrivate * driScrnPriv,  	 rgbFormat = MESA_FORMAT_ARGB8888;        /* setup the hardware-based renderbuffers */ -      intel_fb->color_rb[0] = intel_create_renderbuffer(rgbFormat); -      _mesa_add_renderbuffer(&intel_fb->Base, BUFFER_FRONT_LEFT, -			     &intel_fb->color_rb[0]->Base); +      rb = intel_create_renderbuffer(rgbFormat); +      _mesa_add_renderbuffer(fb, BUFFER_FRONT_LEFT, &rb->Base);        if (mesaVis->doubleBufferMode) { -	 intel_fb->color_rb[1] = intel_create_renderbuffer(rgbFormat); - -         _mesa_add_renderbuffer(&intel_fb->Base, BUFFER_BACK_LEFT, -				&intel_fb->color_rb[1]->Base); - +	 rb = intel_create_renderbuffer(rgbFormat); +         _mesa_add_renderbuffer(fb, BUFFER_BACK_LEFT, &rb->Base);        }        if (mesaVis->depthBits == 24) { @@ -381,115 +228,63 @@ intelCreateBuffer(__DRIscreenPrivate * driScrnPriv,  	    struct intel_renderbuffer *depthStencilRb  	       = intel_create_renderbuffer(MESA_FORMAT_S8_Z24);  	    /* note: bind RB to two attachment points */ -	    _mesa_add_renderbuffer(&intel_fb->Base, BUFFER_DEPTH, -				   &depthStencilRb->Base); -	    _mesa_add_renderbuffer(&intel_fb->Base, BUFFER_STENCIL, -				   &depthStencilRb->Base); +	    _mesa_add_renderbuffer(fb, BUFFER_DEPTH, &depthStencilRb->Base); +	    _mesa_add_renderbuffer(fb, BUFFER_STENCIL, &depthStencilRb->Base);  	 } else {  	    struct intel_renderbuffer *depthRb  	       = intel_create_renderbuffer(MESA_FORMAT_X8_Z24); -	    _mesa_add_renderbuffer(&intel_fb->Base, BUFFER_DEPTH, -				   &depthRb->Base); +	    _mesa_add_renderbuffer(fb, BUFFER_DEPTH, &depthRb->Base);  	 }        }        else if (mesaVis->depthBits == 16) {           /* just 16-bit depth buffer, no hw stencil */           struct intel_renderbuffer *depthRb  	    = intel_create_renderbuffer(MESA_FORMAT_Z16); -         _mesa_add_renderbuffer(&intel_fb->Base, BUFFER_DEPTH, &depthRb->Base); +         _mesa_add_renderbuffer(fb, BUFFER_DEPTH, &depthRb->Base);        }        /* now add any/all software-based renderbuffers we may need */ -      _mesa_add_soft_renderbuffers(&intel_fb->Base, +      _mesa_add_soft_renderbuffers(fb,                                     GL_FALSE, /* never sw color */                                     GL_FALSE, /* never sw depth */                                     swStencil, mesaVis->accumRedBits > 0,                                     GL_FALSE, /* never sw alpha */                                     GL_FALSE  /* never sw aux */ ); -      driDrawPriv->driverPrivate = (void *) intel_fb; +      driDrawPriv->driverPrivate = fb;        return GL_TRUE;     }  }  static void -intelDestroyBuffer(__DRIdrawablePrivate * driDrawPriv) +intelDestroyBuffer(__DRIdrawable * driDrawPriv)  { -   struct intel_framebuffer *intel_fb = driDrawPriv->driverPrivate; -   struct intel_renderbuffer *depth_rb; -   struct intel_renderbuffer *stencil_rb; - -   if (intel_fb) { -      if (intel_fb->color_rb[0]) { -         intel_renderbuffer_set_region(intel_fb->color_rb[0], NULL); -      } - -      if (intel_fb->color_rb[1]) { -         intel_renderbuffer_set_region(intel_fb->color_rb[1], NULL); -      } - -      depth_rb = intel_get_renderbuffer(&intel_fb->Base, BUFFER_DEPTH); -      if (depth_rb) { -         intel_renderbuffer_set_region(depth_rb, NULL); -      } - -      stencil_rb = intel_get_renderbuffer(&intel_fb->Base, BUFFER_STENCIL); -      if (stencil_rb) { -         intel_renderbuffer_set_region(stencil_rb, NULL); -      } -   } - -   _mesa_reference_framebuffer((GLframebuffer **)(&(driDrawPriv->driverPrivate)), NULL); -} - - -/** - * Get information about previous buffer swaps. - */ -static int -intelGetSwapInfo(__DRIdrawablePrivate * dPriv, __DRIswapInfo * sInfo) -{ -   struct intel_framebuffer *intel_fb; - -   if ((dPriv == NULL) || (dPriv->driverPrivate == NULL) -       || (sInfo == NULL)) { -      return -1; -   } - -   intel_fb = dPriv->driverPrivate; -   sInfo->swap_count = intel_fb->swap_count; -   sInfo->swap_ust = intel_fb->swap_ust; -   sInfo->swap_missed_count = intel_fb->swap_missed_count; - -   sInfo->swap_missed_usage = (sInfo->swap_missed_count != 0) -      ? driCalculateSwapUsage(dPriv, 0, intel_fb->swap_missed_ust) -      : 0.0; - -   return 0; +    struct gl_framebuffer *fb = driDrawPriv->driverPrivate; +   +    _mesa_reference_framebuffer(&fb, NULL);  } -  /* There are probably better ways to do this, such as an   * init-designated function to register chipids and createcontext   * functions.   */  extern GLboolean i830CreateContext(const __GLcontextModes * mesaVis, -                                   __DRIcontextPrivate * driContextPriv, +                                   __DRIcontext * driContextPriv,                                     void *sharedContextPrivate);  extern GLboolean i915CreateContext(const __GLcontextModes * mesaVis, -                                   __DRIcontextPrivate * driContextPriv, +                                   __DRIcontext * driContextPriv,                                     void *sharedContextPrivate);  extern GLboolean brwCreateContext(const __GLcontextModes * mesaVis, -				  __DRIcontextPrivate * driContextPriv, +				  __DRIcontext * driContextPriv,  				  void *sharedContextPrivate);  static GLboolean  intelCreateContext(const __GLcontextModes * mesaVis, -                   __DRIcontextPrivate * driContextPriv, +                   __DRIcontext * driContextPriv,                     void *sharedContextPrivate)  { -   __DRIscreenPrivate *sPriv = driContextPriv->driScreenPriv; +   __DRIscreen *sPriv = driContextPriv->driScreenPriv;     intelScreenPrivate *intelScreen = (intelScreenPrivate *) sPriv->private;  #ifdef I915 @@ -510,152 +305,20 @@ intelCreateContext(const __GLcontextModes * mesaVis,     return GL_FALSE;  } - -static __DRIconfig ** -intelFillInModes(__DRIscreenPrivate *psp, -		 unsigned pixel_bits, unsigned depth_bits, -                 unsigned stencil_bits, GLboolean have_back_buffer) -{ -   __DRIconfig **configs; -   __GLcontextModes *m; -   unsigned depth_buffer_factor; -   unsigned back_buffer_factor; -   int i; - -   /* GLX_SWAP_COPY_OML is only supported because the Intel driver doesn't -    * support pageflipping at all. -    */ -   static const GLenum back_buffer_modes[] = { -      GLX_NONE, GLX_SWAP_UNDEFINED_OML, GLX_SWAP_COPY_OML -   }; - -   uint8_t depth_bits_array[3]; -   uint8_t stencil_bits_array[3]; -   uint8_t msaa_samples_array[1]; - -   depth_bits_array[0] = 0; -   depth_bits_array[1] = depth_bits; -   depth_bits_array[2] = depth_bits; - -   /* Just like with the accumulation buffer, always provide some modes -    * with a stencil buffer.  It will be a sw fallback, but some apps won't -    * care about that. -    */ -   stencil_bits_array[0] = 0; -   stencil_bits_array[1] = 0; -   if (depth_bits == 24) -      stencil_bits_array[1] = (stencil_bits == 0) ? 8 : stencil_bits; - -   stencil_bits_array[2] = (stencil_bits == 0) ? 8 : stencil_bits; - -   msaa_samples_array[0] = 0; - -   depth_buffer_factor = ((depth_bits != 0) || (stencil_bits != 0)) ? 3 : 1; -   back_buffer_factor = (have_back_buffer) ? 3 : 1; - -   if (pixel_bits == 16) { -      configs = driCreateConfigs(GL_RGB, GL_UNSIGNED_SHORT_5_6_5, -				 depth_bits_array, stencil_bits_array, -				 depth_buffer_factor, back_buffer_modes, -				 back_buffer_factor, -				 msaa_samples_array, 1); -   } -   else { -      __DRIconfig **configs_a8r8g8b8; -      __DRIconfig **configs_x8r8g8b8; - -      configs_a8r8g8b8 = driCreateConfigs(GL_BGRA, GL_UNSIGNED_INT_8_8_8_8_REV, -					  depth_bits_array, -					  stencil_bits_array, -					  depth_buffer_factor, -					  back_buffer_modes, -					  back_buffer_factor, -					  msaa_samples_array, 1); -      configs_x8r8g8b8 = driCreateConfigs(GL_BGR, GL_UNSIGNED_INT_8_8_8_8_REV, -					  depth_bits_array, -					  stencil_bits_array, -					  depth_buffer_factor, -					  back_buffer_modes, -					  back_buffer_factor, -					  msaa_samples_array, 1); -      configs = driConcatConfigs(configs_a8r8g8b8, configs_x8r8g8b8); -   } - -   if (configs == NULL) { -    fprintf(stderr, "[%s:%u] Error creating FBConfig!\n", __func__, -              __LINE__); -      return NULL; -   } - -   /* Mark the visual as slow if there are "fake" stencil bits. -    */ -   for (i = 0; configs[i]; i++) { -      m = &configs[i]->modes; -      if ((m->stencilBits != 0) && (m->stencilBits != stencil_bits)) { -         m->visualRating = GLX_SLOW_CONFIG; -      } -   } - -   return configs; -} -  static GLboolean  intel_init_bufmgr(intelScreenPrivate *intelScreen)  { -   GLboolean gem_disable = getenv("INTEL_NO_GEM") != NULL; -   int gem_kernel = 0; -   GLboolean gem_supported; -   struct drm_i915_getparam gp; -   __DRIscreenPrivate *spriv = intelScreen->driScrnPriv; +   __DRIscreen *spriv = intelScreen->driScrnPriv;     int num_fences = 0;     intelScreen->no_hw = getenv("INTEL_NO_HW") != NULL; -   gp.param = I915_PARAM_HAS_GEM; -   gp.value = &gem_kernel; - -   (void) drmCommandWriteRead(spriv->fd, DRM_I915_GETPARAM, &gp, sizeof(gp)); - -   /* If we've got a new enough DDX that's initializing GEM and giving us -    * object handles for the shared buffers, use that. -    */ -   intelScreen->ttm = GL_FALSE; -   if (intelScreen->driScrnPriv->dri2.enabled) -       gem_supported = GL_TRUE; -   else if (intelScreen->driScrnPriv->ddx_version.minor >= 9 && -	    gem_kernel && -	    intelScreen->front.bo_handle != -1) -       gem_supported = GL_TRUE; -   else -       gem_supported = GL_FALSE; - -   if (!gem_disable && gem_supported) { -      intelScreen->bufmgr = intel_bufmgr_gem_init(spriv->fd, BATCH_SZ); -      if (intelScreen->bufmgr != NULL) -	 intelScreen->ttm = GL_TRUE; -   } +   intelScreen->bufmgr = intel_bufmgr_gem_init(spriv->fd, BATCH_SZ);     /* Otherwise, use the classic buffer manager. */     if (intelScreen->bufmgr == NULL) { -      if (gem_disable) { -	 _mesa_warning(NULL, "GEM disabled.  Using classic."); -      } else { -	 _mesa_warning(NULL, -                       "Failed to initialize GEM.  Falling back to classic."); -      } - -      if (intelScreen->tex.size == 0) { -	 fprintf(stderr, "[%s:%u] Error initializing buffer manager.\n", -		 __func__, __LINE__); -	 return GL_FALSE; -      } - -      intelScreen->bufmgr = -	 intel_bufmgr_fake_init(spriv->fd, -				intelScreen->tex.offset, -				intelScreen->tex.map, -				intelScreen->tex.size, -				(unsigned int * volatile) -				&intelScreen->sarea->last_dispatch); +      fprintf(stderr, "[%s:%u] Error initializing buffer manager.\n", +	      __func__, __LINE__); +      return GL_FALSE;     }     if (intel_get_param(spriv, I915_PARAM_NUM_FENCES_AVAIL, &num_fences)) @@ -668,78 +331,20 @@ intel_init_bufmgr(intelScreenPrivate *intelScreen)  /**   * This is the driver specific part of the createNewScreen entry point. - * Called when using legacy DRI. - *  - * \todo maybe fold this into intelInitDriver - * - * \return the __GLcontextModes supported by this driver - */ -static const __DRIconfig **intelInitScreen(__DRIscreenPrivate *psp) -{ -   intelScreenPrivate *intelScreen; -#ifdef I915 -   static const __DRIversion ddx_expected = { 1, 5, 0 }; -#else -   static const __DRIversion ddx_expected = { 1, 6, 0 }; -#endif -   static const __DRIversion dri_expected = { 4, 0, 0 }; -   static const __DRIversion drm_expected = { 1, 5, 0 }; -   I830DRIPtr dri_priv = (I830DRIPtr) psp->pDevPriv; - -   if (!driCheckDriDdxDrmVersions2("i915", -                                   &psp->dri_version, &dri_expected, -                                   &psp->ddx_version, &ddx_expected, -                                   &psp->drm_version, &drm_expected)) { -      return NULL; -   } - -   if (!intelInitDriver(psp)) -       return NULL; - -   psp->extensions = intelScreenExtensions; - -   intelScreen = psp->private; -   if (!intel_init_bufmgr(intelScreen)) -       return GL_FALSE; - -   return (const __DRIconfig **) -       intelFillInModes(psp, dri_priv->cpp * 8, -			(dri_priv->cpp == 2) ? 16 : 24, -			(dri_priv->cpp == 2) ? 0  : 8, 1); -} - -struct intel_context *intelScreenContext(intelScreenPrivate *intelScreen) -{ -  /* -   * This should probably change to have the screen allocate a dummy -   * context at screen creation. For now just use the current context. -   */ - -  GET_CURRENT_CONTEXT(ctx); -  if (ctx == NULL) { -     _mesa_problem(NULL, "No current context in intelScreenContext\n"); -     return NULL; -  } -  return intel_context(ctx); -} - -/** - * This is the driver specific part of the createNewScreen entry point.   * Called when using DRI2.   *   * \return the __GLcontextModes supported by this driver   */  static const -__DRIconfig **intelInitScreen2(__DRIscreenPrivate *psp) +__DRIconfig **intelInitScreen2(__DRIscreen *psp)  {     intelScreenPrivate *intelScreen;     GLenum fb_format[3];     GLenum fb_type[3]; -   /* GLX_SWAP_COPY_OML is only supported because the Intel driver doesn't -    * support pageflipping at all. -    */ +     static const GLenum back_buffer_modes[] = { -      GLX_NONE, GLX_SWAP_UNDEFINED_OML, GLX_SWAP_COPY_OML +       GLX_NONE, GLX_SWAP_UNDEFINED_OML, +       GLX_SWAP_EXCHANGE_OML, GLX_SWAP_COPY_OML     };     uint8_t depth_bits[4], stencil_bits[4], msaa_samples_array[1];     int color; @@ -839,19 +444,19 @@ __DRIconfig **intelInitScreen2(__DRIscreenPrivate *psp)  }  const struct __DriverAPIRec driDriverAPI = { -   .InitScreen		 = intelInitScreen,     .DestroyScreen	 = intelDestroyScreen,     .CreateContext	 = intelCreateContext,     .DestroyContext	 = intelDestroyContext,     .CreateBuffer	 = intelCreateBuffer,     .DestroyBuffer	 = intelDestroyBuffer, -   .SwapBuffers		 = intelSwapBuffers,     .MakeCurrent		 = intelMakeCurrent,     .UnbindContext	 = intelUnbindContext, -   .GetSwapInfo		 = intelGetSwapInfo, -   .GetDrawableMSC	 = driDrawableGetMSC32, -   .WaitForMSC		 = driWaitForMSC32, -   .CopySubBuffer	 = intelCopySubBuffer, -     .InitScreen2		 = intelInitScreen2,  }; + +/* This is the table of extensions that the loader will dlsym() for. */ +PUBLIC const __DRIextension *__driDriverExtensions[] = { +    &driCoreExtension.base, +    &driDRI2Extension.base, +    NULL +}; diff --git a/src/mesa/drivers/dri/intel/intel_screen.h b/src/mesa/drivers/dri/intel/intel_screen.h index a9b9e109a6..e87e306d86 100644 --- a/src/mesa/drivers/dri/intel/intel_screen.h +++ b/src/mesa/drivers/dri/intel/intel_screen.h @@ -66,7 +66,7 @@ typedef struct     int logTextureGranularity; -   __DRIscreenPrivate *driScrnPriv; +   __DRIscreen *driScrnPriv;     volatile drm_i915_sarea_t *sarea; @@ -77,7 +77,6 @@ typedef struct     GLboolean no_hw;     GLboolean no_vbo; -   int ttm;     dri_bufmgr *bufmgr;     GLboolean kernel_exec_fencing; @@ -89,18 +88,18 @@ typedef struct -extern GLboolean intelMapScreenRegions(__DRIscreenPrivate * sPriv); +extern GLboolean intelMapScreenRegions(__DRIscreen * sPriv);  extern void intelUnmapScreenRegions(intelScreenPrivate * intelScreen); -extern void intelDestroyContext(__DRIcontextPrivate * driContextPriv); +extern void intelDestroyContext(__DRIcontext * driContextPriv); -extern GLboolean intelUnbindContext(__DRIcontextPrivate * driContextPriv); +extern GLboolean intelUnbindContext(__DRIcontext * driContextPriv);  extern GLboolean -intelMakeCurrent(__DRIcontextPrivate * driContextPriv, -                 __DRIdrawablePrivate * driDrawPriv, -                 __DRIdrawablePrivate * driReadPriv); +intelMakeCurrent(__DRIcontext * driContextPriv, +                 __DRIdrawable * driDrawPriv, +                 __DRIdrawable * driReadPriv);  extern struct intel_context *intelScreenContext(intelScreenPrivate *intelScreen); diff --git a/src/mesa/drivers/dri/intel/intel_span.c b/src/mesa/drivers/dri/intel/intel_span.c index 34c3d9df74..605734d8e5 100644 --- a/src/mesa/drivers/dri/intel/intel_span.c +++ b/src/mesa/drivers/dri/intel/intel_span.c @@ -517,7 +517,6 @@ intelSpanRenderStart(GLcontext * ctx)     GLuint i;     intelFlush(&intel->ctx); -   LOCK_HARDWARE(intel);     for (i = 0; i < ctx->Const.MaxTextureImageUnits; i++) {        if (ctx->Texture.Unit[i]._ReallyEnabled) { @@ -553,8 +552,6 @@ intelSpanRenderFinish(GLcontext * ctx)     intel_map_unmap_framebuffer(intel, ctx->DrawBuffer, GL_FALSE);     if (ctx->ReadBuffer != ctx->DrawBuffer)        intel_map_unmap_framebuffer(intel, ctx->ReadBuffer, GL_FALSE); - -   UNLOCK_HARDWARE(intel);  } @@ -613,15 +610,7 @@ intel_set_span_functions(struct intel_context *intel,  			 struct gl_renderbuffer *rb)  {     struct intel_renderbuffer *irb = (struct intel_renderbuffer *) rb; -   uint32_t tiling; - -   /* If in GEM mode, we need to do the tile address swizzling ourselves, -    * instead of the fence registers handling it. -    */ -   if (intel->ttm) -      tiling = irb->region->tiling; -   else -      tiling = I915_TILING_NONE; +   uint32_t tiling = irb->region->tiling;     if (intel->intelScreen->kernel_exec_fencing) {        switch (irb->Base.Format) { @@ -667,6 +656,9 @@ intel_set_span_functions(struct intel_context *intel,        return;     } +   /* If in GEM mode, we need to do the tile address swizzling ourselves, +    * instead of the fence registers handling it. +    */     switch (irb->Base.Format) {     case MESA_FORMAT_RGB565:        switch (tiling) { diff --git a/src/mesa/drivers/dri/intel/intel_state.c b/src/mesa/drivers/dri/intel/intel_state.c index f18e625244..c5ef909dbf 100644 --- a/src/mesa/drivers/dri/intel/intel_state.c +++ b/src/mesa/drivers/dri/intel/intel_state.c @@ -194,25 +194,6 @@ intel_translate_logic_op(GLenum opcode)     }  } - -static void -intelClearColor(GLcontext *ctx, const GLfloat color[4]) -{ -   struct intel_context *intel = intel_context(ctx); -   GLubyte clear[4]; - -   CLAMPED_FLOAT_TO_UBYTE(clear[0], color[0]); -   CLAMPED_FLOAT_TO_UBYTE(clear[1], color[1]); -   CLAMPED_FLOAT_TO_UBYTE(clear[2], color[2]); -   CLAMPED_FLOAT_TO_UBYTE(clear[3], color[3]); - -   /* compute both 32 and 16-bit clear values */ -   intel->ClearColor8888 = INTEL_PACKCOLOR8888(clear[0], clear[1], -                                               clear[2], clear[3]); -   intel->ClearColor565 = INTEL_PACKCOLOR565(clear[0], clear[1], clear[2]); -} - -  /* Fallback to swrast for select and feedback.   */  static void @@ -227,5 +208,4 @@ void  intelInitStateFuncs(struct dd_function_table *functions)  {     functions->RenderMode = intelRenderMode; -   functions->ClearColor = intelClearColor;  } diff --git a/src/mesa/drivers/dri/intel/intel_swapbuffers.c b/src/mesa/drivers/dri/intel/intel_swapbuffers.c deleted file mode 100644 index 5af2f5f1ca..0000000000 --- a/src/mesa/drivers/dri/intel/intel_swapbuffers.c +++ /dev/null @@ -1,247 +0,0 @@ -/************************************************************************** - *  - * Copyright 2003 Tungsten Graphics, Inc., Cedar Park, Texas. - * All Rights Reserved. - *  - * Permission is hereby granted, free of charge, to any person obtaining a - * copy of this software and associated documentation files (the - * "Software"), to deal in the Software without restriction, including - * without limitation the rights to use, copy, modify, merge, publish, - * distribute, sub license, and/or sell copies of the Software, and to - * permit persons to whom the Software is furnished to do so, subject to - * the following conditions: - *  - * The above copyright notice and this permission notice (including the - * next paragraph) shall be included in all copies or substantial portions - * of the Software. - *  - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS - * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. - * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, - * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE - * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - *  - **************************************************************************/ - -#include "intel_blit.h" -#include "intel_buffers.h" -#include "intel_swapbuffers.h" -#include "intel_fbo.h" -#include "drirenderbuffer.h" -#include "vblank.h" -#include "i915_drm.h" - - - -/* - * Correct a drawablePrivate's set of vblank flags WRT the current context. - * When considering multiple crtcs. - */ -GLuint -intelFixupVblank(struct intel_context *intel, __DRIdrawablePrivate *dPriv) -{ -   if (!intel->intelScreen->driScrnPriv->dri2.enabled && -       intel->intelScreen->driScrnPriv->ddx_version.minor >= 7) { -      volatile drm_i915_sarea_t *sarea = intel->sarea; -      drm_clip_rect_t drw_rect = { .x1 = dPriv->x, .x2 = dPriv->x + dPriv->w, -				   .y1 = dPriv->y, .y2 = dPriv->y + dPriv->h }; -      drm_clip_rect_t planeA_rect = { .x1 = sarea->planeA_x, .y1 = sarea->planeA_y, -				     .x2 = sarea->planeA_x + sarea->planeA_w, -				     .y2 = sarea->planeA_y + sarea->planeA_h }; -      drm_clip_rect_t planeB_rect = { .x1 = sarea->planeB_x, .y1 = sarea->planeB_y, -				     .x2 = sarea->planeB_x + sarea->planeB_w, -				     .y2 = sarea->planeB_y + sarea->planeB_h }; -      GLint areaA = driIntersectArea( drw_rect, planeA_rect ); -      GLint areaB = driIntersectArea( drw_rect, planeB_rect ); -      GLuint flags = dPriv->vblFlags; - -      /* Update vblank info -       */ -      if (areaB > areaA || (areaA == areaB && areaB > 0)) { -	 flags = dPriv->vblFlags | VBLANK_FLAG_SECONDARY; -      } else { -	 flags = dPriv->vblFlags & ~VBLANK_FLAG_SECONDARY; -      } - -      /* Do the stupid test: Is one of them actually disabled? -       */ -      if (sarea->planeA_w == 0 || sarea->planeA_h == 0) { -	 flags = dPriv->vblFlags | VBLANK_FLAG_SECONDARY; -      } else if (sarea->planeB_w == 0 || sarea->planeB_h == 0) { -	 flags = dPriv->vblFlags & ~VBLANK_FLAG_SECONDARY; -      } - -      return flags; -   } else { -      return dPriv->vblFlags & ~VBLANK_FLAG_SECONDARY; -   } -} - - -/** - * Called from driSwapBuffers() - */ -void -intelSwapBuffers(__DRIdrawablePrivate * dPriv) -{ -   __DRIscreenPrivate *psp = dPriv->driScreenPriv; - -   if (dPriv->driContextPriv && dPriv->driContextPriv->driverPrivate) { -      GET_CURRENT_CONTEXT(ctx); -      struct intel_context *intel; - -      if (ctx == NULL) -	 return; - -      intel = intel_context(ctx); - -      if (ctx->Visual.doubleBufferMode) { -	 GLboolean missed_target; -	 struct intel_framebuffer *intel_fb = dPriv->driverPrivate; -	 int64_t ust; -          -	 _mesa_notifySwapBuffers(ctx);  /* flush pending rendering comands */ - -	/* -	 * The old swapping ioctl was incredibly racy, just wait for vblank -	 * and do the swap ourselves. -	 */ -	 driWaitForVBlank(dPriv, &missed_target); - -	 /* -	  * Update each buffer's vbl_pending so we don't get too out of -	  * sync -	  */ -	 intel_get_renderbuffer(&intel_fb->Base, -		   		BUFFER_BACK_LEFT)->vbl_pending = dPriv->vblSeq; -         intel_get_renderbuffer(&intel_fb->Base, -		   		BUFFER_FRONT_LEFT)->vbl_pending = dPriv->vblSeq; - -	 intelCopyBuffer(dPriv, NULL); - -	 intel_fb->swap_count++; -	 (*psp->systemTime->getUST) (&ust); -	 if (missed_target) { -	    intel_fb->swap_missed_count++; -	    intel_fb->swap_missed_ust = ust - intel_fb->swap_ust; -	 } - -	 intel_fb->swap_ust = ust; -      } -      drmCommandNone(intel->driFd, DRM_I915_GEM_THROTTLE); -   } -   else { -      /* XXX this shouldn't be an error but we can't handle it for now */ -      fprintf(stderr, "%s: drawable has no context!\n", __FUNCTION__); -   } -} - - -/** - * Called from driCopySubBuffer() - */ -void -intelCopySubBuffer(__DRIdrawablePrivate * dPriv, int x, int y, int w, int h) -{ -   if (dPriv->driContextPriv && dPriv->driContextPriv->driverPrivate) { -      struct intel_context *intel = -         (struct intel_context *) dPriv->driContextPriv->driverPrivate; -      GLcontext *ctx = &intel->ctx; - -      if (ctx->Visual.doubleBufferMode) { -         drm_clip_rect_t rect; -         rect.x1 = x + dPriv->x; -         rect.y1 = (dPriv->h - y - h) + dPriv->y; -         rect.x2 = rect.x1 + w; -         rect.y2 = rect.y1 + h; -         _mesa_notifySwapBuffers(ctx);  /* flush pending rendering comands */ -         intelCopyBuffer(dPriv, &rect); -      } -   } -   else { -      /* XXX this shouldn't be an error but we can't handle it for now */ -      fprintf(stderr, "%s: drawable has no context!\n", __FUNCTION__); -   } -} - - -/** - * This will be called whenever the currently bound window is moved/resized. - * XXX: actually, it seems to NOT be called when the window is only moved (BP). - */ -void -intelWindowMoved(struct intel_context *intel) -{ -   GLcontext *ctx = &intel->ctx; -   __DRIdrawablePrivate *dPriv = intel->driDrawable; -   struct intel_framebuffer *intel_fb = dPriv->driverPrivate; - -   if (!intel->intelScreen->driScrnPriv->dri2.enabled && -       intel->intelScreen->driScrnPriv->ddx_version.minor >= 7) { -      GLuint flags = intelFixupVblank(intel, dPriv); - -      /* Check to see if we changed pipes */ -      if (flags != dPriv->vblFlags && dPriv->vblFlags && -	  !(dPriv->vblFlags & VBLANK_FLAG_NO_IRQ)) { -	 int64_t count; -	 drmVBlank vbl; -	 int i; - -	 /* -	  * Deal with page flipping -	  */ -	 vbl.request.type = DRM_VBLANK_ABSOLUTE; - -	 if ( dPriv->vblFlags & VBLANK_FLAG_SECONDARY ) { -	    vbl.request.type |= DRM_VBLANK_SECONDARY; -	 } - -	 for (i = 0; i < 2; i++) { -	    if (!intel_fb->color_rb[i] || -		(intel_fb->vbl_waited - intel_fb->color_rb[i]->vbl_pending) <= -		(1<<23)) -	       continue; - -	    vbl.request.sequence = intel_fb->color_rb[i]->vbl_pending; -	    drmWaitVBlank(intel->driFd, &vbl); -	 } - -	 /* -	  * Update msc_base from old pipe -	  */ -	 driDrawableGetMSC32(dPriv->driScreenPriv, dPriv, &count); -	 dPriv->msc_base = count; -	 /* -	  * Then get new vblank_base and vblSeq values -	  */ -	 dPriv->vblFlags = flags; -	 driGetCurrentVBlank(dPriv); -	 dPriv->vblank_base = dPriv->vblSeq; - -	 intel_fb->vbl_waited = dPriv->vblSeq; - -	 for (i = 0; i < 2; i++) { -	    if (intel_fb->color_rb[i]) -	       intel_fb->color_rb[i]->vbl_pending = intel_fb->vbl_waited; -	 } -      } -   } else { -      dPriv->vblFlags &= ~VBLANK_FLAG_SECONDARY; -   } - -   /* Update Mesa's notion of window size */ -   driUpdateFramebufferSize(ctx, dPriv); -   intel_fb->Base.Initialized = GL_TRUE; /* XXX remove someday */ - -   /* Update hardware scissor */ -   if (ctx->Driver.Scissor != NULL) { -      ctx->Driver.Scissor(ctx, ctx->Scissor.X, ctx->Scissor.Y, -			  ctx->Scissor.Width, ctx->Scissor.Height); -   } - -   /* Re-calculate viewport related state */ -   if (ctx->Driver.DepthRange != NULL) -      ctx->Driver.DepthRange( ctx, ctx->Viewport.Near, ctx->Viewport.Far ); -} diff --git a/src/mesa/drivers/dri/intel/intel_swapbuffers.h b/src/mesa/drivers/dri/intel/intel_swapbuffers.h deleted file mode 100644 index 75bb6242ff..0000000000 --- a/src/mesa/drivers/dri/intel/intel_swapbuffers.h +++ /dev/null @@ -1,52 +0,0 @@ - -/************************************************************************** - *  - * Copyright 2006 Tungsten Graphics, Inc., Cedar Park, Texas. - * All Rights Reserved. - *  - * Permission is hereby granted, free of charge, to any person obtaining a - * copy of this software and associated documentation files (the - * "Software"), to deal in the Software without restriction, including - * without limitation the rights to use, copy, modify, merge, publish, - * distribute, sub license, and/or sell copies of the Software, and to - * permit persons to whom the Software is furnished to do so, subject to - * the following conditions: - *  - * The above copyright notice and this permission notice (including the - * next paragraph) shall be included in all copies or substantial portions - * of the Software. - *  - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS - * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. - * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR - * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, - * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE - * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - *  - **************************************************************************/ - -#ifndef INTEL_SWAPBUFFERS_H -#define INTEL_SWAPBUFFERS_H - -#include "dri_util.h" -#include "drm.h" - -struct intel_context; -struct intel_framebuffer; - - -extern void -intelSwapBuffers(__DRIdrawablePrivate * dPriv); - -extern void -intelCopySubBuffer(__DRIdrawablePrivate * dPriv, int x, int y, int w, int h); - -extern GLuint -intelFixupVblank(struct intel_context *intel, __DRIdrawablePrivate *dPriv); - -extern void -intelWindowMoved(struct intel_context *intel); - - -#endif /* INTEL_SWAPBUFFERS_H */ diff --git a/src/mesa/drivers/dri/intel/intel_tex_copy.c b/src/mesa/drivers/dri/intel/intel_tex_copy.c index a80cab31f3..79994b4a6a 100644 --- a/src/mesa/drivers/dri/intel/intel_tex_copy.c +++ b/src/mesa/drivers/dri/intel/intel_tex_copy.c @@ -109,7 +109,6 @@ do_copy_texsubimage(struct intel_context *intel,     }     /* intelFlush(ctx); */ -   LOCK_HARDWARE(intel);     {        drm_intel_bo *dst_bo = intel_region_buffer(intel,  						 intelImage->mt->region, @@ -131,13 +130,12 @@ do_copy_texsubimage(struct intel_context *intel,        /* Can't blit to tiled buffers with non-tile-aligned offset. */        if (intelImage->mt->region->tiling == I915_TILING_Y) { -	 UNLOCK_HARDWARE(intel);  	 return GL_FALSE;        }        if (ctx->ReadBuffer->Name == 0) {  	 /* reading from a window, adjust x, y */ -	 const __DRIdrawablePrivate *dPriv = intel->driReadDrawable; +	 const __DRIdrawable *dPriv = intel->driReadDrawable;  	 y = dPriv->y + (dPriv->h - (y + height));  	 x += dPriv->x; @@ -169,13 +167,10 @@ do_copy_texsubimage(struct intel_context *intel,  			     image_x + dstx, image_y + dsty,  			     width, height,  			     GL_COPY)) { -	 UNLOCK_HARDWARE(intel);  	 return GL_FALSE;        }     } -   UNLOCK_HARDWARE(intel); -     return GL_TRUE;  } diff --git a/src/mesa/drivers/dri/intel/intel_tex_format.c b/src/mesa/drivers/dri/intel/intel_tex_format.c index 87efb72cc5..a7c6c45ffe 100644 --- a/src/mesa/drivers/dri/intel/intel_tex_format.c +++ b/src/mesa/drivers/dri/intel/intel_tex_format.c @@ -173,13 +173,13 @@ intelChooseTextureFormat(GLcontext * ctx, GLint internalFormat,        return MESA_FORMAT_SARGB8;     case GL_SLUMINANCE_EXT:     case GL_SLUMINANCE8_EXT: -      if (IS_G4X(intel->intelScreen->deviceID)) +      if (intel->has_luminance_srgb)           return MESA_FORMAT_SL8;        else           return MESA_FORMAT_SARGB8;     case GL_SLUMINANCE_ALPHA_EXT:     case GL_SLUMINANCE8_ALPHA8_EXT: -      if (IS_G4X(intel->intelScreen->deviceID)) +      if (intel->has_luminance_srgb)           return MESA_FORMAT_SLA8;        else           return MESA_FORMAT_SARGB8; diff --git a/src/mesa/drivers/dri/intel/intel_tex_image.c b/src/mesa/drivers/dri/intel/intel_tex_image.c index fe4806c00a..f5d0dabebb 100644 --- a/src/mesa/drivers/dri/intel/intel_tex_image.c +++ b/src/mesa/drivers/dri/intel/intel_tex_image.c @@ -234,7 +234,6 @@ try_pbo_upload(struct intel_context *intel,     if (drm_intel_bo_references(intel->batch->buf, dst_buffer))        intelFlush(&intel->ctx); -   LOCK_HARDWARE(intel);     {        dri_bo *src_buffer = intel_bufferobj_buffer(intel, pbo, INTEL_READ); @@ -244,11 +243,9 @@ try_pbo_upload(struct intel_context *intel,  			     dst_stride, dst_buffer, 0, GL_FALSE,  			     0, 0, dst_x, dst_y, width, height,  			     GL_COPY)) { -	 UNLOCK_HARDWARE(intel);  	 return GL_FALSE;        }     } -   UNLOCK_HARDWARE(intel);     return GL_TRUE;  } @@ -468,8 +465,6 @@ intelTexImage(GLcontext * ctx,  					   pixels, unpack, "glTexImage");     } -   LOCK_HARDWARE(intel); -     if (intelImage->mt) {        if (pixels != NULL) {  	 /* Flush any queued rendering with the texture before mapping. */ @@ -550,8 +545,6 @@ intelTexImage(GLcontext * ctx,           intel_miptree_image_unmap(intel, intelImage->mt);        texImage->Data = NULL;     } - -   UNLOCK_HARDWARE(intel);  } @@ -731,7 +724,7 @@ intelSetTexBuffer2(__DRIcontext *pDRICtx, GLint target,  		   GLint glx_texture_format,  		   __DRIdrawable *dPriv)  { -   struct intel_framebuffer *intel_fb = dPriv->driverPrivate; +   struct gl_framebuffer *fb = dPriv->driverPrivate;     struct intel_context *intel = pDRICtx->driverPrivate;     GLcontext *ctx = &intel->ctx;     struct intel_texture_object *intelObj; @@ -748,9 +741,10 @@ intelSetTexBuffer2(__DRIcontext *pDRICtx, GLint target,     if (!intelObj)        return; -   intel_update_renderbuffers(pDRICtx, dPriv); +   if (!dPriv->validBuffers) +      intel_update_renderbuffers(pDRICtx, dPriv); -   rb = intel_fb->color_rb[0]; +   rb = intel_get_renderbuffer(fb, BUFFER_FRONT_LEFT);     /* If the region isn't set, then intel_update_renderbuffers was unable      * to get the buffers for the drawable.      */ diff --git a/src/mesa/drivers/dri/intel/intel_tex_subimage.c b/src/mesa/drivers/dri/intel/intel_tex_subimage.c index 1f68208266..7f1dc89022 100644 --- a/src/mesa/drivers/dri/intel/intel_tex_subimage.c +++ b/src/mesa/drivers/dri/intel/intel_tex_subimage.c @@ -72,8 +72,6 @@ intelTexSubimage(GLcontext * ctx,     if (!pixels)        return; -   LOCK_HARDWARE(intel); -     /* Map buffer if necessary.  Need to lock to prevent other contexts      * from uploading the buffer under us.      */ @@ -129,8 +127,6 @@ intelTexSubimage(GLcontext * ctx,        intel_miptree_image_unmap(intel, intelImage->mt);        texImage->Data = NULL;     } - -   UNLOCK_HARDWARE(intel);  } | 
