This is an old revision of the document!
You have been given a module, VgaDrawer
, that generates the signals necessary to send 640×480 video out over the VGA port on the board.
Internally, the module contains a small memory that stores a bitmap image. This image is continually sent out over the VGA port. For each pixel in the image, 3 bits are stored: 1 bit for red, 1 bit for green, and 1 bit for blue. For example, a pixel set to 3'b000 will display black, 3'b111 white, 3'b100 red, 3'b010 green, 3'b001 blue, 3'b101 magenta, 3'b011 cyan and 3'b110 for yellow.
The bitmap image is 320×240 pixels, and VgaDrawer
automatically scales up the image to the 640×480 resolution that is sent to the monitor. (This is done because the limited memory on the FPGA would make it difficult to store a full 640×480 image).
Module Name = VgaDrawer | |||
---|---|---|---|
Port Name | Direction | Width | Description |
clk | Input | 1 | 100 MHz Clock |
clk_vga | Input | 1 | 25 MHz Clock for 640×480 VGA Display |
reset | Input | 1 | Active-high reset |
x | Input | 9 | x-Coordinate of pixel to modify (0..319) |
y | Input | 8 | y-Coordinate of pixel to modify (0..239) |
color | Input | 3 | Color of pixel. [2]=red, [1]=green, [0]=blue |
wr_en | Input | 1 | Write enable. Set to 1 to enable writing to the bitmap image. |
VGA_R | Output | 4 | VGA Red (to external connection) |
VGA_G | Output | 4 | VGA Green (to external connection) |
VGA_B | Output | 4 | VGA Blue (to external connection) |
VGA_hsync | Output | 1 | VGA Horizontal Sync (to external connection) |
VGA_vsync | Output | 1 | VGA Vertical Sync (to external connection) |
The VgaDrawer
module has inputs that let you change the value of the pixels in the bitmap image, allowing you to draw things on the VGA monitor.
The (x,y) layout of the bitmap is shown below:
The following waveform example demonstrates writing the (35, 40) pixel to red, the (34, 41) pixel to green and the (100, 2) pixel to yellow.
The VgaDrawer
requires a 25MHz clock. This is because the 640×480 VGA standard requires that pixels be sent at a rate of ~25MHz.
You have been given the clk_generator
module that uses special circuity on the FPGA (a Phase-Locked Loop (PLL), https://en.wikipedia.org/wiki/Phase-locked_loop) to derive a new clock based on the input 100MHz clock.
Module Name = clk_generator | |||
---|---|---|---|
Port Name | Direction | Width | Description |
clk_in_100 | Input | 1 | 100 MHz Input Clock |
clk_vga | Output | 1 | 25 MHz Generated Clock |
clk_100 | Output | 1 | 100 MHz Generated Clock |
Note: The clk_generator
module also contains a 100MHz clock output. The reason for this is because once you input your 100MHz clock into the PLL circuity, the tools will not let you use it elsewhere in your design. Thus you will need to use the clk_100
output of this module to clock the rest of your design.