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

wined3d: Simplify shader_generate_main() a bit.

parent 8553665c
...@@ -822,10 +822,8 @@ static void shader_color_correction(IWineD3DBaseShaderImpl *shader, ...@@ -822,10 +822,8 @@ static void shader_color_correction(IWineD3DBaseShaderImpl *shader,
device->shader_backend->shader_color_correction(arg, fixup); device->shader_backend->shader_color_correction(arg, fixup);
} }
/** Shared code in order to generate the bulk of the shader string. /* Shared code in order to generate the bulk of the shader string.
Use the shader_header_fct & shader_footer_fct to add strings * NOTE: A description of how to parse tokens can be found on msdn */
that are specific to pixel or vertex functions
NOTE: A description of how to parse tokens can be found on msdn */
void shader_generate_main(IWineD3DBaseShader *iface, SHADER_BUFFER* buffer, void shader_generate_main(IWineD3DBaseShader *iface, SHADER_BUFFER* buffer,
const shader_reg_maps* reg_maps, CONST DWORD* pFunction) const shader_reg_maps* reg_maps, CONST DWORD* pFunction)
{ {
...@@ -835,8 +833,8 @@ void shader_generate_main(IWineD3DBaseShader *iface, SHADER_BUFFER* buffer, ...@@ -835,8 +833,8 @@ void shader_generate_main(IWineD3DBaseShader *iface, SHADER_BUFFER* buffer,
const SHADER_HANDLER *handler_table = device->shader_backend->shader_instruction_handler_table; const SHADER_HANDLER *handler_table = device->shader_backend->shader_instruction_handler_table;
DWORD shader_version = reg_maps->shader_version; DWORD shader_version = reg_maps->shader_version;
const DWORD *pToken = pFunction; const DWORD *pToken = pFunction;
const SHADER_OPCODE *curOpcode = NULL; const SHADER_OPCODE *curOpcode;
SHADER_HANDLER hw_fct = NULL; SHADER_HANDLER hw_fct;
DWORD i; DWORD i;
SHADER_OPCODE_ARG hw_arg; SHADER_OPCODE_ARG hw_arg;
...@@ -846,99 +844,94 @@ void shader_generate_main(IWineD3DBaseShader *iface, SHADER_BUFFER* buffer, ...@@ -846,99 +844,94 @@ void shader_generate_main(IWineD3DBaseShader *iface, SHADER_BUFFER* buffer,
hw_arg.reg_maps = reg_maps; hw_arg.reg_maps = reg_maps;
This->baseShader.parse_state.current_row = 0; This->baseShader.parse_state.current_row = 0;
/* Second pass, process opcodes */ if (!pToken) return;
if (NULL != pToken) {
while (WINED3DPS_END() != *pToken) {
/* Skip version token */ while (WINED3DPS_END() != *pToken)
if (shader_is_version_token(*pToken)) { {
++pToken; /* Skip version token */
continue; if (shader_is_version_token(*pToken))
} {
++pToken;
/* Skip comment tokens */ continue;
if (shader_is_comment(*pToken)) { }
DWORD comment_len = (*pToken & WINED3DSI_COMMENTSIZE_MASK) >> WINED3DSI_COMMENTSIZE_SHIFT;
++pToken;
TRACE("#%s\n", (const char*)pToken);
pToken += comment_len;
continue;
}
/* Read opcode */
hw_arg.opcode_token = *pToken++;
curOpcode = shader_get_opcode(opcode_table, shader_version, hw_arg.opcode_token);
/* Select handler */
if (curOpcode == NULL)
hw_fct = NULL;
else
hw_fct = handler_table[curOpcode->handler_idx];
/* Unknown opcode and its parameters */
if (NULL == curOpcode) {
FIXME("Unrecognized opcode: token=0x%08x\n", hw_arg.opcode_token);
pToken += shader_skip_unrecognized(pToken, shader_version);
/* Nothing to do */
} else if (WINED3DSIO_DCL == curOpcode->opcode ||
WINED3DSIO_NOP == curOpcode->opcode ||
WINED3DSIO_DEF == curOpcode->opcode ||
WINED3DSIO_DEFI == curOpcode->opcode ||
WINED3DSIO_DEFB == curOpcode->opcode ||
WINED3DSIO_PHASE == curOpcode->opcode ||
WINED3DSIO_RET == curOpcode->opcode) {
pToken += shader_skip_opcode(curOpcode, hw_arg.opcode_token, shader_version);
/* If a generator function is set for current shader target, use it */ /* Skip comment tokens */
} else if (hw_fct != NULL) { if (shader_is_comment(*pToken))
{
pToken += (*pToken & WINED3DSI_COMMENTSIZE_MASK) >> WINED3DSI_COMMENTSIZE_SHIFT;
++pToken;
continue;
}
hw_arg.opcode = curOpcode; /* Read opcode */
hw_arg.opcode_token = *pToken++;
curOpcode = shader_get_opcode(opcode_table, shader_version, hw_arg.opcode_token);
/* Destination token */ /* Unknown opcode and its parameters */
if (curOpcode->dst_token) { if (!curOpcode)
{
FIXME("Unrecognized opcode: token=0x%08x\n", hw_arg.opcode_token);
pToken += shader_skip_unrecognized(pToken, shader_version);
continue;
}
DWORD param, addr_token = 0; /* Nothing to do */
pToken += shader_get_param(pToken, shader_version, &param, &addr_token); if (WINED3DSIO_DCL == curOpcode->opcode
hw_arg.dst = param; || WINED3DSIO_NOP == curOpcode->opcode
hw_arg.dst_addr = addr_token; || WINED3DSIO_DEF == curOpcode->opcode
} || WINED3DSIO_DEFI == curOpcode->opcode
|| WINED3DSIO_DEFB == curOpcode->opcode
|| WINED3DSIO_PHASE == curOpcode->opcode
|| WINED3DSIO_RET == curOpcode->opcode)
{
pToken += shader_skip_opcode(curOpcode, hw_arg.opcode_token, shader_version);
continue;
}
/* Predication token */ /* Select handler */
if (hw_arg.opcode_token & WINED3DSHADER_INSTRUCTION_PREDICATED) hw_fct = handler_table[curOpcode->handler_idx];
hw_arg.predicate = *pToken++;
/* Other source tokens */ /* Unhandled opcode */
for (i = 0; i < (curOpcode->num_params - curOpcode->dst_token); i++) { if (!hw_fct)
{
FIXME("Can't handle opcode %s in hwShader\n", curOpcode->name);
pToken += shader_skip_opcode(curOpcode, hw_arg.opcode_token, shader_version);
continue;
}
DWORD param, addr_token = 0; hw_arg.opcode = curOpcode;
pToken += shader_get_param(pToken, shader_version, &param, &addr_token);
hw_arg.src[i] = param;
hw_arg.src_addr[i] = addr_token;
}
/* Call appropriate function for output target */ /* Destination token */
hw_fct(&hw_arg); if (curOpcode->dst_token)
{
DWORD param, addr_token = 0;
pToken += shader_get_param(pToken, shader_version, &param, &addr_token);
hw_arg.dst = param;
hw_arg.dst_addr = addr_token;
}
/* Add color correction if needed */ /* Predication token */
shader_color_correction(This, device, &hw_arg, shader_version); if (hw_arg.opcode_token & WINED3DSHADER_INSTRUCTION_PREDICATED) hw_arg.predicate = *pToken++;
/* Process instruction modifiers for GLSL apps ( _sat, etc. ) */ /* Other source tokens */
/* FIXME: This should be internal to the shader backend. for (i = 0; i < (curOpcode->num_params - curOpcode->dst_token); ++i)
* Also, right now this is the only reason "shader_mode" exists. */ {
if (This->baseShader.shader_mode == SHADER_GLSL) DWORD param, addr_token = 0;
shader_glsl_add_instruction_modifiers(&hw_arg); pToken += shader_get_param(pToken, shader_version, &param, &addr_token);
hw_arg.src[i] = param;
hw_arg.src_addr[i] = addr_token;
}
/* Unhandled opcode */ /* Call appropriate function for output target */
} else { hw_fct(&hw_arg);
FIXME("Can't handle opcode %s in hwShader\n", curOpcode->name); /* Add color correction if needed */
pToken += shader_skip_opcode(curOpcode, hw_arg.opcode_token, shader_version); shader_color_correction(This, device, &hw_arg, shader_version);
}
}
/* TODO: What about result.depth? */
/* Process instruction modifiers for GLSL apps ( _sat, etc. ) */
/* FIXME: This should be internal to the shader backend.
* Also, right now this is the only reason "shader_mode" exists. */
if (This->baseShader.shader_mode == SHADER_GLSL) shader_glsl_add_instruction_modifiers(&hw_arg);
} }
} }
......
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