

# Dual-Port RAM (with collision flag)

- A small synchronous dual-port RAM allowing 2 independent port (A and B) to read and write the same  $N \times N$  memory concurrently.
- Each port has its own addr, data-in, read/write controls.
- Similar to normal RAM, on  $\text{en}_1=1$  and  $\text{R-W}_1=1$  the  $1\text{lp}$  data stored in memory and  $\text{R-W}_2=0$  the stored data in memory goes as  $0\text{lp}$ .
- Collision flag :- If both ports write to the same addrs. in same CLK., the module asserts a collision flag.  $0\text{lp}$  drive = during writes (behav. bus release)
- Circuit explained
  - ① storage & init
    - register [0..3] holds 4 bit words
    - initial sets data\_out\_A = Z, and collision = 0 along with zeroes memory.
  - ② Port A logic

```
always @ (posedge clk) begin
    if (R-W-A) begin
        register [address_A] <= data_in_A;
        data_out_A <= 4'dZ;
    end else
        data_out_A <= register [address_A];
```

- on clk :- if R-w-A = 1 (write)  
data-in-A to reg [address-A]  
and data-out-A to Z  
else drive data-out with reg [addr-A]  
or the read op"

### (3) Port B logic

- identical behavior for port B with its own signals.

"collision detect" & duplicate writes

always @ (posedge clk) begin

collision <= 1'b0;

if (R-w-A && R-w-B && address\_A == address\_B)

begin

collision <= 1'b1;

end

else begin

if (R-w-A) register[address-A] <= data-in-A;

if (R-w-B) register[address-B] <= data-in-B;

end

end

- clears collision, then if both ports are writing the same addr sets collision = 1
- Else it performs write for any port that requests it.

Summary :-

- The module intends dual-port behaviour and collision reporting, but the duplicated write logic (per-port blocks + collision block) is redundant and can cause multiple conflicting assign, consolidate writes into a single clocked block to avoid races.
- OLPs driven to Z during write for synthesis prefer defined OLP behaviour or tri-state only on top-level I/O with proper bus arbitration.
- Collision flag is useful - but product design should define which write wins (priority) or implement byte-merge / "resol" policy.

