summaryrefslogtreecommitdiff
path: root/platform/wavelet3d/gfx_sim_debug.sv
diff options
context:
space:
mode:
authorAlejandro Soto <alejandro@34project.org>2024-05-03 12:22:48 -0600
committerAlejandro Soto <alejandro@34project.org>2024-05-03 21:19:09 -0600
commit7f95c983b2d77492ea1876b9229b3a7f29c54bbc (patch)
tree57e7ac7784ed066fa5b1722a960541dc21557e55 /platform/wavelet3d/gfx_sim_debug.sv
parentd6dcfc10f26056485cb260af93027047a6aa8d30 (diff)
platform/wavelet3d: add sched debug agent
Diffstat (limited to 'platform/wavelet3d/gfx_sim_debug.sv')
-rw-r--r--platform/wavelet3d/gfx_sim_debug.sv50
1 files changed, 50 insertions, 0 deletions
diff --git a/platform/wavelet3d/gfx_sim_debug.sv b/platform/wavelet3d/gfx_sim_debug.sv
new file mode 100644
index 0000000..4b4622a
--- /dev/null
+++ b/platform/wavelet3d/gfx_sim_debug.sv
@@ -0,0 +1,50 @@
+module gfx_sim_debug
+import gfx::*;
+(
+ input logic clk,
+ rst_n,
+
+ gfx_axil.s axis
+);
+
+ enum int unsigned
+ {
+ INPUT,
+ STALL
+ } state;
+
+ assign axis.rvalid = 0;
+ assign axis.arready = 0;
+ assign axis.awready = 1;
+
+ always_comb
+ unique case (state)
+ INPUT: begin
+ axis.wready = 1;
+ axis.bvalid = axis.wvalid;
+ end
+
+ STALL: begin
+ axis.wready = 0;
+ axis.bvalid = 1;
+ end
+ endcase
+
+ always_ff @(posedge clk or negedge rst_n)
+ if (~rst_n)
+ state <= INPUT;
+ else
+ unique case (state)
+ INPUT:
+ if (axis.wvalid) begin
+ $display("%c", axis.wdata[7:0]);
+ if (~axis.bready)
+ state <= STALL;
+ end
+
+ STALL:
+ if (axis.bready)
+ state <= INPUT;
+ endcase
+
+endmodule