

-Run lab#1 on 2<sup>nd</sup> monitor



# ECE 383 - Embedded Computer Systems II

## Lecture 5 - Combination of Elements and Lab Intro

Official Grades?  
Copy Lab 1 files?  
HDMI Monitor?

# Homework 3 and 4?



- HW4: count 00 to 44, then roll over

roll  
$$\begin{array}{r} 000 \\ 023 \\ 04 \hline 10 \\ 11 \\ 12 \\ 13 \\ 14 \hline 20 \\ 21 \end{array}$$
$$\begin{array}{r} \dots \\ 48 \\ 49 \\ 41 \\ 42 \\ 43 \\ 44 \\ 00 \end{array}$$

- hold works?
- reset works?

00  
01  
02  
03  
04  
04  
10  
11

# Lesson Outline

- 1. Comparator Construction**
- 2. Gated and Non-Gated Circuit**
- 3. Lab 1 Intro**

|    |                                     |                              |                        |                   |
|----|-------------------------------------|------------------------------|------------------------|-------------------|
| L5 | Combinations of elements, lab intro | 7.2                          | HW #5                  | BOC L6            |
| L6 | Lab1 - VGA Synchronization          |                              | Gate Check 1           | COB L6            |
| L7 | Lab1 - VGA Synchronization          |                              | Gate Check 2           | COB L7            |
| L8 | Lab1 - VGA Synchronization          |                              | Lab1 Functionality     | COB L8            |
| L9 | Finite State Machines               | 10.2.1, 10.3.2, 10.4, 10.6.1 | Lab1 Write-up<br>HW #6 | COB L9<br>BOC L10 |

# Glitches

Datasheet

$T_{CO}$   $T_{PD}$

AND 20ps 45ps

OR 15ps 30ps



Suppose A and D change simultaneously,  
but logically the output shouldn't change



Contamination Delay?

Propagation Delay?

Solution?

# Comparator Construction

$E \leftarrow '1'$  when  $A = B$  else  $0$ ;

- How do you make a comparator?



$\rightarrow$  MSB  
0 positive:  $A > B$   
1 negative:  $A < B$   
 $\rightarrow$  ALL Zeros:  $A = B$



- Bit Slice  $\rightarrow$  Cascade

RIPPLE  
=



# Comparator Construction

- You will generate a signal similar to this CSA in Lab 1:  
`h_blank <= '1' when ((h_count >= 100) and (h_synch < 200)) else '0';`
  - This is a Non-Gated output Signal
- Non-Gated signals Generate glitches on the output!
- ~~How is a comparator constructed?~~

# Gated and Non-Gated Circuit

# Gated and Non-Gated Circuit

Take a look at lec05.vhd1



# Gated and Non-Gated Circuit – PMOD Connector

JB PMOD  
Connector



Figure 12. Pmod ports: front view as loaded on PCB.

PMOD connector (see page 20 (Chapter 10) of the Nexys Video Board Reference Manual)

# Gated and Non-Gated Circuit – PMOD Connector



Figure 12. Pmod ports: front view as loaded on PCB.

| PMOD Pinouts |                  |           |              |
|--------------|------------------|-----------|--------------|
| JA1: AB22    | JB1: V9          | JC1: Y6   | JXADC1: J14  |
| JA2: AB21    | JB2: V8          | JC2: AA6  | JXADC2: H13  |
| JA3: AB20    | JB3: V7<br>JB(2) | JC3: AA8  | JXADC3: G15  |
| JA4: AB18    | JB4: W7<br>JB(3) | JC4: AB8  | JXADC4: J15  |
| JA7: Y21     | JB7: W9          | JC7: R6   | JXADC7: H14  |
| JA8: AA21    | JB8: Y9          | JC8: T6   | JXADC8: G13  |
| JA9: AA20    | JB9: Y8          | JC9: AB7  | JXADC9: G16  |
| JA10: AA18   | JB10: Y7         | JC10: AB6 | JXADC10: H15 |

Table 10. Nexys Video Pmod pin assignments.

PMOD connectors (see page 20 (Chapter 10) of the Nexys Video Board Reference Manual) corresponding to JB(3) and JB(2) (the most 2 significant bits of the non-gated comparator outputs)

# Gated and Non-Gated Circuit

## Combinational Realization – Non-gated

```
JB(3 downto 0) <= "0001" when ((processQ >= 0) and (processQ < L0)) else
    "0010" when ((processQ >= L0) and (processQ < L1)) else
    "0100" when ((processQ >= L1) and (processQ < L2)) else
    "1000";
```

## Sequential Realization – Gated

```
process(clk)
begin
    if (rising_edge(clk)) then
        if (reset = '0') then
            JB(6 downto 4) <= "000";
        elsif ((processQ >= 0) and (processQ < L0)) then
            JB(6 downto 4) <= "001";
        elsif ((processQ >= L0) and (processQ < L1)) then
            JB(6 downto 4) <= "010";
        elsif ((processQ >= L1) and (processQ < L2)) then
            JB(6 downto 4) <= "100";
        elsif (processQ >= L2) then
            JB(6 downto 4) <= "111";
        end if;
    end if;
```





UNITED STATES  
AIR FORCE  
ACADEMY



Tek Run

Trig'd

UN  
AIF  
AC

2

1

t



14 Jan 2015  
17:57:37

T→ -517.600ns

14

# Lab 1 Intro

# Analog TV

## -- CRT



# H\_sync and V\_sync

VGA: 640x480 pixels



# H\_sync relative to V\_sync?



what about columns? pixels?

# HW 5 – Lab 1 Prelab

1. Draw a detailed diagram of the oscilloscope grid required for Lab1. A detailed diagram must be drawn on green engineering paper (or computer) and include
  - (x,y) corners of the monitor.
  - (x,y) each of the four major corners (already given).
  - y-coordinates for all the major horizontal grid lines.
  - (x,y) coordinates for one set of three horizontal of hatch marks. Indicate with an arrow which set of three.
  - x-coordinates for all the major vertical grid lines.
  - (x,y) coordinates for one set of four vertical of hatch marks. Indicate with an arrow which set of four.

VGA: 640x480 pixels

# HW 5 – Lab 1 Prelab



## HW 5 – Lab 1 Prelab

$$T = 1/F = \underline{\hspace{2cm}}$$

2. Given that the pixel clock is running at  $F = \boxed{25\text{Mhz}}$ , add the durations of the h\_sync and v\_sync signals show in Lab1. Set time=0 on the blue dashed line on the left side of the region labeled "Active Video".

w3schools.com/colors/  
names.asp



# HW 5 – Lab 1 Prelab

- Given that the pixel clock is running at 25Mhz, add the durations of the h\_synch and v\_synch signals show in Lab1. Set time=0 on the blue dashed line on the left side of the region labeled "Active Video".



# Lab 1 Intro – VGA Overview

- [https://www.w3schools.com/colors/colors\\_names.asp](https://www.w3schools.com/colors/colors_names.asp)

## RGB

Black R =                    G =                    B =

White R =                    G =                    B =

Green R =                    G =                    B =

Blue R =                    G =                    B =

Yellow R =                    G =                    B =

Not complete!

# Lab 1 Intro – Architecture

Lab1



Video



btn  
clk  
reset\_n

pixel\_clk  
reset\_n

tr\_volt  
tr\_time

ctrl  
ctrl

ch1  
ch1\_enb

ch2  
ch2\_enb

VGA



Hw

Hw3



Serialize\_clk  
Serialize\_clk\_n



DVI  
HDMI

Switch(1)  
switch(0)

Gated logic?

blank <= h\_blank \_\_\_\_ v\_blank;

24

entity vga is

|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port( | clk: in STD_LOGIC;<br>reset_n : in STD_LOGIC;<br>h_sync : out STD_LOGIC;<br>v_sync : out STD_LOGIC;<br>blank : out STD_LOGIC;<br>r: out STD_LOGIC_VECTOR(7 downto 0);<br>g: out STD_LOGIC_VECTOR(7 downto 0);<br>b: out STD_LOGIC_VECTOR(7 downto 0);<br>trigger_time: in unsigned(9 downto 0);<br>trigger_volt: in unsigned (9 downto 0);<br>row: out unsigned(9 downto 0);<br>column: out unsigned(9 downto 0);<br>ch1: in std_logic;<br>ch1_enb: in std_logic;<br>ch2: in std_logic;<br>ch2_enb: in std_logic); |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

end vga;

# VGA Module

|                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>clk</b>      | This is the 25Mhz pixel clock generated by the DCM in the video module.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>reset_n</b>  | This is the same active low reset signal passed into the top level Lab1 module.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <b>tr_volt</b>  | This is a 10-bit unsigned value representing the trigger voltage. This value is passed to the scopeFace module so that a yellow arrow (see Trigger Level Marker in the screen show) on the vertical axis.                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <b>tr_time</b>  | This is a 10-bit unsigned value representing the trigger time. This value is passed to the scopeFace module so that a yellow arrow (see Trigger Time Marker in the screen show) on the horizontal axis.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>ch1</b>      | This 1-bit signal signals the VGA module to draw the channel 1 signal on the scope for this row, column pixel. When the value is 1, draw a yellow pixel on the display at the current row,colum position. When 0, do not draw a pixel.                                                                                                                                                                                                                                                                                                                                                                                                        |
| <b>ch1_enb</b>  | This 1-bit signal enable the ch1 signal to be drawn.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <b>ch2</b>      | This 1-bit signal signals the VGA module to draw the channel 2 signal on the scope for this row,column pixel. When the value is 1, draw a green pixel on the display at the current row, column position. When 0, do not draw a pixel.                                                                                                                                                                                                                                                                                                                                                                                                        |
| <b>ch2_enb</b>  | This 1-bit signal enable the ch2 signal to be drawn.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <b>R</b>        | The 8-bit red intensity for this row,column pixel on the screen.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| <b>G</b>        | The 8-bit green intensity for this row,column pixel on the screen.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <b>B</b>        | The 8-bit blue intensity for this row,column pixel on the screen.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| <b>Row</b>      | The current row being drawn on the display.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>Column</b>   | The current row being drawn on the display.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| <b>blank</b>    | The blank signal for the current row,column position. Its the logical OR of the h_blank and v_blank signals.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>h_synch</b>  | The h_synch signal for the current row,column position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>v_synch</b>  | The v_synch signal for the current row,column position.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>Behavior</b> | The VGA component contains a pair of cascaded counters which generate the row and column values of the current pixel being displayed. The row and column values are used to generate the blank, h_synch and v_synch signals according to the Figures above. The scopeFace component (more on this below), takes the row and column values (along with some other information) and generates the R,G,B color of that pixel. The three muxes on the output of the R,G,B output of the scopeFace component output the scopeFace R,G,B values for row,column values within the 640x480 displayable region, or 0's for values outside this region. |

# scopeFace Module

entity scopeFace is

Port ( row : in unsigned(9 downto 0);  
column : in unsigned(9 downto 0);  
trigger\_volt: in unsigned (9 downto 0);  
trigger\_time: in unsigned (9 downto 0);  
r : out std\_logic\_vector(7 downto 0);  
g : out std\_logic\_vector(7 downto 0);  
b : out std\_logic\_vector(7 downto 0);  
ch1: in std\_logic;  
ch1\_enb: in std\_logic;  
ch2: in std\_logic;  
ch2\_enb: in std\_logic);

end scopeFace;



# ScopeFace Module

|                 |                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>clk</b>      | This is the 25Mhz pixel clock generated by the DCM in the video module.                                                                                                                                                                                                                                                                                                                         |
| <b>reset_n</b>  | This is the same active low reset signal passed into the top level Lab1 module.                                                                                                                                                                                                                                                                                                                 |
| <b>tr_volt</b>  | This is a 10-bit unsigned value representing the trigger voltage. This value is passed to the scopeFace module so that a yellow arrow (see Trigger Level Marker in the screen show) on the vertical axis.                                                                                                                                                                                       |
| <b>tr_time</b>  | This is a 10-bit unsigned value representing the trigger time. This value is passed to the scopeFace module so that a yellow arrow (see Trigger Time Marker in the screen show) on the horizontal axis.                                                                                                                                                                                         |
| <b>ch1</b>      | This 1-bit signal signals the VGA module to draw the channel 1 signal on the scope for this row, column pixel. When the value is 1, draw a yellow pixel on the display at the current row,column position. When 0, do not draw a pixel.                                                                                                                                                         |
| <b>ch1_enb</b>  | This 1-bit signal enable the ch1 signal to be drawn.                                                                                                                                                                                                                                                                                                                                            |
| <b>ch2</b>      | This 1-bit signal signals the VGA module to draw the channel 2 signal on the scope for this row,column pixel. When the value is 1, draw a green pixel on the display at the current row, column position. When 0, do not draw a pixel.                                                                                                                                                          |
| <b>ch2_enb</b>  | This 1-bit signal enable the ch2 signal to be drawn.                                                                                                                                                                                                                                                                                                                                            |
| <b>R</b>        | The 8-bit red intensity for this row,column pixel on the screen.                                                                                                                                                                                                                                                                                                                                |
| <b>G</b>        | The 8-bit green intensity for this row,column pixel on the screen.                                                                                                                                                                                                                                                                                                                              |
| <b>B</b>        | The 8-bit blue intensity for this row,column pixel on the screen.                                                                                                                                                                                                                                                                                                                               |
| <b>Row</b>      | The current row being drawn on the display.                                                                                                                                                                                                                                                                                                                                                     |
| <b>Column</b>   | The current row being drawn on the display.                                                                                                                                                                                                                                                                                                                                                     |
| <b>Behavior</b> | The scopeFace component takes in the current row,column coordinates of the display and generates the R,G,B values at that screen coordinate. For example, if row,column = 20,20 then the R,G,B output should be 0xFF,0xFF,0xFF (white) because the upper left corner of the O'scope grid display is white. Note, you can get the RGB values for common colors at <a href="#">this</a> web site. |

# Scopeface: just CSA code

• how to make an ~~X~~

ch1 <= '1' when

ch2 <= '1' when

■ gridH <= '1' when row = \_\_ or row = \_\_ or ...

■ gridV <= '1' when col = \_\_ or col = \_\_ or ...

■ white <= '1' when gridH = '1' or gridV = '1' or ...

■ r <= "11111111" when white = '1' or ch1 = '1' or...  
*and ch1.enable = '1'*

■ g <= "11111111" when white = '1' or ch1 = '1' or

ch2 = '1' or ...

■ b <= "11111111" when white = '1' or ...  
*and ch2.enable = '1' ?*

Triangle <= '1' when



# Lab 1 Connections



# Setup code for lab1

- Create a lab 1 project in Vivado
- Copy code from
  - [https://georgeyork.github.io/ECE383\\_web/lab/lab1/lab1.html](https://georgeyork.github.io/ECE383_web/lab/lab1/lab1.html)  
(middle of the webpage)      or Teams → Lab1\_cadet.zip
  - Add files to the project
- Save to bitbucket repo

# Digital Clocking Wizard

How to convert a 100 MHz clock  
to a 25 MHz clock and a 125 MHz clock?

## ■ Xilinx Clocking Wizard Page:

- [https://www.xilinx.com/products/intellectual-property/clocking\\_wizard.html](https://www.xilinx.com/products/intellectual-property/clocking_wizard.html)

## ■ Clocking Wizard v5.3 - LogiCORE IP Product Guide:

- [https://www.xilinx.com/support/documentation/ip\\_documentation/clk\\_wiz/v5\\_3/pg065-clk-wiz.pdf](https://www.xilinx.com/support/documentation/ip_documentation/clk_wiz/v5_3/pg065-clk-wiz.pdf)

# Digital Clocking Wizard

- Click on IP Catalog
- Search for Clocking Wizard IP



# Digital Clocking Wizard



# Digital Clocking Wizard



# Digital Clocking Wizard



# Digital Clocking Wizard



# Digital Clocking Wizard



# Digital Clocking Wizard



# Digital Clocking Wizard

## ■ Verify Component Declaration in video.vhd

-- Clock Wizard Component Instantiation Using Xilinx Vivado

```
component clk_wiz_0 is
Port (
    clk_in1 : in STD_LOGIC;
    clk_out1 : out STD_LOGIC;
    clk_out2 : out STD_LOGIC;
    clk_out3 : out STD_LOGIC;
    resetn : in STD_LOGIC);
end component;
```

## ■ Verify Component Instantiation in video.vhd

# Digital Clocking Wizard

## ■ Verify Component Instantiation in video.vhd

-- Digital Clocking Wizard using Xilinx Vivado creates 25Mhz pixel clock and  
-- 125MHz HDMI serial output clocks from 100MHz system clock. The Digital  
-- Clocking Wizard is in the Vivado IP Catalog.

`mmcm_adv_inst_display_clocks: clk_wiz_0`

`Port Map (`

- `clk_in1 => clk,`
- `clk_out1 => pixel_clk, -- 25Mhz pixel clock`
- `clk_out2 => serialize_clk, -- 125Mhz HDMI serial output clock`
- `clk_out3 => serialize_clk_n, -- 125Mhz HDMI serial output clock 180`  
`degrees out of phase`
- `resetn => reset_n); -- active low reset for Nexys Video`

# Lesson Outline

1. Comparator Construction
2. Gated and Non-Gated Circuit
3. Lab 1 Intro

See Gradescope GC1

-- State what was achieved?

achieved → details

partially achieved → details

not achieved