Use spvc API instead of directly accessing compiler on GLSL path

BUG=dawn:291

Change-Id: I3e76749bcff8d7635d9dc02de0a9a66b686cd9d8
Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/14622
Commit-Queue: Ryan Harrison <rharrison@chromium.org>
Reviewed-by: Austin Eng <enga@chromium.org>
This commit is contained in:
Ryan Harrison 2019-12-17 19:14:21 +00:00 committed by Commit Bot service account
parent bee45bb79c
commit 2fdc7ab692
2 changed files with 50 additions and 18 deletions

View File

@ -93,9 +93,9 @@ namespace dawn_native { namespace opengl {
#endif #endif
shaderc_spvc_status status = shaderc_spvc_status status =
mSpvcContext.InitializeForGlsl(descriptor->code, descriptor->codeSize, options); mSpvcContext.InitializeForGlsl(descriptor->code, descriptor->codeSize, options);
if (status != shaderc_spvc_status_success) if (status != shaderc_spvc_status_success) {
return DAWN_VALIDATION_ERROR("Unable to initialize instance of spvc"); return DAWN_VALIDATION_ERROR("Unable to initialize instance of spvc");
}
compiler = reinterpret_cast<spirv_cross::CompilerGLSL*>(mSpvcContext.GetCompiler()); compiler = reinterpret_cast<spirv_cross::CompilerGLSL*>(mSpvcContext.GetCompiler());
} else { } else {
// If these options are changed, the values in DawnSPIRVCrossGLSLFastFuzzer.cpp need to // If these options are changed, the values in DawnSPIRVCrossGLSLFastFuzzer.cpp need to
@ -129,21 +129,45 @@ namespace dawn_native { namespace opengl {
// Extract bindings names so that it can be used to get its location in program. // Extract bindings names so that it can be used to get its location in program.
// Now translate the separate sampler / textures into combined ones and store their info. // Now translate the separate sampler / textures into combined ones and store their info.
// We need to do this before removing the set and binding decorations. // We need to do this before removing the set and binding decorations.
compiler->build_combined_image_samplers(); if (GetDevice()->IsToggleEnabled(Toggle::UseSpvc)) {
mSpvcContext.BuildCombinedImageSamplers();
} else {
compiler->build_combined_image_samplers();
}
for (const auto& combined : compiler->get_combined_image_samplers()) { if (GetDevice()->IsToggleEnabled(Toggle::UseSpvc)) {
mCombinedInfo.emplace_back(); std::vector<shaderc_spvc_combined_image_sampler> samplers;
mSpvcContext.GetCombinedImageSamplers(&samplers);
for (auto sampler : samplers) {
mCombinedInfo.emplace_back();
auto& info = mCombinedInfo.back();
auto& info = mCombinedInfo.back(); mSpvcContext.GetDecoration(sampler.sampler_id,
info.samplerLocation.group = shaderc_spvc_decoration_descriptorset,
compiler->get_decoration(combined.sampler_id, spv::DecorationDescriptorSet); &info.samplerLocation.group);
info.samplerLocation.binding = mSpvcContext.GetDecoration(sampler.sampler_id, shaderc_spvc_decoration_binding,
compiler->get_decoration(combined.sampler_id, spv::DecorationBinding); &info.samplerLocation.binding);
info.textureLocation.group = mSpvcContext.GetDecoration(sampler.image_id, shaderc_spvc_decoration_descriptorset,
compiler->get_decoration(combined.image_id, spv::DecorationDescriptorSet); &info.textureLocation.group);
info.textureLocation.binding = mSpvcContext.GetDecoration(sampler.image_id, shaderc_spvc_decoration_binding,
compiler->get_decoration(combined.image_id, spv::DecorationBinding); &info.textureLocation.binding);
compiler->set_name(combined.combined_id, info.GetName()); mSpvcContext.SetName(sampler.combined_id, info.GetName());
}
} else {
for (const auto& combined : compiler->get_combined_image_samplers()) {
mCombinedInfo.emplace_back();
auto& info = mCombinedInfo.back();
info.samplerLocation.group =
compiler->get_decoration(combined.sampler_id, spv::DecorationDescriptorSet);
info.samplerLocation.binding =
compiler->get_decoration(combined.sampler_id, spv::DecorationBinding);
info.textureLocation.group =
compiler->get_decoration(combined.image_id, spv::DecorationDescriptorSet);
info.textureLocation.binding =
compiler->get_decoration(combined.image_id, spv::DecorationBinding);
compiler->set_name(combined.combined_id, info.GetName());
}
} }
// Change binding names to be "dawn_binding_<group>_<binding>". // Change binding names to be "dawn_binding_<group>_<binding>".
@ -153,9 +177,16 @@ namespace dawn_native { namespace opengl {
for (uint32_t binding = 0; binding < kMaxBindingsPerGroup; ++binding) { for (uint32_t binding = 0; binding < kMaxBindingsPerGroup; ++binding) {
const auto& info = bindingInfo[group][binding]; const auto& info = bindingInfo[group][binding];
if (info.used) { if (info.used) {
compiler->set_name(info.base_type_id, GetBindingName(group, binding)); if (GetDevice()->IsToggleEnabled(Toggle::UseSpvc)) {
compiler->unset_decoration(info.id, spv::DecorationBinding); mSpvcContext.SetName(info.base_type_id, GetBindingName(group, binding));
compiler->unset_decoration(info.id, spv::DecorationDescriptorSet); mSpvcContext.UnsetDecoration(info.id, shaderc_spvc_decoration_binding);
mSpvcContext.UnsetDecoration(info.id,
shaderc_spvc_decoration_descriptorset);
} else {
compiler->set_name(info.base_type_id, GetBindingName(group, binding));
compiler->unset_decoration(info.id, spv::DecorationBinding);
compiler->unset_decoration(info.id, spv::DecorationDescriptorSet);
}
} }
} }
} }

View File

@ -183,6 +183,7 @@ DawnTestEnvironment::DawnTestEnvironment(int argc, char** argv) {
" -c, --begin-capture-on-startup: Begin debug capture on startup " " -c, --begin-capture-on-startup: Begin debug capture on startup "
"(defaults to no capture)\n" "(defaults to no capture)\n"
" --skip-validation: Skip Dawn validation\n" " --skip-validation: Skip Dawn validation\n"
" --use-spvc: Use spvc for accessing spirv-cross\n"
" --adapter-vendor-id: Select adapter by vendor id to run end2end tests" " --adapter-vendor-id: Select adapter by vendor id to run end2end tests"
"on multi-GPU systems \n"; "on multi-GPU systems \n";
continue; continue;