Interfacing LCD with PIC Microcontroller – CCS C
In this tutorial we will see How to interface a 16×2 character LCD Module with PIC 16F877A Microcontroller using CCS C Compiler. 16×2 character LCD is a very commonly used LCD module in electronic projects and products. 16×2 means it can display 2 rows of 16 characters. It is a very basic and low cost module. Its other variants such as 16×1, 20×4 are available in the market. In these displays each character is displayed using 5×8 or 5×10 dot matrix. These LCDs commonly uses HD44780 compliant controllers for their operation.
Interface between a microcontroller and LCD can be 4-bit or 8-bit. The difference between 4-bit and 8-bit is how data are send to the LCD. To write an 8-bit character to the LCD module in 8-bit mode, ASCII data is send through the data lines DB0- DB7 and data strobe is given through the E line.
But 4-bit mode uses only 4 data lines. In this mode the 8-bit ASCII data is divided into 2 parts which are send sequentially through data lines DB4 – DB7 with its own data strobe through the E line. The idea of 4-bit communication is to save as much pins that used to interface with LCD. The 4-bit communication is a bit slower when compared to 8-bit. The speed difference is only minimal, as LCDs are slow speed devices the tiny speed difference between these two modes is not significant. Remember that our microcontrollers works in the speed of MHz range. Thus the 4-bit mode data transmission is most commonly used.
CCS C provides a built in library file, “lcd.c” for interfacing LCDs having HD44780 compliant controllers using 4-bit mode communication. Just include this file in your program and enjoy.
CCS C LCD Library
For the proper functioning of LCD Library, you should define the connections of below 7 pins used for LCD interfacing in the program.
- Enable – E or EN
- Register Select – RS
- Read / Write – RW
- Data 4 – DB4 or D4
- Data 5 – DB5 or D5
- Data 6 – DB6 or D6
- Data 7 – DB7 or D7
These must be defined before including the header file, it can be done in two ways as given below.
PORT Access Method
This method requires the entire 7 bit interface connected to same GPIO port. It should be defined before including the header file as shown below.
#define LCD_DATA_PORT getenv("SFR:PORTD")
This defines that the entire 7 bit interface is connected to PORTD of PIC Microcontroller.
PIN Access Method
In this method you can connect those 7 bits to any GPIO pins and it should be defined before including the header file as shown below.
//LCD Module Connections #define LCD_RS_PIN PIN_D1 #define LCD_RW_PIN PIN_D2 #define LCD_ENABLE_PIN PIN_D3 #define LCD_DATA4 PIN_D4 #define LCD_DATA5 PIN_D5 #define LCD_DATA6 PIN_D6 #define LCD_DATA7 PIN_D7 //End LCD Module Connections
This function will display c on the next cursor position of the LCD. You can print strings and characters using this function. You can also use following backslash character constants for sending different commands to LCD.
- \\a – To set cursor to the upper left
- \\f – To clear display and set cursor to upper left
- \\n – To go to start of next line
- \\b – To move back one position
This function can be used to set cursor position of the LCD, upper left position is (1,1).
This function returns the character at the position (x, y) on the LCD.
This function can be used to turn the cursor on or off.
lcd_cursor_on(TRUE); //Turns ON the cursor
lcd_cursor_on(FALSE); //Turns OFF the cursor
Note : For more details you can read the library file “lcd.c” in the location C:/Program Files/PICC/Drivers/.
For more detail: Interfacing LCD with PIC Microcontroller – CCS C
EasyEDA: Ideas for Circuit Design, Innovation for Electronics Access
Free Circuit Design: Schematic – Simulation – PCB Layout – Gerber Viewer
Cheapest PCB Prototype: Only $2 for 10pcs 10×10cm PCBs, 24 hours Quick Turn, DHL Delivery in 3 Days
Current Project / Post can also be found using:
- how to connect port with lcd in pic microcontroller
- how to use multi lcds with 1 pic in ccs c compiler
- interfacing lcd with pic 18 microcontroller
- lcd with pic ccs