summaryrefslogtreecommitdiff
path: root/platform/wavelet3d/gfx_shader_setup.sv
diff options
context:
space:
mode:
authorAlejandro Soto <alejandro@34project.org>2024-05-04 23:58:08 -0600
committerAlejandro Soto <alejandro@34project.org>2024-05-05 14:19:15 -0600
commit4fdcb079663eccc71ed2c120f8279d6c364de9fd (patch)
tree1df076513ef031fa2a2f55d280e2edd09748cdd5 /platform/wavelet3d/gfx_shader_setup.sv
parenta7d92072c0bdc3a3e1c99de64f353e932846bc2a (diff)
platform/wavelet3d: implement shader writeback
Diffstat (limited to '')
-rw-r--r--platform/wavelet3d/gfx_shader_setup.sv37
1 files changed, 37 insertions, 0 deletions
diff --git a/platform/wavelet3d/gfx_shader_setup.sv b/platform/wavelet3d/gfx_shader_setup.sv
new file mode 100644
index 0000000..f46fb66
--- /dev/null
+++ b/platform/wavelet3d/gfx_shader_setup.sv
@@ -0,0 +1,37 @@
+interface gfx_shader_setup
+import gfx::*;;
+
+ struct
+ {
+ group_id group;
+ word_ptr pc;
+ xgpr_num gpr;
+ word gpr_value;
+ lane_mask mask;
+ logic pc_set,
+ gpr_set,
+ mask_set;
+ } write;
+
+ struct
+ {
+ logic gpr,
+ mask,
+ submit;
+ } set_done;
+
+ modport core
+ (
+ input write,
+
+ output set_done
+ );
+
+ modport sched
+ (
+ input set_done,
+
+ output write
+ );
+
+endinterface