Commit b97a9572 by Chris Forbes

Add support for OpCompositeConstruct

Bug: b/126475423 Change-Id: I69d05db8eaf0825893210424496dc6c9ad793d0d Reviewed-on: https://swiftshader-review.googlesource.com/c/25190Tested-by: 's avatarChris Forbes <chrisforbes@google.com> Reviewed-by: 's avatarNicolas Capens <nicolascapens@google.com> Reviewed-by: 's avatarBen Clayton <bclayton@google.com> Kokoro-Presubmit: kokoro <noreply+kokoro@google.com>
parent d30b5ac5
...@@ -259,6 +259,7 @@ namespace sw ...@@ -259,6 +259,7 @@ namespace sw
case spv::OpLoad: case spv::OpLoad:
case spv::OpAccessChain: case spv::OpAccessChain:
case spv::OpCompositeConstruct:
// Instructions that yield an ssavalue. // Instructions that yield an ssavalue.
{ {
TypeID typeId = insn.word(1); TypeID typeId = insn.word(1);
...@@ -927,6 +928,24 @@ namespace sw ...@@ -927,6 +928,24 @@ namespace sw
} }
break; break;
} }
case spv::OpCompositeConstruct:
{
auto &type = getType(insn.word(1));
auto &dst = routine->createIntermediate(insn.word(2), type.sizeInComponents);
auto offset = 0u;
for (auto i = 0u; i < insn.wordCount() - 3; i++)
{
ObjectID srcObjectId = insn.word(3u + i);
auto & srcObject = getObject(srcObjectId);
auto & srcObjectTy = getType(srcObject.type);
GenericValue srcObjectAccess(this, routine, srcObjectId);
for (auto j = 0u; j < srcObjectTy.sizeInComponents; j++)
dst.emplace(offset++, srcObjectAccess[j]);
}
break;
}
default: default:
printf("emit: ignoring opcode %d\n", insn.opcode()); printf("emit: ignoring opcode %d\n", insn.opcode());
break; break;
......
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