#### Debug Sobel Filter(AXI DMA#2) AXI DMA#1 filter\_top\_0 + S AXI LITE - S\_AXIS\_MM2S - S AXIS SZMM - S\_AXIS\_MM2S\_TDATA[23.0] s axis s2mm tdsta[23:0] M AXI S2MM + S\_AXIS\_MM2S\_TKEEP[2:0] - I s skis s2mm skeec/2-01 M AXIS MM2S - \* - ► S\_AXIS\_MM2S\_TLASTID:01 m\_axis\_mm2s\_tdata(23:0) > \_\_ M\_AXIS\_S2MM -- > s axis s2mm slast S AXIS MM2S TVALID M\_AXIS\_SZMM\_TDATA[23:0] > - ≪ s axis\_s2mm\_tready m axis mm2s tkeep(2:0) > -- ■ S AXIS MM2S TREADY M\_AXIS\_SZMM\_TKEEP[2:0] > m axis mm2s thest > -- s axis s2mm tuser[0:0] rgb2y\_bypass M\_AXIS\_S2MM\_TLAST[0:0] > m axis mm2s treatly 4 -- s axis s2mm tvalid filter\_bypass M\_AXIS\_SZMM\_TVALID > m\_axis\_mm2s\_tuser(0:0) > s and the activ - S\_AXIS\_MM2S\_ACLK m Jaxis mm2s traild . M\_AXIS\_S2MM\_TREADY 4 m\_axi\_mm2s\_acik - M\_AXIS\_S2MM\_ACLK mm2s frame ptr out(5.0) s2mm\_frame\_ptr\_out[5:0] 4 - m\_axi\_s2mm\_aclk --- aresetn mm2s\_introut -- s\_axis\_s2mm\_ack axi resetn 142

# Sobel Filter Verilog Source Code



### Sobel Filter(AXI DMA#2)





## Line Buffer(SRAM)

#### **NARLabs**

```
CLK, AA, CEA, WEA, D, AB, CEB, O);
 parameter ABITS =
 parameter ASI2E = 1920;
 input [ABITS - 1:0]
input [DBITS - 1:0]
input [ABITS - 1:0]
output[DBITS - 1:0]
(* ram_style = "block" *)reg [DBITS-1:0] ram[ASIZE-1:0];
reg [DBITS - 1:0] Q:
//assign @ = CEB 7 ram[AB] : 0;
always @ (posedge CLE)
        Q <= ram[AB];
always @ (posedge CLK)
begin
   if (CEA)
    begin
             ram[AA] <= D:
modmodulm // 1 lineram
```