[Mesa-dev] [PATCH] r300/compiler: recursive look for RC_OPCODE_S**

Tom Stellard tom at stellard.net
Fri Aug 1 07:55:45 PDT 2014


On Fri, Aug 01, 2014 at 03:55:56PM +0200, Marek Olšák wrote:
> From: David Heidelberger <david.heidelberger at ixit.cz>
> 
> Get rid of error "Failed to build loop info" by fixing failure in cases
> like
> 4:   SGE temp[2].x, temp[0].xxxx, const[0].wwww;
> 5:   CMP temp[1].x, -temp[2].xxxx, const[0].zzzz, temp[1].xxxx;
> 6:   IF temp[1].xxxx;
> 
> On RS690
>  - fixes piglit glean "do-loop with continue and break"
>  - changes error from Failed to build loop info ->
>    Not a native swizzle: 00000e89
>    r300_fragprog_emit.c::begin_tex(): Too many texture indirections
>    for "discard statement in for loop"
>  - hide Failed to build loop info for
>    "precision log2", "while-loop with continue",
>    "for-loop with continue" and return "1 1 1 1" insted of "0 0 0 1"
> 
> Signed-off-by: David Heidelberger <david.heidelberger at ixit.cz>
> ---
> 
> I'm sending this on behalf of David. I'll commit it soon if there is no review.
> 
>  .../drivers/r300/compiler/radeon_emulate_loops.c   | 27 +++++++++++++---------
>  1 file changed, 16 insertions(+), 11 deletions(-)
> 
> diff --git a/src/gallium/drivers/r300/compiler/radeon_emulate_loops.c b/src/gallium/drivers/r300/compiler/radeon_emulate_loops.c
> index 91ed9d2..d1fae9a 100644
> --- a/src/gallium/drivers/r300/compiler/radeon_emulate_loops.c
> +++ b/src/gallium/drivers/r300/compiler/radeon_emulate_loops.c
> @@ -376,18 +376,23 @@ static int build_loop_info(struct radeon_compiler * c, struct loop_info * loop,
>  			loop->Brk = ptr;
>  			loop->If = ptr->Prev;
>  			loop->EndIf = ptr->Next;
> -			switch(loop->If->Prev->U.I.Opcode){
> -			case RC_OPCODE_SLT:
> -			case RC_OPCODE_SGE:
> -			case RC_OPCODE_SGT:
> -			case RC_OPCODE_SLE:
> -			case RC_OPCODE_SEQ:
> -			case RC_OPCODE_SNE:
> -				break;
> -			default:
> -				return 0;
> -			}
> +
>  			loop->Cond = loop->If->Prev;
> +			while (loop->Cond->U.I.Opcode != RC_OPCODE_BGNLOOP) {
> +				switch(loop->Cond->U.I.Opcode){
> +					case RC_OPCODE_SLT:
> +					case RC_OPCODE_SGE:
> +					case RC_OPCODE_SGT:
> +					case RC_OPCODE_SLE:
> +					case RC_OPCODE_SEQ:
> +					case RC_OPCODE_SNE:
> +						goto found;
> +					default:

You can't just look for any S* instruction here, you need to look for
the one that is defining the register used by IF.  I know I posted a patch
that does this, but I forgot what the problem was with it.

-Tom

> +						loop->Cond = loop->Cond->Prev;
> +						break;
> +				}
> +			}
> +			found:
>  			break;
>  
>  		case RC_OPCODE_ENDLOOP:
> -- 
> 1.9.1
> 
> _______________________________________________
> mesa-dev mailing list
> mesa-dev at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/mesa-dev


More information about the mesa-dev mailing list