diff options
author | Felix Kuehling <[email protected]> | 2004-03-24 16:15:28 +0000 |
---|---|---|
committer | Felix Kuehling <[email protected]> | 2004-03-24 16:15:28 +0000 |
commit | 67d03433772867abc23272c9cf323b15285dde47 (patch) | |
tree | 0b4c5df93786cb097da5eed60e39141e530bfd71 /src/mesa/drivers/dri/savage/savageioctl.c | |
parent | fda7215db36ddee1900cab38b1435f1d73ac7858 (diff) |
Buffer vertices and emit them in batches. Still using conventional drawing
commands, no vertex DMA.
Diffstat (limited to 'src/mesa/drivers/dri/savage/savageioctl.c')
-rw-r--r-- | src/mesa/drivers/dri/savage/savageioctl.c | 37 |
1 files changed, 31 insertions, 6 deletions
diff --git a/src/mesa/drivers/dri/savage/savageioctl.c b/src/mesa/drivers/dri/savage/savageioctl.c index 95cbeecbfa2..8b946195c3b 100644 --- a/src/mesa/drivers/dri/savage/savageioctl.c +++ b/src/mesa/drivers/dri/savage/savageioctl.c @@ -244,9 +244,9 @@ static void savageDDClear( GLcontext *ctx, GLbitfield mask, GLboolean all, clear.clear_depth = (GLuint) (ctx->Depth.Clear * DEPTH_SCALE_16); else clear.clear_depth = (GLuint) (ctx->Depth.Clear * DEPTH_SCALE_24); -#if 0 + FLUSH_BATCH( imesa ); -#endif + if ((mask & DD_FRONT_LEFT_BIT) && ((colorMask&0xffffffUL)==0xffffffUL) ){ clear.flags |= SAVAGE_FRONT; mask &= ~DD_FRONT_LEFT_BIT; @@ -346,6 +346,8 @@ void savageSwapBuffers( __DRIdrawablePrivate *dPriv ) if (imesa->IsDouble) _mesa_notifySwapBuffers( imesa->glCtx ); + FLUSH_BATCH(imesa); + LOCK_HARDWARE( imesa ); PAGE_PENDING(pending); @@ -397,15 +399,29 @@ void savageWaitAge( savageContextPtr imesa, int age ) -void savageFlushVertices( savageContextPtr imesa ) +void savageFlushVerticesLocked( savageContextPtr imesa ) { + drmBufPtr buffer = imesa->vertex_dma_buffer; + + if (!buffer) + return; + + imesa->vertex_dma_buffer = NULL; + /* Lot's of stuff to do here. For now there is a fake DMA implementation + * in savagedma.c that emits drawing commands. Cliprects are not handled + * yet. */ + if (buffer->used) { + savageFakeVertices (imesa, buffer); + } } -void savageFlushVerticesLocked( savageContextPtr imesa ) +void savageFlushVertices( savageContextPtr imesa ) { - + LOCK_HARDWARE(imesa); + savageFlushVerticesLocked (imesa); + UNLOCK_HARDWARE(imesa); } @@ -416,11 +432,20 @@ int savage_check_copy(int fd) static void savageDDFlush( GLcontext *ctx ) { - + savageContextPtr imesa = SAVAGE_CONTEXT(ctx); + LOCK_HARDWARE(imesa); + savageFlushVerticesLocked (imesa); + savageDMAFlush (imesa); + UNLOCK_HARDWARE(imesa); } static void savageDDFinish( GLcontext *ctx ) { + savageContextPtr imesa = SAVAGE_CONTEXT(ctx); + LOCK_HARDWARE(imesa); + savageFlushVerticesLocked (imesa); + savageDmaFinish (imesa); + UNLOCK_HARDWARE(imesa); } #define ALT_STATUS_WORD0 (* (volatile GLuint *)(imesa->MMIO_BASE+0x48c60)) |