## SINGLE PORT BRAM



## Verilog code:

```
module bram_single_port #(

parameter DATA_WIDTH = 16, // Width of data bus

parameter ADDR_WIDTH = 8 // Determines memory depth (2^ADDR_WIDTH)
)(

input wire clk, // System clock

input wire en, // Memory enable

input wire we, // Write enable (1 = write, 0 = read)

input wire [ADDR_WIDTH-1:0] addr, // Memory address
```

```
input wire [DATA_WIDTH-1:0] di, // Data input
  output reg [DATA_WIDTH-1:0] dout // Data output
);
// Memory array declaration
reg [DATA_WIDTH-1:0] mem [0:(1 << ADDR_WIDTH)-1];
// Memory operation
always @(posedge clk) begin
  if (en) begin
    if (we) begin
      mem[addr] <= di; // Write data to memory
      dout <= di; // Write-first: output new data
    end else begin
      dout <= mem[addr]; // Read data from memory</pre>
    end
  end
end
endmodule
```





