1*c8dee2aaSAndroid Build Coastguard Worker /* 2*c8dee2aaSAndroid Build Coastguard Worker * Copyright 2024 Google LLC 3*c8dee2aaSAndroid Build Coastguard Worker * 4*c8dee2aaSAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license that can be 5*c8dee2aaSAndroid Build Coastguard Worker * found in the LICENSE file. 6*c8dee2aaSAndroid Build Coastguard Worker */ 7*c8dee2aaSAndroid Build Coastguard Worker 8*c8dee2aaSAndroid Build Coastguard Worker #ifndef SKSL_SPIRVVALIDATOR 9*c8dee2aaSAndroid Build Coastguard Worker #define SKSL_SPIRVVALIDATOR 10*c8dee2aaSAndroid Build Coastguard Worker 11*c8dee2aaSAndroid Build Coastguard Worker #include <string_view> 12*c8dee2aaSAndroid Build Coastguard Worker 13*c8dee2aaSAndroid Build Coastguard Worker namespace SkSL { 14*c8dee2aaSAndroid Build Coastguard Worker 15*c8dee2aaSAndroid Build Coastguard Worker class ErrorReporter; 16*c8dee2aaSAndroid Build Coastguard Worker 17*c8dee2aaSAndroid Build Coastguard Worker // SPIRV issues will cause an SkDEBUGFAILF to be triggered with the error message 18*c8dee2aaSAndroid Build Coastguard Worker // and false will be returned (i.e. invalid SPIRV is a fatal issue in debug builds). 19*c8dee2aaSAndroid Build Coastguard Worker bool ValidateSPIRV(ErrorReporter&, std::string_view); 20*c8dee2aaSAndroid Build Coastguard Worker 21*c8dee2aaSAndroid Build Coastguard Worker // SPIRV issues will be sent to the provided ErrorReporter along with a disassembly 22*c8dee2aaSAndroid Build Coastguard Worker // of the code. This will also return false, but not be fatal in debug builds. 23*c8dee2aaSAndroid Build Coastguard Worker bool ValidateSPIRVAndDissassemble(ErrorReporter&, std::string_view); 24*c8dee2aaSAndroid Build Coastguard Worker 25*c8dee2aaSAndroid Build Coastguard Worker } // namespace SkSL 26*c8dee2aaSAndroid Build Coastguard Worker 27*c8dee2aaSAndroid Build Coastguard Worker #endif 28