Copyright (c) 2014 - 2016 Young W. Lim.

Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.2 or any later version published by the Free Software Foundation; with no Invariant Sections, no Front-Cover Texts, and no Back-Cover Texts. A copy of the license is included in the section entitled "GNU Free Documentation License".

Please send corrections (or suggestions) to youngwlim@hotmail.com.

This document was produced by using LibreOffice and Octave.

# Virtex LUT RAM

```
module ram16x1(q, a, d, we, clk);
output
         q;
input
         d;
input [3:0] a;
input clk, we;
         mem [15:0];
reg
always @(posedge clk) begin
                                  Synchronous
 if(we)
                                  Write
   mem[a] <= d;
end
                                  Asynchronous
assign q = mem[a];
                                   Read
endmodule
```

http://www-inst.eecs.berkeley.edu/~cs150

# LUT RAM Timing



4

Xilinx Document

# Virtex Block RAM

Every block SelectRAM

- synchronous write
- syncrhronous read
- dual-ported
- independent control signals
- independent data widths
- independent CLKA & CLKB
- 4096-bit RAM



http://www-inst.eecs.berkeley.edu/~cs150

# Virtex Block RAM Timing



#### Sync RD Cycle - worst & best case



#### Async RD Cycle - worst & best case

FPGA RAM (C1)



8

#### WR Cycle – worst & best case



\* timing figures without delay (Ideal case)

**RTL** functional simulation

\* timing figures with delay

Gate level simulation with SDF annotation

# Waveform Viewer Timing (2)



# Waveform Viewer Timing (3)



5/13/16

### LUT as a combination logic block



### LUT : Async Read



#### References

- [1] http://en.wikipedia.org/
- [2] https://en.wikiversity.org/wiki/The\_necessities\_in\_SOC\_Design
- [3] https://en.wikiversity.org/wiki/The\_necessities\_in\_Digital\_Design
- [4] https://en.wikiversity.org/wiki/The\_necessities\_in\_Computer\_Design
- [5] https://en.wikiversity.org/wiki/The\_necessities\_in\_Computer\_Architecture
- [6] https://en.wikiversity.org/wiki/The\_necessities\_in\_Computer\_Organization
- [7] https://en.wikiversity.org/wiki/Understanding\_Embedded\_Software
- [8] Digital Systems, Hill, Peterson, 1987
- [9] http://en.wikipedia.org/

[10] http://www.ele.uri.edu/Courses/ele306/f01/Tinydoc.pdf