diff options
| author | Eric Anholt <eric@anholt.net> | 2010-08-04 19:55:52 -0700 | 
|---|---|---|
| committer | Eric Anholt <eric@anholt.net> | 2010-08-04 20:52:33 -0700 | 
| commit | 72fd0568db0ce5f25a1eee0266ec1e7cb3dafab0 (patch) | |
| tree | 5256514e227cdfd2aaced8852b16056611448759 /src/mesa | |
| parent | 455290e4281bf53ce2fe248a2adf5163563c44c8 (diff) | |
i965: Settle on printing our program debug to stdout.
Mixing stderr (_mesa_print_program, _mesa_print_instruction,
_mesa_print_alu) with stdout means that when writing both to a file,
there isn't a consistent ordering between the two.
Diffstat (limited to 'src/mesa')
| -rw-r--r-- | src/mesa/drivers/dri/i965/brw_vs.c | 8 | ||||
| -rw-r--r-- | src/mesa/drivers/dri/i965/brw_vs_emit.c | 3 | ||||
| -rw-r--r-- | src/mesa/drivers/dri/i965/brw_wm_fp.c | 10 | ||||
| -rw-r--r-- | src/mesa/program/prog_print.c | 32 | ||||
| -rw-r--r-- | src/mesa/program/prog_print.h | 7 | 
5 files changed, 34 insertions, 26 deletions
| diff --git a/src/mesa/drivers/dri/i965/brw_vs.c b/src/mesa/drivers/dri/i965/brw_vs.c index 9a832af9a9..9f90e1e5e5 100644 --- a/src/mesa/drivers/dri/i965/brw_vs.c +++ b/src/mesa/drivers/dri/i965/brw_vs.c @@ -75,10 +75,10 @@ static void do_vs_prog( struct brw_context *brw,  	 c.prog_data.outputs_written |= BITFIELD64_BIT(VERT_RESULT_TEX0 + i);     } -   if (0) -      _mesa_print_program(&c.vp->program.Base); - - +   if (0) { +      _mesa_fprint_program_opt(stdout, &c.vp->program.Base, PROG_PRINT_DEBUG, +			       GL_TRUE); +   }     /* Emit GEN4 code.      */ diff --git a/src/mesa/drivers/dri/i965/brw_vs_emit.c b/src/mesa/drivers/dri/i965/brw_vs_emit.c index c1d6525e9b..d2bd2c7f79 100644 --- a/src/mesa/drivers/dri/i965/brw_vs_emit.c +++ b/src/mesa/drivers/dri/i965/brw_vs_emit.c @@ -1564,7 +1564,8 @@ void brw_vs_emit(struct brw_vs_compile *c )     if (INTEL_DEBUG & DEBUG_VS) {        printf("vs-mesa:\n"); -      _mesa_print_program(&c->vp->program.Base);  +      _mesa_fprint_program_opt(stdout, &c->vp->program.Base, PROG_PRINT_DEBUG, +			       GL_TRUE);        printf("\n");     } diff --git a/src/mesa/drivers/dri/i965/brw_wm_fp.c b/src/mesa/drivers/dri/i965/brw_wm_fp.c index df9e54c6b4..3870bf10fc 100644 --- a/src/mesa/drivers/dri/i965/brw_wm_fp.c +++ b/src/mesa/drivers/dri/i965/brw_wm_fp.c @@ -1037,13 +1037,12 @@ static void print_insns( const struct prog_instruction *insn,     for (i = 0; i < nr; i++, insn++) {        printf("%3d: ", i);        if (insn->Opcode < MAX_OPCODE) -	 _mesa_print_instruction(insn); +	 _mesa_fprint_instruction_opt(stdout, insn, 0, PROG_PRINT_DEBUG, NULL);        else if (insn->Opcode < MAX_WM_OPCODE) {  	 GLuint idx = insn->Opcode - MAX_OPCODE; -	 _mesa_print_alu_instruction(insn, -				     wm_opcode_strings[idx], -				     3); +	 _mesa_fprint_alu_instruction(stdout, insn, wm_opcode_strings[idx], +				      3, PROG_PRINT_DEBUG, NULL);        }        else   	 printf("965 Opcode %d\n", insn->Opcode); @@ -1062,7 +1061,8 @@ void brw_wm_pass_fp( struct brw_wm_compile *c )     if (INTEL_DEBUG & DEBUG_WM) {        printf("pre-fp:\n"); -      _mesa_print_program(&fp->program.Base);  +      _mesa_fprint_program_opt(stdout, &fp->program.Base, PROG_PRINT_DEBUG, +			       GL_TRUE);        printf("\n");     } diff --git a/src/mesa/program/prog_print.c b/src/mesa/program/prog_print.c index b66d709d50..1ce1bf2f4e 100644 --- a/src/mesa/program/prog_print.c +++ b/src/mesa/program/prog_print.c @@ -540,12 +540,12 @@ fprint_comment(FILE *f, const struct prog_instruction *inst)  } -static void -fprint_alu_instruction(FILE *f, -                       const struct prog_instruction *inst, -                       const char *opcode_string, GLuint numRegs, -                       gl_prog_print_mode mode, -                       const struct gl_program *prog) +void +_mesa_fprint_alu_instruction(FILE *f, +			     const struct prog_instruction *inst, +			     const char *opcode_string, GLuint numRegs, +			     gl_prog_print_mode mode, +			     const struct gl_program *prog)  {     GLuint j; @@ -582,8 +582,8 @@ void  _mesa_print_alu_instruction(const struct prog_instruction *inst,                              const char *opcode_string, GLuint numRegs)  { -   fprint_alu_instruction(stderr, inst, opcode_string, -                          numRegs, PROG_PRINT_DEBUG, NULL); +   _mesa_fprint_alu_instruction(stderr, inst, opcode_string, +				numRegs, PROG_PRINT_DEBUG, NULL);  } @@ -791,16 +791,16 @@ _mesa_fprint_instruction_opt(FILE *f,     default:        if (inst->Opcode < MAX_OPCODE) {           /* typical alu instruction */ -         fprint_alu_instruction(f, inst, -                                _mesa_opcode_string(inst->Opcode), -                                _mesa_num_inst_src_regs(inst->Opcode), -                                mode, prog); +         _mesa_fprint_alu_instruction(f, inst, +				      _mesa_opcode_string(inst->Opcode), +				      _mesa_num_inst_src_regs(inst->Opcode), +				      mode, prog);        }        else { -         fprint_alu_instruction(f, inst, -                                _mesa_opcode_string(inst->Opcode), -                                3/*_mesa_num_inst_src_regs(inst->Opcode)*/, -                                mode, prog); +         _mesa_fprint_alu_instruction(f, inst, +				      _mesa_opcode_string(inst->Opcode), +				      3/*_mesa_num_inst_src_regs(inst->Opcode)*/, +				      mode, prog);        }        break;     } diff --git a/src/mesa/program/prog_print.h b/src/mesa/program/prog_print.h index 9ab7456016..4ffd5ab96c 100644 --- a/src/mesa/program/prog_print.h +++ b/src/mesa/program/prog_print.h @@ -56,6 +56,13 @@ extern void  _mesa_print_swizzle(GLuint swizzle);  extern void +_mesa_fprint_alu_instruction(FILE *f, +			     const struct prog_instruction *inst, +			     const char *opcode_string, GLuint numRegs, +			     gl_prog_print_mode mode, +			     const struct gl_program *prog); + +extern void  _mesa_print_alu_instruction(const struct prog_instruction *inst,                              const char *opcode_string, GLuint numRegs); | 
