From b54248ad49ef3e60b659f683c7887d83aa31634c Mon Sep 17 00:00:00 2001 From: baldurk Date: Tue, 9 Jun 2020 17:50:42 +0100 Subject: [PATCH] Fix indexing of symbols for metadata --- renderdoc/driver/shaders/dxil/dxil_bytecode.cpp | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/renderdoc/driver/shaders/dxil/dxil_bytecode.cpp b/renderdoc/driver/shaders/dxil/dxil_bytecode.cpp index 744a9fcc3..bb3f7d17c 100644 --- a/renderdoc/driver/shaders/dxil/dxil_bytecode.cpp +++ b/renderdoc/driver/shaders/dxil/dxil_bytecode.cpp @@ -1215,9 +1215,15 @@ Program::Program(const byte *bytes, size_t length) for(size_t i = 0; n < op.ops.size(); n++, i++) { - s = getSymbol(op.ops[n]); if(inst.funcCall->funcType->members[i]->type == Type::Metadata) + { s.type = SymbolType::Metadata; + s.idx = uint32_t((uint64_t)m_Symbols.size() - op.ops[n]); + } + else + { + s = getSymbol(op.ops[n]); + } inst.args.push_back(s); }