# SRAM based FPGAs (2A)

Young Won Lim 2/6/19 Copyright (c) 2019 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.

The VLSI Handbook, edited by Wai-Kai Chen, CRC

Any horizontal line and any vertical line can be connected At some cross points by controlling a flip-flop

a flip-flop has one : connect a flip-flop has zero : disconnect

A flip-flop is a one memory cell of SRAM

- a pass transistor
- a transmission gate
- Multiplexer

A horizontal and a vertical line are

the input of one block and the output of other block

#### Manufacturer of SRAM based FPGAs

SRAM based FPGAs : Xilinx and Atmel

Focus on Xilinx XC4000

A logic block contain SRAM and flip-flops

Each block is connected to nearby one-line segment

A switch matrix :

a square shaped representation a set of multiplexers connecting one outgoing line segment of a block and one incoming line segment of another block connecting many line segments to form long lines connecting global long lines to form longer lines with a fewer number of segments without causing much delay Each logic block has

- SRAMs for table look-up function
- Several flip-flops

These memory elements can be used

Xilinx calls logic block CLB (Configurable Logic Block)

## Configurable Logic Block (1)

- A pair of flip-flops
  - Edge triggered D-type flip-flop
  - rising edge or falling edge is selected
  - Common clock input K
  - Clock Enable input EC
  - Asynchronous Set/Reset S/R input
  - XQ, YQ outputs
  - D input is selected from DIN, F', G', and H'

## Configurable Logic Block (2)

- 2 independent 4-input function generators
  - realized by SRAM
  - Any 4-input logic function
  - F' and G' outputs
  - F1~F4, G1~G4 inputs
  - Dedicated arithmetic / logic unit
    - For fast generation of carry / borrow
    - Adders / substractors / accumulators / comparators
- Multiplexers map
  - 4 control inputs C1~C4
    - onto H1, DIN, S/R, EC

## Configurable Logic Block (3)

- 3<sup>rd</sup> function generator
  - F', G', H1 : 3 inputs
  - H' output
- CLB outputs X and Y
  - X is selected from H' and F'
  - Y is selected from H' and G'
- A CLB can realize
  - Any two independent 4-input functions
  - Any one 5-input function
  - Any one 4-input function and some 5-input functions
  - Some 9-input functions
- Realizing variety of functions in a single logic block
  - Size
  - speed

#### References

- [1] ftp://ftp.geoinfo.tuwien.ac.at/navratil/HaskellTutorial.pdf
- [2] https://www.umiacs.umd.edu/~hal/docs/daume02yaht.pdf