summaryrefslogtreecommitdiff
path: root/src/shader_recompiler/backend/glasm/emit_glasm.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/shader_recompiler/backend/glasm/emit_glasm.cpp')
-rw-r--r--src/shader_recompiler/backend/glasm/emit_glasm.cpp32
1 files changed, 26 insertions, 6 deletions
diff --git a/src/shader_recompiler/backend/glasm/emit_glasm.cpp b/src/shader_recompiler/backend/glasm/emit_glasm.cpp
index 0b70bf3f6..ab6790ce8 100644
--- a/src/shader_recompiler/backend/glasm/emit_glasm.cpp
+++ b/src/shader_recompiler/backend/glasm/emit_glasm.cpp
@@ -261,6 +261,12 @@ void EmitCode(EmitContext& ctx, const IR::Program& program) {
261} 261}
262 262
263void SetupOptions(std::string& header, Info info) { 263void SetupOptions(std::string& header, Info info) {
264 // TODO: Track the shared atomic ops
265 header += "OPTION NV_internal;"
266 "OPTION NV_shader_storage_buffer;"
267 "OPTION NV_gpu_program_fp64;"
268 "OPTION NV_bindless_texture;"
269 "OPTION ARB_derivative_control;";
264 if (info.uses_int64_bit_atomics) { 270 if (info.uses_int64_bit_atomics) {
265 header += "OPTION NV_shader_atomic_int64;"; 271 header += "OPTION NV_shader_atomic_int64;";
266 } 272 }
@@ -276,10 +282,25 @@ void SetupOptions(std::string& header, Info info) {
276 if (info.uses_subgroup_shuffles) { 282 if (info.uses_subgroup_shuffles) {
277 header += "OPTION NV_shader_thread_shuffle;"; 283 header += "OPTION NV_shader_thread_shuffle;";
278 } 284 }
279 // TODO: Track the shared atomic ops 285}
280 header += "OPTION NV_shader_storage_buffer;" 286
281 "OPTION NV_gpu_program_fp64;" 287std::string_view StageHeader(Stage stage) {
282 "OPTION NV_bindless_texture;"; 288 switch (stage) {
289 case Stage::VertexA:
290 case Stage::VertexB:
291 return "!!NVvp5.0\n";
292 case Stage::TessellationControl:
293 return "!!NVtcs5.0\n";
294 case Stage::TessellationEval:
295 return "!!NVtes5.0\n";
296 case Stage::Geometry:
297 return "!!NVgp5.0\n";
298 case Stage::Fragment:
299 return "!!NVfp5.0\n";
300 case Stage::Compute:
301 return "!!NVcp5.0\n";
302 }
303 throw InvalidArgument("Invalid stage {}", stage);
283} 304}
284} // Anonymous namespace 305} // Anonymous namespace
285 306
@@ -287,8 +308,7 @@ std::string EmitGLASM(const Profile&, IR::Program& program, Bindings&) {
287 EmitContext ctx{program}; 308 EmitContext ctx{program};
288 Precolor(ctx, program); 309 Precolor(ctx, program);
289 EmitCode(ctx, program); 310 EmitCode(ctx, program);
290 std::string header = "!!NVcp5.0\n" 311 std::string header{StageHeader(program.stage)};
291 "OPTION NV_internal;";
292 SetupOptions(header, program.info); 312 SetupOptions(header, program.info);
293 switch (program.stage) { 313 switch (program.stage) {
294 case Stage::Compute: 314 case Stage::Compute: