

# 4x4 RAM (4 words x 4 bits)

- Synchronous write, Asynchronous Read
- A small memory with 4 location (address 2 bits)  
each 4 bits wide.
- Write :- synchronous on posedge clk  
when en = 1 and R-W = 1  
\* write data-in into reg [address]
- Read :- combinational / Asynchronous  
when en = 1 and R-W = 0  
\* drives data-out from reg [address]
- Data-out is driven high impedance (1'bz)  
during write cycle. Memory initialized to 0
- Code Explanation
- ① Declaration :-
  - reg [0..3] is 4x4 storage
  - data\_out is a reg [3:0] o/p
  - address is 2 bits
  - R-W = 1, write R-W = 0, Read en enable memory
- ② Initial block :- data\_out = 0 and clears all reg to 0 at simulation start
- formula :- Memory capacity =  $2^n$  word x m bits/word  
n = address lines m = no. of data lines (1lp / 0lp)



### • Always block (write)

```
always @ (posedge clk) begin
  if (en) begin
    if (!R_W) begin
      register [address] = data_in;
      data_out = 4'bz;
    end
  end
end
```

} on rising clk edge  
en=1 and R\_W=1  
data-in stored in  
Register [Address] &  
data-out = 4'bz  
during write op

### • Combinational block (Read)

```
always @ (*) begin
  if (en) begin
    if (!R_W) data_out = register [address];
    else data_out = 4'bz;
  end
end
```

} en=1 and R\_W=0  
data\_out immediately  
reflect register [Address]

otherwise data\_out  
is Z (High Impedance)