module xpos ( input logic run, clock) output logic [7:0] X logic (7:6) s; always-ff e(posedge clock) S = run 7 S=1; 0; always-ff e(posedge clock) x = run, x+ s/2; 0 en amodule | expression | value | 0111 800 166 \$10 | | | |------------------------------|---------|------------------------|--|--| | $\{x[3:0], y[3:0], x[7:4]\}$ | 12'he9a | = 0101 0011 | | | | !x&& x | 1'h0 | 160 | | | | ~X)X | 8'h ff | ~ X + X | | | | x << 2 + 2'd3 | g'h 80 | <del>1</del> 1101 6011 | | | | <u>y/2</u> | 32/h4 | (1)01(1 11)1 | | | | x[3:0] > y | 1'h 1 | 1010 1100 | | | | <u>x^y</u> | 8 ha5 | 1 0000 1001 | | | | x[0] ? x : y | 8 ' h 9 | 1010,0102 | | | | | | - | | | | | <u> </u> | | | | |-------------|----------------------|------------------------------------------|---------------------------|--------------------------------------| | signal name | truth value<br>(T/F) | truth value in<br>an expression<br>(0/1) | ₩<br>logic level<br>(H/L) | Verilog value<br>when input<br>(0/1) | | busy | Ĭ. | <b>1</b> T | Ŀ | 0 -> L | | dark | F | o F | L | D -> L | | even* | Ŀ | ا 0 | Н | 1 ->H | | short | 7 | 1 1 | L | 0 -> L | olusy-ff @ (possed ge dock) state == 2'600 && P? 2'601: state == 2'60 | && n? 2'611: State == 2'b10 && P? 2'b11: State == 2'b11 && P? 2'b10: State == 2'b10 && n? 2'b01: State == 2'b01 && P? 2'b00: state; The maximum propagation delay through any combinational logic path in a CPLD is 17 ns, the minimum setup time of its registers is 2 ns and the maximum clock-to-output delay is 1 ns. What is the fastest clock frequency at which this CPLD can operate? Question 7 2 marks A digital power quality analyzer needs to measure the level of harmonics up to the 50'th harmonic of the 60 Hz power line frequency (i.e. up to 3000 Hz) with a quantization SNR of over 80 dB. What minimum ADC sampling rate is required? What number of bits of resolution is required? Question 8 ∠ marks You are choosing the logic levels for a new design and need to maintain a noise margin of 1.5 V for both high and low logic levels. $V_{\text{IL}(\text{max})}$ is 2 V and $V_{\text{IH} (\text{min})}$ is 3 V. What are $V_{\text{OL}(\text{max})}$ and $V_{\text{OH}(\text{min})}$ ? $$V_{OH}$$ $(min) = V_{IH}$ $(min) + 1.5U$ $= 3 + 1.5$ $V_{OH}$ $(min) = 4.5V$ $V_{OL}$ $(max) = V_{IL}$ $(max) - 1.5V$ $= 2 - 1.5$ $V_{OL}$ $(max) = 0.5V$ Question 9 2 marks A CMOS digital logic circuit operates from a 1.5 V battery for 20 hours before the battery is exhausted. How long would the same battery last if the clock frequency was reduced by a factor of 20? Hint: Battery life is inversely proportional to current consumption. 20? Hint: Battery life is inversely proportional to current consumption. $$\frac{P_2}{P_1} = \frac{f_2}{f_1} \left( \frac{V_2}{V_1} \right)^2 \qquad \frac{P_2}{F_1} = \frac{V_2}{V_1} \frac{V$$ Question 10 1 marks Draw the schematic of a two-input NOR gate with an open-drain output. Use MOSFET transistors. 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. | fabless | * | | |---------|---|--| | die | 7 | | | TQFP | 4 | | | wafer | 5 | | | CPLD | 3 | | - (1) manufacturer - (2) chip - (3) programmable - (4) package - (5) 300 mm Write a Verilog module named **alu** corresponding to the diagram shown below. The module has a **w** in input **B**, a 2-bit input **op**, a clock input **clk**, and a **w**-bit registered output **A**. The module declaration should include a parameter named **w** for the bus widths with a default value of 16. The use of the signals **x** and **y** is optional but they must be declared if they're used. Bits should be numbered in decreasing order. Follow the course coding conventions. You may omit comments. always = ff @ (posedge dk) A = op[i]:? x: y; a ssign $$x = op [o]? A+B:A&B$$ a ssign $y = op [o]? A>>1:A <<1;$ end module ``` logic [7:0] x = 8'h5a ; logic [3:0] y = 4'b0011 ; ``` | | T | |-----------------|-------| | expression | value | | {x[3:0],x[7:4]} | | | !x x | | | ~x x | | | x >> 1 + 1'b1 | | | 2*y | | | x[1:0] > y | | | x^y | | | !y ? x : x^y | | Question 3 5 marks Draw the waveforms that would be used to transfer a byte that has the value 8'h53 (in Verilog notation) from the <u>slave</u> to the <u>master over</u> an SPI interface. Draw the waveforms for $\overline{SS}$ , and the appropriate data signal (either MOSI or MISO, but not both). Follow the conventions shown in the lecture notes, including the timing of $\overline{SS}$ relative to the data, the data relative to SCLK, and that the most significant bit is transferred first. MISO Question 5 Silvan Write the state transition table for a state machine that has the following state transition diagram. The state machine has two one-bit inputs: $\mathbf{r}$ and $\mathbf{f}$ . The value in each circle is the 2-bit binary encoding of that state. The Verilog expression above a state transition defines the condition for a transition between the two states. Conditions that do not result in a change of state are not shown. Include columns for the current state, the r and f inputs, and the next state. You may use the conventions described in the lecture notes including x for "don't-care." You need not include input conditions that do not result in a change of state. | | 00 | | r && f | 00<br>00<br>00 | 00<br>01<br>10<br>11 | 00 | |---------|----------|---|--------|----------------|----------------------|-----------------------| | Covernt | - inputs | ſ | - next | | | | | 5tate | τ | 1 | Stole | | | | | 00 | \ | 0 | 0 - | | | | | 00 | 1 | \ | [ ] - | | | | | 0\ | 1 | Х | 10 - | | | | | (0) | | χ | 1 - | | $\sqrt{}$ | 1 ( | | ( ) | , ( | Χ | 00- | | Y & & / | ! <del>+</del><br>- — | | | 1 | | SE | V = | \ | $\bigcirc$ | | S | $\times$ | Χ | | V | 1 1 | | | | | | | | | |