summaryrefslogtreecommitdiff
path: root/sc
diff options
context:
space:
mode:
authorquou <quou@disroot.org>2025-01-05 22:15:22 +1100
committerquou <quou@disroot.org>2025-01-05 22:15:22 +1100
commitbce070eba418c8a79f6affcd885564babbf8c9d3 (patch)
tree70fd5b4a57091cb5d6c4b47c1b29c98ba7b54062 /sc
parent925a2707c1f2d0f5e256f6e70050b7b2242d99e8 (diff)
source level shader debugging
Diffstat (limited to 'sc')
m---------sc/glslang0
-rw-r--r--sc/sc.cpp16
2 files changed, 15 insertions, 1 deletions
diff --git a/sc/glslang b/sc/glslang
-Subproject 1062752a891c95b2bfeed9e356562d88f9df84a
+Subproject f754c852a87988eb097a39480c65f704ceb4627
diff --git a/sc/sc.cpp b/sc/sc.cpp
index 2bd1406..de39187 100644
--- a/sc/sc.cpp
+++ b/sc/sc.cpp
@@ -508,6 +508,7 @@ struct Desc {
std::vector<uint32_t> compile_shader(
Desc& d,
+ const char* fname,
const char* presrc,
const char* src,
const char* define,
@@ -532,6 +533,9 @@ std::vector<uint32_t> compile_shader(
#ifdef DEBUG
options.disableOptimizer = true;
options.generateDebugInfo = true;
+ options.emitNonSemanticShaderDebugInfo = true;
+ options.emitNonSemanticShaderDebugSource = true;
+ options.stripDebugInfo = false;
#else
options.disableOptimizer = false;
options.stripDebugInfo = true;
@@ -541,6 +545,14 @@ std::vector<uint32_t> compile_shader(
shader.setEnvClient(glslang::EShClientVulkan, client_version);
shader.setEnvTarget(glslang::EShTargetSpv, target_version);
shader.setEntryPoint(d.entrypoints[stage].c_str());
+#ifdef DEBUG
+ shader.setDebugInfo(true);
+ shader.setSourceEntryPoint(d.entrypoints[stage].c_str());
+ shader.setSourceFile(fname);
+ shader.addSourceText(src, strlen(src));
+#else
+ (void)fname;
+#endif
if (!shader.preprocess(
GetDefaultResources(),
glsl_version,
@@ -599,6 +611,7 @@ void configure(
}
void compile_shaders(
+ const char* fname,
std::vector<uint32_t>* spv,
const char* src,
Desc& d
@@ -612,6 +625,7 @@ void compile_shaders(
configure(d, i, define, lang, ps);
spv[i] = compile_shader(
d,
+ fname,
ps.c_str(),
src,
define,
@@ -718,7 +732,7 @@ int main(int argc, const char** argv) {
desc_src = get_desc(src);
cdesc = parse_desc(dp_mem, desc_src.c_str());
desc.build(cdesc);
- compile_shaders(spv, src, desc);
+ compile_shaders(argv[2], spv, src, desc);
write_csh(argv[2], desc, spv);
return 0;
}