mirror of
				https://gitlab.winehq.org/wine/vkd3d.git
				synced 2025-09-12 18:50:22 -07:00 
			
		
		
		
	vkd3d-shader/hlsl: Parse multisample texture type names.
This commit is contained in:
		
				
					committed by
					
						 Alexandre Julliard
						Alexandre Julliard
					
				
			
			
				
	
			
			
			
						parent
						
							ee52ad8106
						
					
				
				
					commit
					ae2f777a4d
				
			
				
				Notes:
				
					Alexandre Julliard
				
				2023-03-08 21:51:58 +01:00 
			
			Approved-by: Zebediah Figura (@zfigura) Approved-by: Henri Verbeet (@hverbeet) Approved-by: Alexandre Julliard (@julliard) Merge-Request: https://gitlab.winehq.org/wine/vkd3d/-/merge_requests/115
| @@ -570,7 +570,8 @@ struct hlsl_type *hlsl_new_struct_type(struct hlsl_ctx *ctx, const char *name, | ||||
|     return type; | ||||
| } | ||||
|  | ||||
| struct hlsl_type *hlsl_new_texture_type(struct hlsl_ctx *ctx, enum hlsl_sampler_dim dim, struct hlsl_type *format) | ||||
| struct hlsl_type *hlsl_new_texture_type(struct hlsl_ctx *ctx, enum hlsl_sampler_dim dim, | ||||
|         struct hlsl_type *format, unsigned int sample_count) | ||||
| { | ||||
|     struct hlsl_type *type; | ||||
|  | ||||
| @@ -582,6 +583,7 @@ struct hlsl_type *hlsl_new_texture_type(struct hlsl_ctx *ctx, enum hlsl_sampler_ | ||||
|     type->dimy = 1; | ||||
|     type->sampler_dim = dim; | ||||
|     type->e.resource_format = format; | ||||
|     type->sample_count = sample_count; | ||||
|     hlsl_type_calculate_reg_size(ctx, type); | ||||
|     list_add_tail(&ctx->types, &type->entry); | ||||
|     return type; | ||||
|   | ||||
| @@ -166,6 +166,8 @@ struct hlsl_type | ||||
|      * Otherwise both dimx = 1 and dimy = 1. */ | ||||
|     unsigned int dimx; | ||||
|     unsigned int dimy; | ||||
|     /* Sample count for HLSL_SAMPLER_DIM_2DMS or HLSL_SAMPLER_DIM_2DMSARRAY. */ | ||||
|     unsigned int sample_count; | ||||
|  | ||||
|     union | ||||
|     { | ||||
| @@ -1059,7 +1061,8 @@ struct hlsl_ir_swizzle *hlsl_new_swizzle(struct hlsl_ctx *ctx, DWORD s, unsigned | ||||
|         struct hlsl_ir_node *val, const struct vkd3d_shader_location *loc); | ||||
| struct hlsl_ir_var *hlsl_new_synthetic_var(struct hlsl_ctx *ctx, const char *template, | ||||
|         struct hlsl_type *type, const struct vkd3d_shader_location *loc); | ||||
| struct hlsl_type *hlsl_new_texture_type(struct hlsl_ctx *ctx, enum hlsl_sampler_dim dim, struct hlsl_type *format); | ||||
| struct hlsl_type *hlsl_new_texture_type(struct hlsl_ctx *ctx, enum hlsl_sampler_dim dim, struct hlsl_type *format, | ||||
|         unsigned int sample_count); | ||||
| struct hlsl_type *hlsl_new_uav_type(struct hlsl_ctx *ctx, enum hlsl_sampler_dim dim, struct hlsl_type *format); | ||||
| struct hlsl_ir_constant *hlsl_new_uint_constant(struct hlsl_ctx *ctx, unsigned int n, | ||||
|         const struct vkd3d_shader_location *loc); | ||||
|   | ||||
| @@ -1122,7 +1122,7 @@ static struct list *make_list(struct hlsl_ctx *ctx, struct hlsl_ir_node *node) | ||||
|     return list; | ||||
| } | ||||
|  | ||||
| static unsigned int evaluate_array_dimension(struct hlsl_ir_node *node) | ||||
| static unsigned int evaluate_static_expression(struct hlsl_ir_node *node) | ||||
| { | ||||
|     if (node->data_type->type != HLSL_CLASS_SCALAR) | ||||
|         return 0; | ||||
| @@ -3765,6 +3765,21 @@ static bool add_method_call(struct hlsl_ctx *ctx, struct list *instrs, struct hl | ||||
|     } | ||||
| } | ||||
|  | ||||
| static void validate_texture_format_type(struct hlsl_ctx *ctx, struct hlsl_type *format, | ||||
|         const struct vkd3d_shader_location *loc) | ||||
| { | ||||
|     if (format->type > HLSL_CLASS_VECTOR) | ||||
|     { | ||||
|         struct vkd3d_string_buffer *string; | ||||
|  | ||||
|         string = hlsl_type_to_string(ctx, format); | ||||
|         if (string) | ||||
|             hlsl_error(ctx, loc, VKD3D_SHADER_ERROR_HLSL_INVALID_TYPE, | ||||
|                     "Texture data type %s is not scalar or vector.", string->buffer); | ||||
|         hlsl_release_string_buffer(ctx, string); | ||||
|     } | ||||
| } | ||||
|  | ||||
| } | ||||
|  | ||||
| %locations | ||||
| @@ -3985,7 +4000,7 @@ static bool add_method_call(struct hlsl_ctx *ctx, struct list *instrs, struct hl | ||||
|  | ||||
| %type <reg_reservation> register_opt | ||||
|  | ||||
| %type <sampler_dim> texture_type uav_type | ||||
| %type <sampler_dim> texture_type texture_ms_type uav_type | ||||
|  | ||||
| %type <semantic> semantic | ||||
|  | ||||
| @@ -4598,6 +4613,16 @@ texture_type: | ||||
|             $$ = HLSL_SAMPLER_DIM_CUBEARRAY; | ||||
|         } | ||||
|  | ||||
| texture_ms_type: | ||||
|       KW_TEXTURE2DMS | ||||
|         { | ||||
|             $$ = HLSL_SAMPLER_DIM_2DMS; | ||||
|         } | ||||
|     | KW_TEXTURE2DMSARRAY | ||||
|         { | ||||
|             $$ = HLSL_SAMPLER_DIM_2DMSARRAY; | ||||
|         } | ||||
|  | ||||
| uav_type: | ||||
|       KW_RWTEXTURE1D | ||||
|         { | ||||
| @@ -4695,25 +4720,30 @@ type_no_void: | ||||
|         } | ||||
|     | KW_TEXTURE | ||||
|         { | ||||
|             $$ = hlsl_new_texture_type(ctx, HLSL_SAMPLER_DIM_GENERIC, NULL); | ||||
|             $$ = hlsl_new_texture_type(ctx, HLSL_SAMPLER_DIM_GENERIC, NULL, 0); | ||||
|         } | ||||
|     | texture_type | ||||
|         { | ||||
|             $$ = hlsl_new_texture_type(ctx, $1, hlsl_get_vector_type(ctx, HLSL_TYPE_FLOAT, 4)); | ||||
|             $$ = hlsl_new_texture_type(ctx, $1, hlsl_get_vector_type(ctx, HLSL_TYPE_FLOAT, 4), 0); | ||||
|         } | ||||
|     | texture_type '<' type '>' | ||||
|         { | ||||
|             if ($3->type > HLSL_CLASS_VECTOR) | ||||
|             { | ||||
|                 struct vkd3d_string_buffer *string; | ||||
|             validate_texture_format_type(ctx, $3, &@3); | ||||
|             $$ = hlsl_new_texture_type(ctx, $1, $3, 0); | ||||
|         } | ||||
|     | texture_ms_type '<' type '>' | ||||
|         { | ||||
|             validate_texture_format_type(ctx, $3, &@3); | ||||
|  | ||||
|                 string = hlsl_type_to_string(ctx, $3); | ||||
|                 if (string) | ||||
|                     hlsl_error(ctx, &@3, VKD3D_SHADER_ERROR_HLSL_INVALID_TYPE, | ||||
|                             "Texture data type %s is not scalar or vector.", string->buffer); | ||||
|                 hlsl_release_string_buffer(ctx, string); | ||||
|             } | ||||
|             $$ = hlsl_new_texture_type(ctx, $1, $3); | ||||
|             /* TODO: unspecified sample count is not allowed for all targets */ | ||||
|             $$ = hlsl_new_texture_type(ctx, $1, $3, 0); | ||||
|         } | ||||
|     | texture_ms_type '<' type ',' shift_expr '>' | ||||
|         { | ||||
|             unsigned int sample_count = evaluate_static_expression(node_from_list($5)); | ||||
|             destroy_instr_list($5); | ||||
|  | ||||
|             $$ = hlsl_new_texture_type(ctx, $1, $3, sample_count); | ||||
|         } | ||||
|     | uav_type '<' type '>' | ||||
|         { | ||||
| @@ -4904,7 +4934,7 @@ arrays: | ||||
|         } | ||||
|     | '[' expr ']' arrays | ||||
|         { | ||||
|             unsigned int size = evaluate_array_dimension(node_from_list($2)); | ||||
|             unsigned int size = evaluate_static_expression(node_from_list($2)); | ||||
|             uint32_t *new_array; | ||||
|  | ||||
|             destroy_instr_list($2); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user