From e294d938f261527ba72f82fe3952ba261d131845 Mon Sep 17 00:00:00 2001 From: Aapo Tahkola Date: Thu, 9 Mar 2006 04:42:45 +0000 Subject: Use the force Luke, use the force. --- src/mesa/drivers/dri/r300/r300_ioctl.c | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) (limited to 'src/mesa') diff --git a/src/mesa/drivers/dri/r300/r300_ioctl.c b/src/mesa/drivers/dri/r300/r300_ioctl.c index d807953506..078ff35397 100644 --- a/src/mesa/drivers/dri/r300/r300_ioctl.c +++ b/src/mesa/drivers/dri/r300/r300_ioctl.c @@ -626,8 +626,19 @@ void r300RefillCurrentDmaRegion(r300ContextPtr rmesa) dmabuf->id = radeon_mm_alloc(rmesa, 4, RADEON_BUFFER_SIZE*16); if (dmabuf->id == 0) { - WARN_ONCE("Whops! Dont know how to evict VBOs yet.\n"); - exit(1); + LOCK_HARDWARE(&rmesa->radeon); /* no need to validate */ + + r300FlushCmdBufLocked(rmesa, __FUNCTION__); + radeonWaitForIdleLocked(&rmesa->radeon); + + dmabuf->id = radeon_mm_alloc(rmesa, 4, RADEON_BUFFER_SIZE*16); + + UNLOCK_HARDWARE(&rmesa->radeon); + + if (dmabuf->id == 0) { + WARN_ONCE("Whops! Dont know how to evict VBOs yet.\n"); + exit(1); + } } rmesa->dma.current.buf = dmabuf; -- cgit v1.2.3