





















| Example fro<br>available FII                                                                                                             | m a commercially<br>FO IP component                                                                                                                                  |
|------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| An error occurs if a push is attemp                                                                                                      | pted while the FIFO is full.                                                                                                                                         |
| Thus, there is no conflict in a simu<br>simultaneous push and pop cannot<br>data to prefetch. However, push da                           | Itaneous push and pop when the FIFO is full. A<br>occur when the FIFO is empty, since there is no pop<br>ta is captured in the FIFO.                                 |
| A pop operation occurs when pop<br>empty. Asserting pop_req_n cause<br>next rising edge of clk. Thus, the<br>the assertion of pop_req_n. | _req_n is asserted (LOW), as long as the FIFO is not<br>es the internal read pointer to be incremented on the<br>RAM read data must be captured on the clk following |
| data_in data_out                                                                                                                         |                                                                                                                                                                      |
| push_req_n full<br>pop_req_n empty<br>clk<br>rstn                                                                                        | These constraints are taken<br>from several paragraphs of<br>documentation, spread over<br>many pages, interspersed<br>with other text                               |
| February 22, 2005 http:                                                                                                                  | //csg.csail.mit.edu/6.884/ L07-12                                                                                                                                    |



















| Generated Verilog RTL · ccp                                           |
|-----------------------------------------------------------------------|
| Ocherated Verhog RTL. 000                                             |
| modulo mbGGD(GIK DGE N stort 1 stort 2 E stort )                      |
| input CLK.                                                            |
| output start rdy:                                                     |
| wire [31 : 0] x\$get;                                                 |
| assign result_ = x\$get;                                              |
| assign _d5 = y\$get == 32'd0;                                         |
|                                                                       |
| assign _d3 = x\$get ^ 32'h80000000) <= (y\$get ^ 32'h80000000);       |
| assign C2 = _d3 && !_d5;                                              |
|                                                                       |
| $assign x$set 1 = P = 1 2 x$get \cdot start 1.$                       |
| assign P $2 = d3 \&\& ! d5;$                                          |
| ····                                                                  |
| assign y\$set_1 =                                                     |
| {32{P2}} & y\$get - x\$get   {32{_dt1}} & x\$get                      |
| {32{_dt2}} & start2;                                                  |
| <pre>RegUN #(32) i_x(.CLK(CLK), .RST_N(RST_N), .val(x\$set_1),)</pre> |
| RegN #(32) i_y(.CLK(CLK), .RST_N(RST_N), .init(32'd0),)               |
| enamoaule                                                             |
| February 22, 2005 http://csg.csail.mit.edu/6.884/ L07-                |











| LPM<br>versions | Code<br>size<br>(lines) | Best Area<br>(gates) | Best Speed<br>(ns)   | Mem. uti<br>(random<br>workload |
|-----------------|-------------------------|----------------------|----------------------|---------------------------------|
| Static V        | 220                     | 2271                 | 3.56                 | 63.5%                           |
| Shane RSV       | 179                     | 12391 (5% larger)    | 0.32 (7//sitester) - | 63.5%                           |
| Linear V        | 410                     | 14759                | 4.7                  | 99.9%                           |
| Linear BSV      | 168                     | 15910 (8% larger)    | 4.7 (same)           | 99.9%                           |
| Circular V      | 364                     | 8103                 | 3.62                 | 99.9%                           |
| Circular BSV    | 257                     | 8170 (1% larger)     | 3.67 (2% slower)     | 99.9%                           |
|                 |                         |                      | Synthesis: TS        | SMC 0.18                        |
| Bluespec re     | esults c                | an match carefi      | ully coded Veril     | og                              |
| Mioro orahi     | tootuno                 | bac a dramatic       | impact on nor        | formono                         |















