Commit eefb45f3 authored by Henri Verbeet's avatar Henri Verbeet Committed by Alexandre Julliard

wined3d: Properly report shader comment sizes.

parent 4064efdc
...@@ -467,10 +467,11 @@ static HRESULT shader_get_registers_used(IWineD3DBaseShader *iface, const struct ...@@ -467,10 +467,11 @@ static HRESULT shader_get_registers_used(IWineD3DBaseShader *iface, const struct
{ {
struct wined3d_shader_instruction ins; struct wined3d_shader_instruction ins;
const char *comment; const char *comment;
UINT comment_size;
UINT param_size; UINT param_size;
/* Skip comments. */ /* Skip comments. */
fe->shader_read_comment(&ptr, &comment); fe->shader_read_comment(&ptr, &comment, &comment_size);
if (comment) continue; if (comment) continue;
/* Fetch opcode. */ /* Fetch opcode. */
...@@ -1115,10 +1116,11 @@ void shader_generate_main(IWineD3DBaseShader *iface, struct wined3d_shader_buffe ...@@ -1115,10 +1116,11 @@ void shader_generate_main(IWineD3DBaseShader *iface, struct wined3d_shader_buffe
while (!fe->shader_is_end(fe_data, &ptr)) while (!fe->shader_is_end(fe_data, &ptr))
{ {
const char *comment; const char *comment;
UINT comment_size;
UINT param_size; UINT param_size;
/* Skip comment tokens. */ /* Skip comment tokens. */
fe->shader_read_comment(&ptr, &comment); fe->shader_read_comment(&ptr, &comment, &comment_size);
if (comment) continue; if (comment) continue;
/* Read opcode. */ /* Read opcode. */
...@@ -1222,10 +1224,11 @@ static void shader_trace_init(const struct wined3d_shader_frontend *fe, void *fe ...@@ -1222,10 +1224,11 @@ static void shader_trace_init(const struct wined3d_shader_frontend *fe, void *fe
{ {
struct wined3d_shader_instruction ins; struct wined3d_shader_instruction ins;
const char *comment; const char *comment;
UINT comment_size;
UINT param_size; UINT param_size;
/* comment */ /* comment */
fe->shader_read_comment(&ptr, &comment); fe->shader_read_comment(&ptr, &comment, &comment_size);
if (comment) if (comment)
{ {
TRACE("//%s\n", comment); TRACE("//%s\n", comment);
......
...@@ -641,9 +641,10 @@ static void shader_sm1_read_semantic(const DWORD **ptr, struct wined3d_shader_se ...@@ -641,9 +641,10 @@ static void shader_sm1_read_semantic(const DWORD **ptr, struct wined3d_shader_se
shader_parse_dst_param(dst_token, NULL, &semantic->reg); shader_parse_dst_param(dst_token, NULL, &semantic->reg);
} }
static void shader_sm1_read_comment(const DWORD **ptr, const char **comment) static void shader_sm1_read_comment(const DWORD **ptr, const char **comment, UINT *comment_size)
{ {
DWORD token = **ptr; DWORD token = **ptr;
UINT size;
if ((token & WINED3DSI_OPCODE_MASK) != WINED3D_SM1_OP_COMMENT) if ((token & WINED3DSI_OPCODE_MASK) != WINED3D_SM1_OP_COMMENT)
{ {
...@@ -651,8 +652,10 @@ static void shader_sm1_read_comment(const DWORD **ptr, const char **comment) ...@@ -651,8 +652,10 @@ static void shader_sm1_read_comment(const DWORD **ptr, const char **comment)
return; return;
} }
size = (token & WINED3DSI_COMMENTSIZE_MASK) >> WINED3DSI_COMMENTSIZE_SHIFT;
*comment = (const char *)++(*ptr); *comment = (const char *)++(*ptr);
*ptr += (token & WINED3DSI_COMMENTSIZE_MASK) >> WINED3DSI_COMMENTSIZE_SHIFT; *comment_size = size * sizeof(DWORD);
*ptr += size;
} }
static BOOL shader_sm1_is_end(void *data, const DWORD **ptr) static BOOL shader_sm1_is_end(void *data, const DWORD **ptr)
......
...@@ -406,9 +406,9 @@ static void shader_sm4_read_semantic(const DWORD **ptr, struct wined3d_shader_se ...@@ -406,9 +406,9 @@ static void shader_sm4_read_semantic(const DWORD **ptr, struct wined3d_shader_se
FIXME("ptr %p, semantic %p stub!\n", ptr, semantic); FIXME("ptr %p, semantic %p stub!\n", ptr, semantic);
} }
static void shader_sm4_read_comment(const DWORD **ptr, const char **comment) static void shader_sm4_read_comment(const DWORD **ptr, const char **comment, UINT *comment_size)
{ {
FIXME("ptr %p, comment %p stub!\n", ptr, comment); FIXME("ptr %p, comment %p, comment_size %p stub!\n", ptr, comment, comment_size);
*comment = NULL; *comment = NULL;
} }
......
...@@ -625,7 +625,7 @@ struct wined3d_shader_frontend ...@@ -625,7 +625,7 @@ struct wined3d_shader_frontend
void (*shader_read_dst_param)(void *data, const DWORD **ptr, struct wined3d_shader_dst_param *dst_param, void (*shader_read_dst_param)(void *data, const DWORD **ptr, struct wined3d_shader_dst_param *dst_param,
struct wined3d_shader_src_param *dst_rel_addr); struct wined3d_shader_src_param *dst_rel_addr);
void (*shader_read_semantic)(const DWORD **ptr, struct wined3d_shader_semantic *semantic); void (*shader_read_semantic)(const DWORD **ptr, struct wined3d_shader_semantic *semantic);
void (*shader_read_comment)(const DWORD **ptr, const char **comment); void (*shader_read_comment)(const DWORD **ptr, const char **comment, UINT *comment_size);
BOOL (*shader_is_end)(void *data, const DWORD **ptr); BOOL (*shader_is_end)(void *data, const DWORD **ptr);
}; };
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment