Commit d49a6ab0 authored by Nikolay Sivov's avatar Nikolay Sivov Committed by Alexandre Julliard

d3d10/effect: Implement instructions used for signed integer division.

parent 27ab6967
......@@ -477,6 +477,34 @@ static void pres_umax(float **args, unsigned int n, const struct preshader_instr
}
}
static void pres_and(float **args, unsigned int n, const struct preshader_instr *instr)
{
unsigned int *arg1 = (unsigned int *)args[0];
unsigned int *arg2 = (unsigned int *)args[1];
float *retval = args[2];
unsigned int i;
for (i = 0; i < instr->comp_count; ++i)
{
unsigned int v = arg1[instr->scalar ? 0 : i] & arg2[i];
retval[i] = *(float *)&v;
}
}
static void pres_xor(float **args, unsigned int n, const struct preshader_instr *instr)
{
unsigned int *arg1 = (unsigned int *)args[0];
unsigned int *arg2 = (unsigned int *)args[1];
float *retval = args[2];
unsigned int i;
for (i = 0; i < instr->comp_count; ++i)
{
unsigned int v = arg1[instr->scalar ? 0 : i] ^ arg2[i];
retval[i] = *(float *)&v;
}
}
static void pres_movc(float **args, unsigned int n, const struct preshader_instr *instr)
{
float *arg1 = args[0], *arg2 = args[1], *arg3 = args[2];
......@@ -522,6 +550,8 @@ static const struct preshader_op_info preshader_ops[] =
{ 0x21e, "imax", pres_imax },
{ 0x21f, "umin", pres_umin },
{ 0x220, "umax", pres_umax },
{ 0x230, "and", pres_and },
{ 0x233, "xor", pres_xor },
{ 0x301, "movc", pres_movc },
};
......
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