### ELEX 2117 : Digital Techniques 2 2021 Fall Term

## FINAL EXAM 14:30 – 17:30 Tuesday, December 7, 2021 SW09-110

This exam has eleven (11) questions on six (6) pages. The marks for each question are as indicated. There are a total of twenty-seven (27) marks. Answer all questions. Write your answers and all rough work in this paper and nowhere else. Show your work. Draw a box around your final answer. Numerical answers must include units. Books and notes are allowed. No electronic devices other than calculators are allowed. **Show your work**.

This exam paper is for:

# Sample Exam 1 A0000000

Each exam is equally difficult.

Answer your own exam.

Do not start until you are told to do so.

Name: \_\_\_\_\_

BCIT ID:

Signature:

| Question | Mark | Max. |
|----------|------|------|
| 1        |      | 3    |
| 2        |      | 2    |
| 3        |      | 1    |
| 4        |      | 2    |
| 5        |      | 4    |
| 6        |      | 2    |
| 7        |      | 4    |
| 8        |      | 1    |
| 9        |      | 5    |
| 10       |      | 1    |
| 11       |      | 2    |
| Total    |      | 27   |

### Given the following Verilog code:

```
module ex50
  ( input logic reset, clock,
    output logic [3:0] count ) ;
  logic [3:0] count_next ;
  assign count_next
    = reset ? 4'd1 :
      count + 4'd2 ;
    always_ff @(posedge clock) count = count_next ;
endmodule
```

and the input signals in the diagram below, draw a vertical line between the dashed lines where the **count** output changes and write the value of **count** in-between each vertical line. Write an **X** if the value is undefined.



## **Question 2**

2 marks



In the timing diagram above x and y are outputs, P and Q are inputs, and a through d are timing specifications. Write the letters corresponding to the timing specifications that are timing requirements and guaranteed responses in the appropriate boxes below. Each box should have zero or more of the letters a through d.

| timing requirements | guaranteed responses |
|---------------------|----------------------|
|                     |                      |

Given the following Verilog declarations:

logic [3:0] x = 4'b0101 ; logic [7:0] y = 8'h4e ;

fill in in the table below with the value of the each expression in hexadecimal and the width (number of bits) in decimal:

| expression | value (hexadecimal) | width (bits, decimal) |
|------------|---------------------|-----------------------|
| {x,y}      |                     |                       |
| y[5:2]     |                     |                       |
| x+5'b1     |                     |                       |
| y>>2       |                     |                       |



The waveform above is measured on an SPI interface. What value was transferred from the master to the slave? Give your answer as a hexadecimal number. Assume the bits are transferred most-significant-bit first.

A module with inputs reset and run, and a clock signal, clock, is declared as:

```
module statemachine
  ( input logic reset, run, clock ) ;
  logic [1:0] state, state_next ;
  // your code here
endmodule
```

The module's behaviour can be described as a state machine with four states that have values 0 through 3. The state transitions are as described in the state transition diagram below:



Write Verilog statements below that, if placed after the comment, would result in the behaviour described in the state transition diagram above. Do not repeat code already given. Follow the course coding conventions.

### **Question 6**

### 2 marks

The maximum propagation delay through any combinational logic path in a CPLD is 18 ns, the minimum setup time of its registers is 1.5 ns and the maximum clock-to-output delay is 0.5 ns. What is the fastest clock frequency at which this CPLD can operate?

You need to design a 1 MByte memory for a 16-bit CPU using 256 k  $\times$  4 memory ICs.

- (a) How many IC's will be needed?
- (b) How many banks will this memory require?
- (c) How many address bits does each memory IC have?
- (d) If an address decoder places the first byte of this memory at address **0x100000**, what is the last address in this 1 MByte memory?

## **Question 8**

### 1 marks

The schematic below shows a CMOS NAND gate with the four transistor numbered from 1 to 4. Which transistors are on (conducting) when the output is low? You answer should be between zero and four digits. Both **A** inputs are at the same logic level. Both **B** inputs are at the same logic level.

$$A \xrightarrow{Vdd} 3$$

$$A \xrightarrow{-d} B \xrightarrow{-d} 3$$

$$A \xrightarrow{-d}$$

For each term in the left column write the number of the most appropriate match in the right column. There is only one best match for each term. No marks will be deducted for wrong answers.

| totem pole     | (1) through-hole |
|----------------|------------------|
| PLD            | (2) FPGA         |
| RAM            | (3) pull-up      |
| DIP            | (4) CMOS         |
| open-collector | (5) volatile     |

## **Question 10**

## 1 marks

A logic signal interface has an output low logic level of  $V_{OL(max)}$  of 0.5 V and a  $V_{IL(max)}$  of 1.5 V. What is the noise margin for low logic levels?

## Question 11

### 2 marks

A CMOS digital logic circuit is operating with a supply voltage of 5 V at a clock frequency of 5 MHz. You want to reduce the power consumption of this circuit by a factor of 10 (i.e. by 90%).

(i) If you were to change only the clock frequency, what frequency would you need to use?

(ii) If you were to change only the supply voltage, what voltage would you need to use?



## FINAL EXAM 14:30 – 17:30 Tuesday, December 7, 2021 SW09-110

This exam has eleven (11) questions on six (6) pages. The marks for each question are as indicated. There are a total of twenty-seven (27) marks. Answer all questions. Write your answers and all rough work in this paper and nowhere else. Show your work. Draw a box around your final answer. Numerical answers must include units. Books and notes are allowed. No electronic devices other than calculators are allowed. **Show your work**.

This exam paper is for:

# Sample Exam 2 A0000000

Each exam is equally difficult.

Answer your own exam.

Do not start until you are told to do so.

Name: \_\_\_\_\_

BCIT ID: \_\_\_\_\_

Signature:

| Question | Mark | Max. |
|----------|------|------|
| 1        |      | 3    |
| 2        |      | 2    |
| 3        |      | 1    |
| 4        |      | 2    |
| 5        |      | 4    |
| 6        |      | 2    |
| 7        |      | 4    |
| 8        |      | 1    |
| 9        |      | 5    |
| 10       |      | 1    |
| 11       |      | 2    |
| Total    |      | 27   |

### Given the following Verilog code:

```
module ex50
  ( input logic reset, clock,
    output logic [3:0] count ) ;
  logic [3:0] count_next ;
  assign count_next
    = reset ? 4'd2 :
        count + 4'd1 ;
    always_ff @(posedge clock) count = count_next ;
endmodule
```

and the input signals in the diagram below, draw a vertical line between the dashed lines where the **count** output changes and write the value of **count** in-between each vertical line. Write an **X** if the value is undefined.



## **Question 2**

2 marks



In the timing diagram above x and y are inputs, P and Q are outputs, and a through d are timing specifications. Write the letters corresponding to the timing specifications that are timing requirements and guaranteed responses in the appropriate boxes below. Each box should have zero or more of the letters a through d.

| timing requirements | guaranteed responses |
|---------------------|----------------------|
|                     |                      |

A00000000

Given the following Verilog declarations:

logic [3:0] x = 4'b1010 ; logic [7:0] y = 8'h5e ;

fill in in the table below with the value of the each expression in hexadecimal and the width (number of bits) in decimal:

| expression | value (hexadecimal) | width (bits, decimal) |
|------------|---------------------|-----------------------|
| {x,y}      |                     |                       |
| y[5:2]     |                     |                       |
| x+5'b1     |                     |                       |
| y>>2       |                     |                       |



The waveform above is measured on an SPI interface. What value was transferred from the slave to the master? Give your answer as a hexadecimal number. Assume the bits are transferred most-significant-bit first.

A module with inputs reset and run, and a clock signal, clock, is declared as:

```
module statemachine
  ( input logic reset, run, clock ) ;
  logic [1:0] state, state_next ;
  // your code here
endmodule
```

The module's behaviour can be described as a state machine with four states that have values 0 through 3. The state transitions are as described in the state transition diagram below:



Write Verilog statements below that, if placed after the comment, would result in the behaviour described in the state transition diagram above. Do not repeat code already given. Follow the course coding conventions.

### **Question 6**

### 2 marks

The maximum propagation delay through any combinational logic path in a CPLD is 8 ns, the minimum setup time of its registers is 1.5 ns and the maximum clock-to-output delay is 0.5 ns. What is the fastest clock frequency at which this CPLD can operate?

You need to design a 1 MByte memory for a 16-bit CPU using 256 k  $\times$  4 memory ICs.

- (a) How many IC's will be needed?
- (b) How many banks will this memory require?
- (c) How many address bits does each memory IC have?
- (d) If an address decoder places the first byte of this memory at address **0x100000**, what is the last address in this 1 MByte memory?

## **Question 8**

### 1 marks

The schematic below shows a CMOS NAND gate with the four transistor numbered from 1 to 4. Which transistors are on (conducting) when the output is low? You answer should be between zero and four digits. Both **A** inputs are at the same logic level. Both **B** inputs are at the same logic level.

$$A \xrightarrow{Vdd} 2$$

$$A \xrightarrow{-d} B \xrightarrow{-d} 2$$

$$A \xrightarrow{-d} B \xrightarrow{-d} 3$$

$$B \xrightarrow{-d} 4$$

$$\xrightarrow{-d} 3$$

For each term in the left column write the number of the most appropriate match in the right column. There is only one best match for each term. No marks will be deducted for wrong answers.

| totem pole     | (1) FPGA         |
|----------------|------------------|
| PLD            | (2) through-hole |
| RAM            | (3) volatile     |
| DIP            | (4) pull-up      |
| open-collector | (5) CMOS         |

## **Question 10**

## 1 marks

A logic signal interface has an output low logic level of  $V_{0L(max)}$  of 0.7 V and a  $V_{IL(max)}$  of 1.4 V. What is the noise margin for low logic levels?

## **Question 11**

### 2 marks

A CMOS digital logic circuit is operating with a supply voltage of 5 V at a clock frequency of 10 MHz. You want to reduce the power consumption of this circuit by a factor of 10 (i.e. by 90%).

(i) If you were to change only the clock frequency, what frequency would you need to use?

(ii) If you were to change only the supply voltage, what voltage would you need to use?