mesa: Branch 'master'

Oliver McFadden z3ro at kemper.freedesktop.org
Thu Mar 15 19:50:28 UTC 2007


 src/mesa/drivers/dri/r300/r300_fragprog.c   |   10 ++++------
 src/mesa/drivers/dri/r300/r300_vertexprog.c |   15 +++++++--------
 2 files changed, 11 insertions(+), 14 deletions(-)

New commits:
diff-tree 0e9ada1087a58af4c1375cc35b318aa0521d3a72 (from 0d6d80ef3dbd39ed346c3189385242016f5aed74)
Author: Oliver McFadden <z3ro.geek at gmail.com>
Date:   Thu Mar 15 19:49:10 2007 +0000

    r300: Use _mesa_alloc_instructions/_mesa_init_instructions instead of malloc.
    
    Note that insert_wpos in r300_vertexprog.c is still a little flaky and could be
    improved.

diff --git a/src/mesa/drivers/dri/r300/r300_fragprog.c b/src/mesa/drivers/dri/r300/r300_fragprog.c
index 82fb5b6..e05abdb 100644
--- a/src/mesa/drivers/dri/r300/r300_fragprog.c
+++ b/src/mesa/drivers/dri/r300/r300_fragprog.c
@@ -1798,12 +1798,8 @@ static void insert_wpos(struct gl_progra
 	/* should do something else if no temps left... */
 	prog->NumTemporaries++;
 
-	
-	fpi = malloc((prog->NumInstructions + 3) * sizeof(struct prog_instruction));
-	/* all including END */
-	memcpy(&fpi[3], prog->Instructions, prog->NumInstructions * sizeof(struct prog_instruction));
-	
-	memset(fpi, 0, 3 * sizeof(struct prog_instruction));
+	fpi = _mesa_alloc_instructions (prog->NumInstructions + 3);
+	_mesa_init_instructions (fpi, prog->NumInstructions + 3);
 
 	/* perspective divide */
 	fpi[i].Opcode = OPCODE_RCP;
@@ -1857,6 +1853,8 @@ static void insert_wpos(struct gl_progra
 	fpi[i].SrcReg[2].Swizzle = MAKE_SWIZZLE4(SWIZZLE_X, SWIZZLE_Y, SWIZZLE_Z, SWIZZLE_ZERO);
 	i++;
 
+	_mesa_memcpy(&fpi[i], prog->Instructions, prog->NumInstructions * sizeof(struct prog_instruction));
+
 	free(prog->Instructions);
 
 	prog->Instructions = fpi;
diff --git a/src/mesa/drivers/dri/r300/r300_vertexprog.c b/src/mesa/drivers/dri/r300/r300_vertexprog.c
index 9257ff4..0c43270 100644
--- a/src/mesa/drivers/dri/r300/r300_vertexprog.c
+++ b/src/mesa/drivers/dri/r300/r300_vertexprog.c
@@ -889,8 +889,8 @@ static void position_invariant(struct gl
 #endif
 	paramList = prog->Parameters;
 
-	vpi = malloc((prog->NumInstructions + 4) * sizeof(struct prog_instruction));
-	memset(vpi, 0, 4 * sizeof(struct prog_instruction));
+	vpi = _mesa_alloc_instructions (prog->NumInstructions + 4);
+	_mesa_init_instructions (vpi, prog->NumInstructions + 4);
 
 	for (i=0; i < 4; i++) {
 		GLint idx;
@@ -946,7 +946,7 @@ static void position_invariant(struct gl
 #endif					
 	}
 
-	memcpy(&vpi[i], prog->Instructions, prog->NumInstructions * sizeof(struct prog_instruction));
+	_mesa_memcpy(&vpi[i], prog->Instructions, prog->NumInstructions * sizeof(struct prog_instruction));
 
 	free(prog->Instructions);
 
@@ -966,15 +966,14 @@ static void insert_wpos(struct r300_vert
 	struct prog_instruction *vpi_insert;
 	int i = 0;
 	
-	vpi = malloc((prog->NumInstructions + 2) * sizeof(struct prog_instruction));
+	vpi = _mesa_alloc_instructions (prog->NumInstructions + 2);
+	_mesa_init_instructions (vpi, prog->NumInstructions + 2);
 	/* all but END */
-	memcpy(vpi, prog->Instructions, (prog->NumInstructions - 1) * sizeof(struct prog_instruction));
+	_mesa_memcpy(vpi, prog->Instructions, (prog->NumInstructions - 1) * sizeof(struct prog_instruction));
 	/* END */
-	memcpy(&vpi[prog->NumInstructions + 1], &prog->Instructions[prog->NumInstructions - 1],
+	_mesa_memcpy(&vpi[prog->NumInstructions + 1], &prog->Instructions[prog->NumInstructions - 1],
 		sizeof(struct prog_instruction));
-	
 	vpi_insert = &vpi[prog->NumInstructions - 1];
-	memset(vpi_insert, 0, 2 * sizeof(struct prog_instruction));
 
 	vpi_insert[i].Opcode = OPCODE_MOV;
 



More information about the mesa-commit mailing list