Skip to content

Commit

Permalink
Merge pull request #38 from niwciu/hot_fix
Browse files Browse the repository at this point in the history
Hot fix:

1) added const correctnes to lcd_str() procedure
2) fix of examples where old name of gpio interface header file was inlcuded. Replaced #include "lcd_hd44780_interface.h" with #include "lcd_hd44780_GPIO_interface.h"
  • Loading branch information
niwciu authored Mar 11, 2024
2 parents 0b96811 + a834940 commit f6b3fdd
Show file tree
Hide file tree
Showing 18 changed files with 9,889 additions and 9,930 deletions.
2 changes: 1 addition & 1 deletion examples/ATMEGA328P_ARDUINO_UNO_R3/src/LCD_IO_driver.c
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
*/


#include "lcd_hd44780_interface.h"
#include "lcd_hd44780_GPIO_interface.h"
#include "lcd_hd44780_config.h"
#include <stdio.h>
#include <avr/io.h>
Expand Down
15 changes: 10 additions & 5 deletions examples/ESP8266_NONOS_SDK/LCD_HD44780_TEST/build.bat
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ if not exist user (
) else (
echo folder "user" exist
)
copy "..\..\..\src\lcd_hd44780.c" "user\"
@REM copy "..\..\..\src\lcd_hd44780.c" "user\"

if not exist include (
call mkdir include
Expand All @@ -20,10 +20,15 @@ if not exist include (
)

echo Copy files to include\lcd_hd44780\
copy "..\..\..\src\lcd_hd44780.h" "include\"
copy "..\..\..\src\lcd_hd44780_interface.h" "include\"
copy "..\..\..\src\lcd_hd44780_def_char.h" "include\"
copy "..\..\..\src\lcd_hd44780_config.h" "include\"
@REM copy "..\..\..\src\lcd_hd44780.h" "include\"
@REM copy "..\..\..\src\lcd_hd44780_GPIO_interface.h" "include\"
@REM copy "..\..\..\src\lcd_hd44780_def_char.h" "include\"
@REM copy "..\..\..\src\lcd_hd44780_config.h" "include\"
@REM copy "..\..\..\src\lcd_hd44780_driver_commands.h" "include\"
echo =======================================================================
echo CLEAN PROJECT
echo =======================================================================
call make clean
echo =======================================================================
echo BUILD PROJECT
echo =======================================================================
Expand Down
70 changes: 58 additions & 12 deletions examples/ESP8266_NONOS_SDK/LCD_HD44780_TEST/include/lcd_hd44780.h
Original file line number Diff line number Diff line change
@@ -1,8 +1,13 @@
/*
* @Author: lukasz.niewelt
* @Date: 2023-12-06 21:40:29
* @Last Modified by: lukasz.niewelt
* @Last Modified time: 2024-01-10 14:00:22
/**
* @file lcd_hd44780.h
* @author niwciu ([email protected])
* @brief
* @version 1.0.2
* @date 2024-02-25
*
* @copyright Copyright (c) 2024
* @defgroup LCD_HD44780_lib_API
* @{
*/

#ifndef _LCD_HD_44780_H_
Expand All @@ -12,15 +17,56 @@
extern "C"
{
#endif /* __cplusplus */
#include <stdbool.h>
#include "lcd_hd44780_config.h"
#include "lcd_hd44780_interface.h"
#include "lcd_hd44780_def_char.h"

#include <stdbool.h>
/**
* @brief Labels for alignment parameter used by lcd_int() and lcd_hex() functions
* @enum LCD_alignment_e
*/
enum LCD_alignment_e
{
left,
right
left, /**< @brief pass as argument when calling lcd_int() or lcd_buf_int() or lcd_hex() or lcd_buf_hex() to set left alighment */
right /**< @brief pass as argument when calling lcd_int() or lcd_buf_int() or lcd_hex() or lcd_buf_hex() to set right alighment */
};
/**
* @brief Line labels used when calling lcd_locate() or lcd_buf_locate() function
* @enum LCD_LINES_e
*/
enum LCD_LINES_e
{
LINE_1, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to first line of LCD */
LINE_2, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to second line of LCD */
LINE_3, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to third line of LCD */
LINE_4, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to fourth line of LCD */
};

/**
* @enum LCD_COLUMNS_e
* @brief Column labels used when calling lcd_locate() or lcd_buf_locate() function
*
*/
enum LCD_COLUMNS_e
{
C1, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 1'st char/collumn of LCD */
C2, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 2'nd char/collumn of LCD */
C3, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 3'th char/collumn of LCD */
C4, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 4'th char/collumn of LCD */
C5, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 5'th char/collumn of LCD */
C6, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 6'th char/collumn of LCD */
C7, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 7'th char/collumn of LCD */
C8, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 8'th char/collumn of LCD */
C9, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 9'th char/collumn of LCD */
C10, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 10'th char/collumn of LCD */
C11, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 11'th char/collumn of LCD */
C12, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 12'th char/collumn of LCD */
C13, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 13'th char/collumn of LCD */
C14, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 14'th char/collumn of LCD */
C15, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 15'th char/collumn of LCD */
C16, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 16'th char/collumn of LCD */
C17, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 17'th char/collumn of LCD */
C18, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 18'th char/collumn of LCD */
C19, /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 19'th char/collumn of LCD */
C20 /**< @brief pass as argument when calling lcd_locate() or lcd_buf_locate() to move curson to 20'th char/collumn of LCD */
};

extern bool LCD_BUFFER_UPDATE_FLAG;
Expand Down Expand Up @@ -55,7 +101,7 @@ extern "C"
void lcd_buf_int(int val, uint8_t width, enum LCD_alignment_e alignment);
void lcd_buf_hex(int val, uint8_t width, enum LCD_alignment_e alignment);
void lcd_buf_bin(int val, uint8_t width);

/**@}*/
#ifdef __cplusplus
}
#endif /* __cplusplus */
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
/**
* @file lcd_hd44780_interface.h
* @author niwciu ([email protected])
* @brief Header file with driver interface declaration that needs to be implemented on the driver layer side.
* This instance eliminates dependencies between the LCD library and the specific microcontroller driver layer.
* @version 1.0.2
* @date 2024-02-25
*
* @copyright Copyright (c) 2024
* @defgroup LCD_HD44780_driver_interface
* @{
*/
#ifndef _LCD_HD44780_INTERFACE_H_
#define _LCD_HD44780_INTERFACE_H_

#ifdef __cplusplus
extern "C"
{
#endif /* __cplusplus */
#include <stdint.h>

typedef uint8_t LCD_data_port_t;

typedef void (*LCD_interface_func_p)(void);
typedef void (*set_LCD_data_port_func_p)(uint8_t data);
typedef LCD_data_port_t (*get_LCD_data_port_func_p)(void);
typedef void (*delay_us_func_p)(uint32_t delay_us);

/**
* @struct LCD_IO_driver_interface_struct
* @brief LCD I/O driver interface definition.
* @attention This interface declaration need to be defined on driver layer side and "full fill the contract" of the defined LCD_IO_driver_interface_struct
*
*/
struct LCD_IO_driver_interface_struct
{
LCD_interface_func_p init_LCD_pins;
LCD_interface_func_p set_data_pins_as_outputs;
LCD_interface_func_p set_data_pins_as_inputs;
set_LCD_data_port_func_p write_data;
get_LCD_data_port_func_p read_data;
delay_us_func_p delay_us;
LCD_interface_func_p set_LCD_E;
LCD_interface_func_p reset_LCD_E;
LCD_interface_func_p set_LCD_RS;
LCD_interface_func_p reset_LCD_RS;
LCD_interface_func_p set_LCD_RW;
LCD_interface_func_p reset_LCD_RW;
LCD_interface_func_p set_LCD_BCKL;
LCD_interface_func_p reset_LCD_BCKL;
};
// clang-format off
/**
* @brief Declaration of the function that return pointer to the interface structure implemented on driver layer side.
* @attention This function need to be defined on driver layer side and must return pointer to LCD_IO_driver_interface_struct defined on dirver layer side
* @return const struct LCD_IO_driver_interface_struct*
*/
const struct LCD_IO_driver_interface_struct* LCD_IO_driver_interface_get(void);
// clang-format on
/**@}*/
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif /* _LCD_HD_44780_H_ */
Original file line number Diff line number Diff line change
@@ -1,8 +1,13 @@
/*
* @Author: lukasz.niewelt
* @Date: 2023-12-06 21:38:27
* @Last Modified by: lukasz.niewelt
* @Last Modified time: 2024-01-09 21:20:52
/**
* @file lcd_hd44780_config.h
* @author niwciu ([email protected])
* @brief
* @version 1.0.2
* @date 2024-02-25
*
* @copyright Copyright (c) 2024
* @addtogroup LCD_HD44780_lib_API
*
*/

#ifndef _LCD_HD44780_CONFIG_H_
Expand All @@ -28,29 +33,12 @@ extern "C"
* ON - when the RW pin is connected
* OFF - when the RW pin is not connected
********************************************************************************************/
#define LCD_TYPE 1602
#define USE_RW_PIN OFF
#define LCD_TYPE 1602
#define USE_RW_PIN OFF

#define LCD_BCKL_PIN_EN_STATE HIGH
#define LCD_BCKL_PIN_EN_STATE HIGH

#define LCD_BUFFERING ON

//definitions of Line and column labels for lcd_locate
enum LCD_LINES_e
{
LINE_1,
LINE_2,
#if ((LCD_TYPE==2004) ||(LCD_TYPE ==1604))
LINE_3,
LINE_4,
#endif
};
enum LCD_COLUMNS_e{
C1,C2,C3,C4,C5,C6,C7,C8,C9,C10,C11,C12,C13,C14,C15,C16,
#if LCD_TYPE==2004
C17,C18,C19,C20
#endif
};
#define LCD_BUFFERING ON

/******************************** LCD LIBRARY COMPILATION SETTINGS ************************
* Setting USE_(procedure name) to:
Expand Down
Original file line number Diff line number Diff line change
@@ -1,8 +1,12 @@
/*
* @Author: lukasz.niewelt
* @Date: 2023-12-08 11:15:52
* @Last Modified by: lukasz.niewelt
* @Last Modified time: 2023-12-13 13:17:53
/**
* @file lcd_hd44780_def_char.h
* @author niwciu ([email protected])
* @brief
* @version 1.0.2
* @date 2024-02-25
* @addtogroup LCD_HD44780_lib_API
* @copyright Copyright (c) 2024
*
*/

#ifndef _LCD_HD44780_DEF_CHAR_H_
Expand All @@ -12,7 +16,14 @@
extern "C"
{
#endif /* __cplusplus */

#include <stdint.h>
#include "lcd_hd44780_config.h"
/**
* @struct char_bank_struct
* @brief Structure that contain pointers to 8 user predefined characters. Structure is used to define user character banks.
* Each bank can contain combinatio of maksimum 8 user special cahracters.
*
*/
struct char_bank_struct
{
const uint8_t *char_0;
Expand All @@ -28,8 +39,10 @@ extern "C"
#if USE_DEF_CHAR_FUNCTION == ON
#define LCD_CGRAM_BYTES_PER_CHAR 8
#define DEF_CHAR_ADR_MASK 7
/**********************USER CHAR DEFINITIONS START*******************************/
/******To sace flash when using defchar comment char definitions that are unused*/
/**********************USER CHAR DECLARATION SECTION*******************************/
/**
* @note To save flash when using defchar comment char definitions that are unused
* */
static const uint8_t Pol_e[8] = {32, 32, 14, 17, 31, 16, 14, 3};
static const uint8_t Pol_o[8] = {2, 4, 14, 17, 17, 17, 14, 0};
static const uint8_t Pol_s[8] = {2, 4, 14, 16, 14, 1, 30, 32};
Expand All @@ -39,9 +52,8 @@ extern "C"
static const uint8_t Pol_n[8] = {2, 4, 22, 25, 17, 17, 17, 0};
static const uint8_t Zn_wody[8] = {0, 0, 0, 6, 9, 2, 4, 15};
// here add "definition" of new chars
/**********************USER CHAR DEFINITIONS END********************************/

/**********************USER CHAR CGRAM BANKS DEFINITIONS START*******************/
/**********************USER CHAR CGRAM BANKS DECALRATION SECTION*******************/
static const struct char_bank_struct lcd_cgram_bank_1 = {
Pol_e,
Pol_o,
Expand All @@ -51,16 +63,23 @@ extern "C"
Pol_a,
Pol_n,
Zn_wody};
enum LCD_CGRAM_BANK_1

/**
* @enum LCD_CGRAM_BANK_1_e
* @brief Labels representing specific user defined chars collected in lcd_cgram_bank_1.
* Labels value are equal to adress in lcd_cgram_bank_1 and addres of LCD_CGRAM where all chars from lcd_cgram_bank_1 will be written when using
* lcd_load_char_bank() or lcd_def_char() when defining single char in LCD_CGRAM
*/
enum LCD_CGRAM_BANK_1_e
{
pol_e,
pol_o,
pol_s,
pol_l,
pol_c,
pol_a,
pol_n,
zn_wody,
pol_e, /**< @brief label with vlaue 0 created for custom Char Piol_e placed under adress 0x00 in lcd_cgram_bank_1 and LCD_CGRAM*/
pol_o, /**< @brief label with vlaue 1 created for custom Char Piol_o placed under adress 0x01 in lcd_cgram_bank_1 and LCD_CGRAM*/
pol_s, /**< @brief label with vlaue 2 created for custom Char Piol_s placed under adress 0x02 in lcd_cgram_bank_1 and LCD_CGRAM*/
pol_l, /**< @brief label with vlaue 3 created for custom Char Piol_l placed under adress 0x03 in lcd_cgram_bank_1 and LCD_CGRAM*/
pol_c, /**< @brief label with vlaue 4 created for custom Char Piol_c placed under adress 0x03 in lcd_cgram_bank_1 and LCD_CGRAM*/
pol_a, /**< @brief label with vlaue 5 created for custom Char Piol_a placed under adress 0x03 in lcd_cgram_bank_1 and LCD_CGRAM*/
pol_n, /**< @brief label with vlaue 6 created for custom Char Piol_n placed under adress 0x03 in lcd_cgram_bank_1 and LCD_CGRAM*/
zn_wody, /**< @brief label with vlaue 7 created for custom Char Zn_wody placed under adress 0x03 in lcd_cgram_bank_1 and LCD_CGRAM*/
};
// //here define new bank with adreses for chars that you want load to this specifci bank
// static const struct char_bank_struct lcd_cgram_bank_x = {
Expand All @@ -73,7 +92,7 @@ extern "C"
// Pol_n,
// Zn_wody};
// // here define labels for lcd_cgram_bank_x
// enum LCD_CGRAM_BANK_x
// enum LCD_CGRAM_BANK_x_e
// {
// pol_e_bank_x,
// pol_o_bank_x,
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
/**
* @file lcd_hd44780_driver_commands.h
* @author niwciu ([email protected])
* @brief
* @version 1.0.2
* @date 2024-02-25
*
* @copyright Copyright (c) 2024
*
*/
// clang-format off

// LCD driver commands
#define LCDC_CLS 0x01
#define LCDC_HOME 0x02
/********************************/
#define LCDC_ENTRY_MODE 0x04
#define LCDC_ENTRYR 0x02
#define LCDC_ENTRYL 0x00
#define LCDC_MOVE 0x01
/********************************/
#define LCDC_ONOFF 0x08
#define LCDC_DISPLAYON 0x04
#define LCDC_CURSORON 0x02
#define LCDC_CURSOROFF 0x00
#define LCDC_BLINKON 0x01
/********************************/
#define LCDC_SHIFT 0x10
#define LCDC_SHIFTDISP 0x08
#define LCDC_SHIFTR 0x04
#define LCDC_SHIFTL 0x00
/********************************/
#define LCDC_FUNC 0x20
#define LCDC_FUNC8B 0x10
#define LCDC_FUNC4B 0x00
#define LCDC_FUNC2L 0x08
#define LCDC_FUNC1L 0x00
#define LCDC_FUNC5x10 0x04
#define LCDC_FUNC5x7 0x00
/********************************/
#define LCDC_SET_CGRAM 0x40
#define LCDC_SET_DDRAM 0x80

// clang-format on
Loading

0 comments on commit f6b3fdd

Please sign in to comment.