summaryrefslogtreecommitdiff
path: root/rtl/gfx/gfx_sim_debug.sv
diff options
context:
space:
mode:
authorAlejandro Soto <alejandro@34project.org>2024-05-05 17:38:55 -0600
committerAlejandro Soto <alejandro@34project.org>2024-05-05 18:12:08 -0600
commitca02833f22b08ceeeff501107371aa6667426115 (patch)
treef864c5fc238a292082d2096ce546270badce9f1d /rtl/gfx/gfx_sim_debug.sv
parent081a8a3ba8bfe036f31da53f9c041a2caa30fce2 (diff)
rtl/gfx: rename platform/wavelet3d -> rtl/gfx
Diffstat (limited to 'rtl/gfx/gfx_sim_debug.sv')
-rw-r--r--rtl/gfx/gfx_sim_debug.sv50
1 files changed, 50 insertions, 0 deletions
diff --git a/rtl/gfx/gfx_sim_debug.sv b/rtl/gfx/gfx_sim_debug.sv
new file mode 100644
index 0000000..4b4622a
--- /dev/null
+++ b/rtl/gfx/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