## Lab 9: LCD Controller (2)

Due: May 7, 2015

## **Objective**

To be familiar with how to control the LCD.

## **Action Item**

1. Modify the Verilog code of Unit 8 or Lab 8 to design a LCD controller. The controller has the following input ports:

```
input CLK;
input RESET;
```

and the following output ports:

```
output LCD_ENABLE;
output LCD_RW;
output LCD_DI;
output LCD_CS1;
output LCD_CS2;
output LCD_RST;
output [7:0] LCD_DATA;
```

The behavior of the controller is explained below.

- When the RESET button is pressed, the LCD will be cleaned.
- After releasing the RESET button, the string "HELLO LCD!" (which is stored in pages 3 and 4 of the display data RAM) will move from right to left on the LCD under the frequency of CLK divided by 2<sup>7</sup> (i.e., CLK/2<sup>7</sup>).

Here are some example operations of the controller:

| page0<br>page1<br>page2<br>page3<br>page4<br>page5<br>page6<br>page7 |            | press RESET |
|----------------------------------------------------------------------|------------|-------------|
| :                                                                    | :          |             |
| page0<br>page1<br>page2<br>page3<br>page4<br>page5<br>page6<br>page7 | Н          |             |
| :                                                                    | :          |             |
| page0<br>page1<br>page2<br>page3<br>page4<br>page5<br>page6<br>page7 | HELLO LCD  |             |
| :                                                                    | :          |             |
| page0<br>page1<br>page2<br>page3<br>page4<br>page5<br>page6<br>page7 | HELLO LCD! |             |

```
page0
page1
page2
page3
       HELLO LCD!
page4
page5
page6
page7
page0
page1
page2
page3
       D!
page4
page5
page6
page7
 :
page0
page1
page2
page3
                                         H
page4
page5
page6
page7
```

More details about the I/O signals of the controller are given below.

- CLK: Clock signal which is connected to the FPGA pin R10.
- **RESET:** Asynchronous negative trigger reset which is connected to the pushbutton **S1** (i.e., the FPGA pin **N3**).
- LCD\_ENABLE: signal to enable the LCD, which is connected to the E signal of the LCD (i.e., the FPGA pin F5).
- LCD\_RW: signal to control read or write of the LCD, which is

- connected to the  $R/\overline{W}$  signal of the LCD (i.e., the FPGA pin C2).
- LCD\_DI: signal to indicate data or instruction for the LCD, which is connected to the D/Ī signal of the LCD (i.e., the FPGA pin C1).
- LCD\_CS1: signal to select column 1 ~ 64 of the LCD, which is connected to the CS1 signal of the LCD (i.e., the FPGA pin F4).
- LCD\_CS2: signal to select column 65 ~ 128 of the LCD, which is connected to the CS2 signal of the LCD (i.e., the FPGA pin E1).
- LCD\_RST: signal to reset the LCD, which is connected to the RST signal of the LCD (i.e., the FPGA pin E3).
- LCD\_DATA: data bits for the LCD, which are connected to the DB7~DB0 signals of the LCD (i.e., the FPGA pins F3, D2, D1, H7, G6, E4, D3, F6).