OpenCores
URL https://opencores.org/ocsvn/hd44780_driver/hd44780_driver/trunk

Subversion Repositories hd44780_driver

[/] [hd44780_driver/] [trunk/] [example_driver.vhd] - Blame information for rev 6

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 2 jodb
-- Filename:     example_driver.vhd
2
-- Filetype:     VHDL Source Code
3
-- Date:         26 oct 2012
4
-- Update:       -
5
-- Description:  VHDL Description of example driver
6
-- Author:       J. op den Brouw
7
-- State:        Demo
8
-- Error:        -
9
-- Version:      1.1alpha
10
-- Copyright:    (c)2012, De Haagse Hogeschool
11
 
12
-- This VHDL code is a example description on how to use the
13
-- HD44780 LCD display driver module. It writes 4x16 characters
14
-- to the display, presuming that the display has four lines.
15
--
16
-- This code is tested on a Terasic DE0-board with an optional
17
-- LCD display. See the weblinks
18
-- http://www.terasic.com.tw/cgi-bin/page/archive.pl?Language=English&CategoryNo=56&No=364
19
-- http://www.terasic.com.tw/cgi-bin/page/archive.pl?Language=English&CategoryNo=78&No=396
20
-- for more info. The display used has only two lines.
21
 
22
-- After a line has written completely, the cursor is moved to
23
-- the beginning of the next line. After the last line is written,
24
-- this code goes into hold mode.
25
--
26
 
27
-- Libraries et al.
28
library ieee;
29
use ieee.std_logic_1164.all;
30
use ieee.numeric_std.all;
31
 
32
-- The entity of a Terasic DE0-board.
33
entity example_driver is
34
        port (CLOCK_50 : in std_logic;
35
                        BUTTON   : in std_logic_vector(2 downto 0);
36
                        SW       : in std_logic_vector(9 downto 0);
37
                        LEDG     : out std_logic_vector(9 downto 0);
38
                        HEX3_D   : out std_logic_vector(6 downto 0);
39
                        HEX2_D   : out std_logic_vector(6 downto 0);
40
                        HEX1_D   : out std_logic_vector(6 downto 0);
41
                        HEX0_D   : out std_logic_vector(6 downto 0);
42
                        HEX0_DP  : out std_logic;
43
                        HEX1_DP  : out std_logic;
44
                        HEX2_DP  : out std_logic;
45
                        HEX3_DP  : out std_logic;
46
                        -- LCD of the DE0 board
47
                        LCD_EN   : out std_logic;
48
                        LCD_RS   : out std_logic;
49
                        LCD_RW   : out std_logic;
50
                        LCD_DATA : inout std_logic_vector(7 downto 0);
51
                        LCD_BLON : out std_logic
52
        );
53
 
54
end entity example_driver;
55
 
56
-- The architecture!
57
architecture hardware of example_driver is
58
-- Component declaration of the LCD module
59
component lcd_driver_hd44780_module is
60
        generic (freq         : integer := 50000000;
61
                                areset_pol   : std_logic := '1';
62
                                time_init1   : time := 40 ms;
63
                                time_init2   : time := 4100 us;
64
                                time_init3   : time := 100 us;
65
                                time_tas     : time := 60 ns;
66
                                time_cycle_e : time := 1000 ns;
67
                                time_pweh    : time := 500 ns;
68
                                time_no_bf   : time := 2 ms;
69
                                cursor_on    : boolean := false;
70
                                blink_on     : boolean := false;
71
                                use_bf       : boolean := true
72
                          );
73
        port      (clk      : in std_logic;
74
                           areset   : in std_logic;
75
                           -- User site
76
                           init     : in std_logic;
77
                           data     : in std_logic_vector(7 downto 0);
78
                           wr       : in std_logic;
79
                           cls      : in std_logic;
80
                           home     : in std_logic;
81
                           goto10   : in std_logic;
82
                           goto20   : in std_logic;
83
                           goto30   : in std_logic;
84
                           busy     : out std_logic;
85
                           -- LCD side
86
                           LCD_E    : out std_logic;
87
                           LCD_RS   : out std_logic;
88
                           LCD_RW   : out std_logic;
89
                           LCD_DB   : inout std_logic_vector(7 downto 0)
90
                          );
91
end component lcd_driver_hd44780_module;
92
 
93
-- The system's frequency
94
constant sys_freq : integer := 50000000;
95
 
96
signal areset   : std_logic;
97
signal clk      : std_logic;
98
signal init     : std_logic;
99
signal data     : std_logic_vector(7 downto 0);
100
signal wr       : std_logic;
101
signal cls      : std_logic;
102
signal home     : std_logic;
103
signal goto10   : std_logic;
104
signal goto20   : std_logic;
105
signal goto30   : std_logic;
106
signal busy              : std_logic;
107
 
108
type state_type is (reset, write_char, write_char_wait, update, update_linecount,
109
                                                  update_linecount_wait, write_char_1, write_char_1_wait,
110 4 jodb
                                                  write_char_2, write_char_2_wait, write_char_3, write_char_4, hold,
111
                                                  hold2);
112 2 jodb
signal state : state_type;
113
 
114
-- A string of 16 characters
115
subtype string16_type is string(1 to 16);
116
-- An array of 4 strings of 16 characters.
117
type message4x16_type is array (1 to 4) of string16_type;
118
 
119
-- The four-line message
120
constant message : message4x16_type :=
121
                                                        ( 1 => "1Elektrotechniek",
122
                                                          2 => "2  LCD HD44780  ",
123
                                                          3 => "3Driver in VHDL!",
124
                                                          4 => "4J. op den Brouw");
125
 
126
-- Counts the characters on a line.
127
signal character_counter : integer range 1 to 16;
128
-- Counts the lines.
129
signal line_counter : integer range 1 to 4;
130
 
131
begin
132
 
133
        -- Push buttons are active low.
134
        areset <= not BUTTON(0);
135
 
136
        -- The clock
137
        clk <= CLOCK_50;
138
 
139
        -- Use LCD module.
140
        lcdm : lcd_driver_hd44780_module
141
        generic map (freq => sys_freq, areset_pol => '1', time_cycle_e => 2000 ns, time_pweh => 500 ns,
142
                                         cursor_on => false, blink_on => false, use_bf => false)
143
        port map (clk => clk, areset => areset, init => init, data => data, wr => wr, cls => cls,
144
                                 home => home, goto10 => goto10, goto20 => goto20, goto30 => goto30, busy => busy,
145
                                 LCD_E => LCD_EN, LCD_RS => LCD_RS, LCD_RW => LCD_RW, LCD_DB => LCD_DATA);
146
 
147
        -- The client side
148
        drive: process (clk, areset) is
149
        variable aline : string16_type;
150
        begin
151
                if areset = '1' then
152
                        wr <= '0';
153
                        init <= '0';
154
                        cls <= '0';
155
                        home <= '0';
156
                        goto10 <= '0';
157
                        goto20 <= '0';
158
                        goto30 <= '0';
159
                        LEDG(0) <= '0';
160
                        data <= "00000000";
161
                        character_counter <= 1;
162
                        state <= reset;
163
                elsif rising_edge(clk) then
164
                        wr <= '0';
165
                        init <= '0';
166
                        cls <= '0';
167
                        home <= '0';
168
                        goto10 <= '0';
169
                        goto20 <= '0';
170
                        goto30 <= '0';
171
                        LEDG(0) <= '0';
172
                        data <= "00000000";
173
                        case state is
174
 
175
                                when reset =>
176
                                        -- Wait for the LCD module ready
177
                                        if busy = '0' then
178
                                                state <= write_char;
179
                                        end if;
180
                                        -- Setup message counter, start at 1.
181
                                        character_counter <= 1;
182
                                        line_counter <= 1;
183
 
184
                                when write_char =>
185
                                        LEDG(0) <= '1';
186
                                        -- Set up WRITE!
187
                                        -- Use the data from the string
188
                                        aline := message(line_counter);
189
                                        data <= std_logic_vector( to_unsigned( character'pos(aline(character_counter)),8));
190
                                        wr <= '1';
191
                                        state <= write_char_wait;
192
 
193
                                when write_char_wait =>
194
                                        -- This state is needed so that the LCD driver
195
                                        -- can process the write command. Note that data
196
                                        -- and wr are registered outputs and get their
197
                                        -- respective values while in *this* state. If you don't
198
                                        -- want this behaviour, please make your outputs
199
                                        -- non-registered.
200
                                        state <= update;
201
 
202
                                when update =>
203
                                        LEDG(0) <= '1';
204
                                        -- Wait for the write complete
205
                                        if busy = '0' then
206
                                                -- If end of string, goto hold mode...
207
                                                if line_counter = 4 and character_counter = 16 then
208
                                                        state <= hold;
209
                                                -- If end of line...    
210
                                                elsif character_counter = 16 then
211
                                                        case line_counter is
212
                                                                when 1 => goto10 <= '1';
213
                                                                when 2 => goto20 <= '1';
214
                                                                when 3 => goto30 <= '1';
215
                                                                -- Never reached, but nice anyway...
216
                                                                when 4 => home <= '1';
217
                                                                when others => null;
218
                                                        end case;
219
                                                        -- Set new values of the counters
220
                                                        line_counter <= line_counter+1;
221
                                                        character_counter <= 1;
222
                                                        -- Goto the update state
223
                                                        state <= update_linecount;
224
                                                else
225
                                                   -- Not the end of a lines, update the character counter.
226
                                                        character_counter <= character_counter+1;
227
                                                        state <= write_char;
228
                                                end if;
229
                                        end if;
230
 
231
                                when update_linecount =>
232
                                        -- This state is needed so that the LCD driver
233
                                        -- can process the gotoXX command. Note that the gotoXX
234
                                        -- signals are registered outputs and get their
235
                                        -- respective values while in *this* state. If you don't
236
                                        -- want this behaviour, please make your outputs
237
                                        -- non-registered.
238
                                        state <= update_linecount_wait;
239
 
240
                                when update_linecount_wait =>
241
                                        -- Wait for the LCD module ready
242
                                        if busy = '0' then
243
                                                state <= write_char;
244
                                        end if;
245
 
246
                                -- The "hohouwer"
247
                                when hold =>
248 4 jodb
                                        --state <= hold;
249
                                        state <= hold2;
250
                                        home <= '1';
251
                                when hold2 =>
252
                                        state <= reset;
253 2 jodb
 
254
                                when others =>
255
                                        null;
256
 
257
                        end case;
258
                end if;
259
        end process;
260
 
261
                -- The unused outputs...
262
        HEX3_D <= (others => '1');
263
        HEX2_D <= (others => '1');
264
        HEX1_D <= (others => '1');
265
        HEX0_D <= (others => '1');
266
 
267
        HEX3_DP <= '1';
268
        HEX2_DP <= '1';
269
        HEX1_DP <= '1';
270
        HEX0_DP <= '1';
271
 
272
        LEDG(9 downto 1) <= (others => '0');
273
 
274
        -- Sadly, the LCD doesn't have a backlight...
275
        LCD_BLON <= '0';
276
 
277
end architecture hardware;

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.