mirror of
				https://gitlab.winehq.org/wine/vkd3d.git
				synced 2025-09-12 18:50:22 -07:00 
			
		
		
		
	vkd3d-shader/hlsl: Support discard for SM1.
This commit is contained in:
		
				
				Notes:
				
					Henri Verbeet
				
				2024-10-22 20:54:35 +02:00 
			
			Approved-by: Elizabeth Figura (@zfigura) Approved-by: Henri Verbeet (@hverbeet) Merge-Request: https://gitlab.winehq.org/wine/vkd3d/-/merge_requests/1198
| @@ -4079,6 +4079,44 @@ static bool lower_discard_neg(struct hlsl_ctx *ctx, struct hlsl_ir_node *instr, | |||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | static bool lower_discard_nz(struct hlsl_ctx *ctx, struct hlsl_ir_node *instr, void *context) | ||||||
|  | { | ||||||
|  |     struct hlsl_ir_node *cond, *cond_cast, *abs, *neg; | ||||||
|  |     struct hlsl_type *float_type; | ||||||
|  |     struct hlsl_ir_jump *jump; | ||||||
|  |     struct hlsl_block block; | ||||||
|  |  | ||||||
|  |     if (instr->type != HLSL_IR_JUMP) | ||||||
|  |         return false; | ||||||
|  |     jump = hlsl_ir_jump(instr); | ||||||
|  |     if (jump->type != HLSL_IR_JUMP_DISCARD_NZ) | ||||||
|  |         return false; | ||||||
|  |  | ||||||
|  |     cond = jump->condition.node; | ||||||
|  |     float_type = hlsl_get_vector_type(ctx, HLSL_TYPE_FLOAT, cond->data_type->dimx); | ||||||
|  |  | ||||||
|  |     hlsl_block_init(&block); | ||||||
|  |  | ||||||
|  |     if (!(cond_cast = hlsl_new_cast(ctx, cond, float_type, &instr->loc))) | ||||||
|  |         return false; | ||||||
|  |     hlsl_block_add_instr(&block, cond_cast); | ||||||
|  |  | ||||||
|  |     if (!(abs = hlsl_new_unary_expr(ctx, HLSL_OP1_ABS, cond_cast, &instr->loc))) | ||||||
|  |         return false; | ||||||
|  |     hlsl_block_add_instr(&block, abs); | ||||||
|  |  | ||||||
|  |     if (!(neg = hlsl_new_unary_expr(ctx, HLSL_OP1_NEG, abs, &instr->loc))) | ||||||
|  |         return false; | ||||||
|  |     hlsl_block_add_instr(&block, neg); | ||||||
|  |  | ||||||
|  |     list_move_tail(&instr->entry, &block.instrs); | ||||||
|  |     hlsl_src_remove(&jump->condition); | ||||||
|  |     hlsl_src_from_node(&jump->condition, neg); | ||||||
|  |     jump->type = HLSL_IR_JUMP_DISCARD_NEG; | ||||||
|  |  | ||||||
|  |     return true; | ||||||
|  | } | ||||||
|  |  | ||||||
| static bool dce(struct hlsl_ctx *ctx, struct hlsl_ir_node *instr, void *context) | static bool dce(struct hlsl_ctx *ctx, struct hlsl_ir_node *instr, void *context) | ||||||
| { | { | ||||||
|     switch (instr->type) |     switch (instr->type) | ||||||
| @@ -7903,6 +7941,10 @@ static void process_entry_function(struct hlsl_ctx *ctx, | |||||||
|     { |     { | ||||||
|         hlsl_transform_ir(ctx, lower_discard_neg, body, NULL); |         hlsl_transform_ir(ctx, lower_discard_neg, body, NULL); | ||||||
|     } |     } | ||||||
|  |     else | ||||||
|  |     { | ||||||
|  |         hlsl_transform_ir(ctx, lower_discard_nz, body, NULL); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     transform_unroll_loops(ctx, body); |     transform_unroll_loops(ctx, body); | ||||||
|     hlsl_run_const_passes(ctx, body); |     hlsl_run_const_passes(ctx, body); | ||||||
|   | |||||||
| @@ -21,7 +21,7 @@ shader model >= 3.0 | |||||||
|  |  | ||||||
| % Check that derivatives are still computed after discarding | % Check that derivatives are still computed after discarding | ||||||
| % other pixels in the same quad | % other pixels in the same quad | ||||||
| [pixel shader todo(sm<4)] | [pixel shader] | ||||||
| float4 main(float4 pos : sv_position) : sv_target | float4 main(float4 pos : sv_position) : sv_target | ||||||
| { | { | ||||||
|     if (frac((floor(pos.x) + floor(pos.y)) / 2) == 0.5) |     if (frac((floor(pos.x) + floor(pos.y)) / 2) == 0.5) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user