## Name:

## COE 405, Term 181

## **Design & Modeling of Digital Systems**

## Quiz#6

Date: Sunday, Dec. 9, 2018

**Q.1.** Fill in the blank in each of the following questions:

(1) Three advantages of using FPGAs over ASICs are \_\_\_\_\_

(2) Two types of FPGA technologies are \_\_\_\_\_

(3) In FPGAs, each configurable logic block (CLB) has a number of the following two main blocks: \_\_\_\_\_\_.

(4) Each IOB can be configured to work as \_\_\_\_\_\_ or \_\_\_\_\_.

- (5) Modern FPGAs, in addition to having CLBs and IOBs, have the following components: \_\_\_\_\_\_.
- (7) The difference between simple dual port and true dual port RAM is that \_\_\_\_\_
- (8) To have a RAM with synchronous read, the RAM must be implemented using

\_\_\_\_\_

- (9) Using a Block RAM with Read\_First write mode means that when the memory is written it will \_\_\_\_\_\_.
- (10) Using a Block RAM with No\_Change write mode means that when the memory is written it will \_\_\_\_\_\_.
- **Q.2.** Write a parametrizable Verilog model for modeling a memory with a simple dual port memory with synchronous read and write by completing the following module:

module Memory\_Unit#(parameter word\_size=8, address\_size=8, memory\_size=256)(
output reg [word\_size-1:0] data\_out1,
output reg [word\_size-1:0] data\_out2,
input [word\_size-1:0] data\_in,
input [address\_size-1:0] address1,
input [address\_size-1:0] address2,
input clk, write);

**Q.3.** Consider the logic network defined by the following expression:

x = a b d' e' + a' c' d' e' + a b' d + a b' e + a' c d + a' c e

Compute the weight of the double cube divisors  $d_1 = a b + a' c'$  and  $d_2 = d + e$ . Extract the double cube divisor with the highest weight and show the resulting network after extraction and the number of literals saved.