void r200FlushElts(struct gl_context *ctx) { r200ContextPtr rmesa = R200_CONTEXT(ctx); int nr, elt_used = rmesa->tcl.elt_used; radeon_print(RADEON_RENDER, RADEON_VERBOSE, "%s %x %d\n", __FUNCTION__, rmesa->tcl.hw_primitive, elt_used); assert( rmesa->radeon.dma.flush == r200FlushElts ); rmesa->radeon.dma.flush = NULL; nr = elt_used / 2; radeon_bo_unmap(rmesa->radeon.tcl.elt_dma_bo); r200FireEB(rmesa, nr, rmesa->tcl.hw_primitive); radeon_bo_unref(rmesa->radeon.tcl.elt_dma_bo); rmesa->radeon.tcl.elt_dma_bo = NULL; if (R200_ELT_BUF_SZ > elt_used) radeonReturnDmaRegion(&rmesa->radeon, R200_ELT_BUF_SZ - elt_used); if (radeon_is_debug_enabled(RADEON_SYNC, RADEON_CRITICAL) && !rmesa->radeon.radeonScreen->kernel_mm) { radeon_print(RADEON_SYNC, RADEON_NORMAL, "%s: Syncing\n", __FUNCTION__); radeonFinish( rmesa->radeon.glCtx ); } }
/** * Checks whether the given miptree has the right format to store the given texture object. */ static GLboolean radeon_miptree_matches_texture(radeon_mipmap_tree *mt, struct gl_texture_object *texObj) { struct gl_texture_image *firstImage; unsigned numLevels; radeon_mipmap_level *mtBaseLevel; if (texObj->BaseLevel < mt->baseLevel) return GL_FALSE; mtBaseLevel = &mt->levels[texObj->BaseLevel - mt->baseLevel]; firstImage = texObj->Image[0][texObj->BaseLevel]; numLevels = MIN2(texObj->_MaxLevel - texObj->BaseLevel + 1, firstImage->MaxNumLevels); if (radeon_is_debug_enabled(RADEON_TEXTURE,RADEON_TRACE)) { fprintf(stderr, "Checking if miptree %p matches texObj %p\n", mt, texObj); fprintf(stderr, "target %d vs %d\n", mt->target, texObj->Target); fprintf(stderr, "format %d vs %d\n", mt->mesaFormat, firstImage->TexFormat); fprintf(stderr, "numLevels %d vs %d\n", mt->numLevels, numLevels); fprintf(stderr, "width0 %d vs %d\n", mtBaseLevel->width, firstImage->Width); fprintf(stderr, "height0 %d vs %d\n", mtBaseLevel->height, firstImage->Height); fprintf(stderr, "depth0 %d vs %d\n", mtBaseLevel->depth, firstImage->Depth); if (mt->target == texObj->Target && mt->mesaFormat == firstImage->TexFormat && mt->numLevels >= numLevels && mtBaseLevel->width == firstImage->Width && mtBaseLevel->height == firstImage->Height && mtBaseLevel->depth == firstImage->Depth) { fprintf(stderr, "MATCHED\n"); } else { fprintf(stderr, "NOT MATCHED\n"); } } return (mt->target == texObj->Target && mt->mesaFormat == firstImage->TexFormat && mt->numLevels >= numLevels && mtBaseLevel->width == firstImage->Width && mtBaseLevel->height == firstImage->Height && mtBaseLevel->depth == firstImage->Depth); }