mirror of
https://github.com/Lime3DS/Lime3DS
synced 2025-01-09 13:43:27 +00:00
vertex_shader: Implement MADI instruction.
nihstro: Update submodule to latest upstream/master to support MADI instruction decoding.
This commit is contained in:
parent
088f6ae2c6
commit
f935130a0f
2 changed files with 8 additions and 5 deletions
2
externals/nihstro
vendored
2
externals/nihstro
vendored
|
@ -1 +1 @@
|
|||
Subproject commit 4a78588b308564f7ebae193e0ae00d9a0d5741d5
|
||||
Subproject commit 81f1804a43f625e3a1a20752c0db70a413410380
|
|
@ -366,12 +366,15 @@ static void ProcessShaderCode(VertexShaderState& state) {
|
|||
|
||||
case OpCode::Type::MultiplyAdd:
|
||||
{
|
||||
if (instr.opcode.Value().EffectiveOpCode() == OpCode::Id::MAD) {
|
||||
if ((instr.opcode.Value().EffectiveOpCode() == OpCode::Id::MAD) ||
|
||||
(instr.opcode.Value().EffectiveOpCode() == OpCode::Id::MADI)) {
|
||||
const SwizzlePattern& swizzle = *(SwizzlePattern*)&swizzle_data[instr.mad.operand_desc_id];
|
||||
|
||||
const float24* src1_ = LookupSourceRegister(instr.mad.src1);
|
||||
const float24* src2_ = LookupSourceRegister(instr.mad.src2);
|
||||
const float24* src3_ = LookupSourceRegister(instr.mad.src3);
|
||||
bool is_inverted = (instr.opcode.Value().EffectiveOpCode() == OpCode::Id::MADI);
|
||||
|
||||
const float24* src1_ = LookupSourceRegister(instr.mad.GetSrc1(is_inverted));
|
||||
const float24* src2_ = LookupSourceRegister(instr.mad.GetSrc2(is_inverted));
|
||||
const float24* src3_ = LookupSourceRegister(instr.mad.GetSrc3(is_inverted));
|
||||
|
||||
const bool negate_src1 = ((bool)swizzle.negate_src1 != false);
|
||||
const bool negate_src2 = ((bool)swizzle.negate_src2 != false);
|
||||
|
|
Loading…
Reference in a new issue