![]() |
![]() |
|
|
|
|
|
|
||||||||||||||||||||
|
|
|
||||||||||||||||||||||||||
|
|
|
|
|||||||||||||||||||||||||
|
|
|
|
|
|
|||||||||||||||||||||||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|||||||||||||||
|
|
|||||||||||||||||||||||||||
|
Home
|
|||||||||||||||||||||||||||
![]() |
![]() |
3-Wire Serial LCD using a Shift Register ![]()
HD44780 based character LCDs require at least 6 I/O lines from microcontroller to display data. Therefore, they are not suitable for low-pin microcontrollers like PIC12F series microchips. In this project, I am going to show how to drive an HD44780 based LCD display with only 3 pins of a microcontroller. I am going to demonstrate it with PIC12F683 microchip. The character data and command from the microcontroller is transferred serially to a shift register (74HC595), and the parallel output from the shift register is fed to LCD pins.
74HC595 is a high-speed 8-bit serial in, serial or parallel-out shift register with a storage register and 3-state outputs.
The shift register and storage
registers have separate clocks, SH_CP and ST_CP respectively. Data in
the shift register is shifted on the positive-going transitions of
SH_CP, and the content of shift register will be transferred to the
storage register on a positive-going transition of the ST_CP. If we tie
both the clocks together, the shift register will always be one clock
ahead of the storage register. The 8-bit data of the storage register
will appear at the parallel output (Q0-Q7) when the output enable (OE)
is low. In this project, SH_CP and ST_CP are tied together. So, if we want to receive a serially transferred 8-bit into parallel form at Q0-Q7, an extra clock pulse is required after transmitting the 8-th bit of serial data because the clocks are tied and the storage register is 1-clock behind the shift register.
All HD44780
based character LCD displays are connected using 14 wires: 8 data lines
(D0-D7), 3 control lines (RS, E, R/W), and three power lines (Vdd, Vss,
Vee). Some LCDs may have LED backlight and so they may have additional
connections (usually two: LED+ and LED-).
Providing
detail explanation of individual LCD pin doesn't fall within the scope
of this project. If you are a beginner with LCD, I recommend to read
these two articles first from Everyday Practical Electronics magazine :
How to use intelligent LCDs Part 1: http://lcd-linux.sourceforge.net/pdfdocs/lcd1.pdf Part 2.
http://lcd-linux.sourceforge.net/pdfdocs/lcd2.pdf
The SH_CP
(11) and ST_CP (12) clock inputs of 75HC595 are tied together, and will
be driven by one microcontroller pin. Serial data from microcontroller
is fed to the shift register through DS (14) pin. OE (13) pin is
grounded and reset pin MR (10) is pulled high. Parallel outputs Q0-Q3
from 74HC595 are connected to D4-D7 pins of the LCD module. Similarly,
Q4 output serves for RS control pin. If the LCD module comes with a
built-in backlight LED, it can simply be turned ON or OFF through LED
control pin shown above. Pulling the LED pin to logic high will turn the
back light ON. ![]() ![]()
Circuit soldered on a general purpose
prototyping board
A first, a
bit of data fed to DS pin of 74HC595 appears at Q0 output after 2 clocks
(because SH_CP and ST_CP are tied). So, sending 4-bit data (D4-D7) and
an RS signal require 6 clock pulses till they appear at Q0-Q4 outputs
respectively. When the LCD module is turned ON, it is initialized in
8-bit mode. A number of initializing commands should be sent to operate
the LCD module in 4-bit mode. All the driver routines that are discussed
here are written in mikroC compiler. They work only for a 16x2 LCD
module. User can modify the initialization operations inside the
Initialize_LCD() routine to account for other LCD configurations. The
driver routines and their functions are described below. - Initialize_LCD() : It initializes the LCD module to operate into 4-bit mode, 2 lines display, 5x7 size character, display ON, and no cursor. - Write_LCD_Data() : Sends a character byte to display at current cursor position.
- Write_LCD_Cmd() : Write a command
byte to the LCD module. - Write_LCD_Nibble() : Data or command byte is sent to the LCD module as two nibbles. So this function routine takes care for sending the nibble data to the LCD module. - Write_LCD_Text() : This routine is for sending a character string to display at current cursor position. - Position_LCD() : To change the current cursor position
At the beginning of your program, you
need to define Data_Pin, Clk_Pin, and Enable_Pin to the chosen
microcontroller ports. I am going to demonstrate here how to use these
driver routines to display two blinking character strings, Message1 and
Message2, at different locations. I am going to test our serial LCD
module with PIC12F683 microcontroller. The test circuit is shown below.
Note:
My PIC12F683 Settings
Running at 4 MHz internal clock, MCLR
disabled, WDT OFF. Clock, Data, and Enable lines are served through GP1, GP5, and GP2 ports. ![]()
/* 3-wire Serial LCD using 74HC595
![]() ![]() Testing with a different LCD module
| |||||||||||||||||||||||||
![]() |
![]() |
|
|||||||||||||||||||||||||
|
|
|
|
|||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||
|
Elektrotekno.com | Free Schematics Search Engine | Electronic Kits | Electronic Accessories |
|||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||