[t_vp_build] Fix refcounting-related memory leak
authorNicolai Haehnle <nhaehnle@gmail.com>
Sat, 31 May 2008 22:10:45 +0000 (00:10 +0200)
committerNicolai Haehnle <nhaehnle@gmail.com>
Mon, 2 Jun 2008 16:42:52 +0000 (18:42 +0200)
This memory leak is identical to the earlier one in texenvprogram.
Fixed by not creating an additional reference to new programs in cache_item.

On top of that, remove some duplicated state setting.

src/mesa/tnl/t_vp_build.c

index 46446d48859c2d7b552717c808fb950302bc5462..d79f84f1eb48327b26ed96cf8e3cc347c1887fdf 100644 (file)
@@ -1511,7 +1511,8 @@ static void cache_item( GLcontext *ctx,
    struct tnl_cache_item *c = CALLOC_STRUCT(tnl_cache_item);
    c->hash = hash;
    c->key = key;
-   _mesa_reference_vertprog(ctx, &c->prog, prog);
+
+   c->prog = prog;
 
    if (++cache->n_items > cache->size * 1.5)
       rehash(cache);
@@ -1569,9 +1570,8 @@ void _tnl_UpdateFixedFunctionProgram( GLcontext *ctx )
            ctx->Driver.ProgramStringNotify( ctx, GL_VERTEX_PROGRAM_ARB, 
                                              &newProg->Base );
 
+         /* Our ownership of newProg is transferred to the cache */
         cache_item(ctx, tnl->vp_cache, hash, key, newProg);
-
-         _mesa_reference_vertprog(ctx, &ctx->VertexProgram._TnlProgram, newProg);
       }
       else {
         FREE(key);