1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/drivers/include/hd44780.h

214 lines
5.4 KiB
C
Raw Normal View History

2017-03-25 11:00:58 +01:00
/*
* Copyright (C) 2017 HAW Hamburg
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
2017-04-21 11:30:15 +02:00
* @defgroup drivers_hd44780 HD44780 LCD driver
* @ingroup drivers_display
* @brief Driver for the Hitachi HD44780 LCD driver
*
* @note The driver currently supports direct addressing, no I2C
*
* @{
*
* @file
* @brief Interface definition for the HD44780 LCD driver
*
* @author Sebastian Meiling <s@mlng.net>
*/
2017-03-25 11:00:58 +01:00
#ifndef HD44780_H
#define HD44780_H
#include <stdint.h>
#include "periph/gpio.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
2017-08-29 18:00:46 +02:00
* @brief Maximal number of columns supported by the driver
2017-03-25 11:00:58 +01:00
*/
#define HD44780_MAX_COLS (40U)
/**
2017-08-29 18:00:46 +02:00
* @brief Maximal number of rows supported by the driver
2017-03-25 11:00:58 +01:00
*/
#define HD44780_MAX_ROWS (4U)
/**
2017-08-29 18:00:46 +02:00
* @brief Number of data pins for communication 4 or 8.
2017-03-25 11:00:58 +01:00
*/
#define HD44780_MAX_PINS (8U)
/**
2017-08-29 18:00:46 +02:00
* @brief Size of RAM for custom chars
2017-03-25 11:00:58 +01:00
*
* Generally the driver could support 8 chars of size 5x8 or 4 of size 5x10.
* However, most displays only use the former, which is (hard wired) default.
*/
#define HD44780_CGRAM_SIZE (8U)
/**
* @brief Parameters needed for device initialization
*/
typedef struct {
uint8_t cols; /**< number of LCD cols */
uint8_t rows; /**< number of LCD rows */
gpio_t rs; /**< rs gpio pin */
gpio_t rw; /**< rw gpio pin */
gpio_t enable; /**< enable gpio pin */
gpio_t data[HD44780_MAX_PINS]; /**< data gpio pins */
2017-03-25 11:00:58 +01:00
} hd44780_params_t;
/**
* @brief Device descriptor for HD44780 LCD
*/
typedef struct {
hd44780_params_t p; /**< LCD config parameters */
uint8_t flag; /**< LCD functional flags */
uint8_t ctrl; /**< LCD control flags */
uint8_t mode; /**< LCD mode flags */
uint8_t roff[HD44780_MAX_ROWS]; /**< offsets for LCD rows */
} hd44780_t;
/**
2017-08-29 18:00:46 +02:00
* @brief Simple state values
2017-03-25 11:00:58 +01:00
*/
typedef enum {
HD44780_OFF, /**< disable feature */
HD44780_ON /**< enable feature */
} hd44780_state_t;
/**
2017-08-29 18:00:46 +02:00
* @brief Initialize the given driver
2017-03-25 11:00:58 +01:00
*
* @param[out] dev device descriptor of display to initialize
* @param[in] params configuration parameters
*
* @return 0 on success, otherwise error
*/
int hd44780_init(hd44780_t *dev, const hd44780_params_t *params);
/**
2017-08-29 18:00:46 +02:00
* @brief Clear display, delete all chars
2017-03-25 11:00:58 +01:00
*
* @param[in] dev device descriptor of LCD
*/
2017-06-20 17:32:45 +02:00
void hd44780_clear(const hd44780_t *dev);
2017-03-25 11:00:58 +01:00
/**
2017-08-29 18:00:46 +02:00
* @brief Reset cursor to row 0 and column 0
2017-03-25 11:00:58 +01:00
*
* @param[in] dev device descriptor of LCD
*/
2017-06-20 17:32:45 +02:00
void hd44780_home(const hd44780_t *dev);
2017-03-25 11:00:58 +01:00
/**
2017-08-29 18:00:46 +02:00
* @brief Set cursor to specific position in column and row
2017-03-25 11:00:58 +01:00
*
* @param[in] dev device descriptor of LCD
* @param[in] col column position
* @param[in] row row position
*/
2017-06-20 17:32:45 +02:00
void hd44780_set_cursor(const hd44780_t *dev, uint8_t col, uint8_t row);
2017-03-25 11:00:58 +01:00
/**
2017-08-29 18:00:46 +02:00
* @brief Turn display on or off
2017-03-25 11:00:58 +01:00
*
* @param[in] dev device descriptor of LCD
* @param[in] state display on or off
*/
void hd44780_display(hd44780_t *dev, hd44780_state_t state);
/**
2017-08-29 18:00:46 +02:00
* @brief Show cursor, on or off
2017-03-25 11:00:58 +01:00
*
* @param[in] dev device descriptor of LCD
* @param[in] state cursor on or off
*/
void hd44780_cursor(hd44780_t *dev, hd44780_state_t state);
/**
2017-08-29 18:00:46 +02:00
* @brief Blink cursor, on or off
2017-03-25 11:00:58 +01:00
*
* @param[in] dev device descriptor of LCD
* @param[in] state blink on or off
*/
void hd44780_blink(hd44780_t *dev, hd44780_state_t state);
/**
2017-08-29 18:00:46 +02:00
* @brief Enable left scrolling
2017-03-25 11:00:58 +01:00
*
* @param[in] dev device descriptor of LCD
*/
2017-06-20 17:32:45 +02:00
void hd44780_scroll_left(const hd44780_t *dev);
2017-03-25 11:00:58 +01:00
/**
2017-08-29 18:00:46 +02:00
* @brief Enable right scrolling
2017-03-25 11:00:58 +01:00
*
* @param[in] dev device descriptor of LCD
*/
2017-06-20 17:32:45 +02:00
void hd44780_scroll_right(const hd44780_t *dev);
2017-03-25 11:00:58 +01:00
/**
2017-08-29 18:00:46 +02:00
* @brief Set display direction left to right
2017-03-25 11:00:58 +01:00
*
* @param[in] dev device descriptor of LCD
*/
void hd44780_left2right(hd44780_t *dev);
/**
2017-08-29 18:00:46 +02:00
* @brief Set display direction right to left
2017-03-25 11:00:58 +01:00
*
* @param[in] dev device descriptor of LCD
*/
void hd44780_right2left(hd44780_t *dev);
/**
2017-08-29 18:00:46 +02:00
* @brief Display autoscroll on or off
2017-03-25 11:00:58 +01:00
*
* @param[in] dev device descriptor of LCD
* @param[in] state scroll on or off
*/
void hd44780_autoscroll(hd44780_t *dev, hd44780_state_t state);
/**
2017-08-29 18:00:46 +02:00
* @brief Create and store a custom character on display memory
2017-03-25 11:00:58 +01:00
*
* @param[in] dev device descriptor of LCD
* @param[in] location memory location
* @param[in] charmap character bitmap
*
* @pre charmap has to be of size HD44780_CGRAM_SIZE, which is 8 by default
*/
2017-06-20 17:32:45 +02:00
void hd44780_create_char(const hd44780_t *dev, uint8_t location, uint8_t charmap[]);
2017-03-25 11:00:58 +01:00
/**
2017-08-29 18:00:46 +02:00
* @brief Write a single character on the LCD
2017-03-25 11:00:58 +01:00
*
* @param[in] dev device descriptor of LCD
* @param[in] value the character to print, i.e., memory location
*/
2017-06-20 17:32:45 +02:00
void hd44780_write(const hd44780_t *dev, uint8_t value);
2017-03-25 11:00:58 +01:00
/**
2017-08-29 18:00:46 +02:00
* @brief Write a string on the LCD
2017-03-25 11:00:58 +01:00
*
* @param[in] dev device descriptor of LCD
* @param[in] data the string to print
*/
2017-06-20 17:32:45 +02:00
void hd44780_print(const hd44780_t *dev, const char *data);
2017-03-25 11:00:58 +01:00
#ifdef __cplusplus
}
#endif
#endif /* HD44780_H */
/** @} */