| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- /* SPDX-License-Identifier: GPL-2.0-or-later */
- /*
- * Character LCD driver for Linux
- *
- * Copyright (C) 2000-2008, Willy Tarreau <w@1wt.eu>
- * Copyright (C) 2016-2017 Glider bvba
- */
- #ifndef _CHARLCD_H
- #define _CHARLCD_H
- #define LCD_FLAG_B 0x0004 /* Blink on */
- #define LCD_FLAG_C 0x0008 /* Cursor on */
- #define LCD_FLAG_D 0x0010 /* Display on */
- #define LCD_FLAG_F 0x0020 /* Large font mode */
- #define LCD_FLAG_N 0x0040 /* 2-rows mode */
- #define LCD_FLAG_L 0x0080 /* Backlight enabled */
- enum charlcd_onoff {
- CHARLCD_OFF = 0,
- CHARLCD_ON,
- };
- enum charlcd_shift_dir {
- CHARLCD_SHIFT_LEFT,
- CHARLCD_SHIFT_RIGHT,
- };
- enum charlcd_fontsize {
- CHARLCD_FONTSIZE_SMALL,
- CHARLCD_FONTSIZE_LARGE,
- };
- enum charlcd_lines {
- CHARLCD_LINES_1,
- CHARLCD_LINES_2,
- };
- struct charlcd_ops;
- struct charlcd {
- const struct charlcd_ops *ops;
- const unsigned char *char_conv; /* Optional */
- int height;
- int width;
- /* Contains the LCD X and Y offset */
- struct {
- unsigned long x;
- unsigned long y;
- } addr;
- void *drvdata; /* Set by charlcd_alloc() */
- };
- /**
- * struct charlcd_ops - Functions used by charlcd. Drivers have to implement
- * these.
- * @backlight: Turn backlight on or off. Optional.
- * @print: Print one character to the display at current cursor position.
- * The buffered cursor position is advanced by charlcd. The cursor should not
- * wrap to the next line at the end of a line.
- * @gotoxy: Set cursor to x, y. The x and y values to set the cursor to are
- * previously set in addr.x and addr.y by charlcd.
- * @home: Set cursor to 0, 0. The values in addr.x and addr.y are set to 0, 0 by
- * charlcd prior to calling this function.
- * @clear_display: Clear the whole display and set the cursor to 0, 0. The
- * values in addr.x and addr.y are set to 0, 0 by charlcd after to calling this
- * function.
- * @init_display: Initialize the display.
- * @shift_cursor: Shift cursor left or right one position.
- * @shift_display: Shift whole display content left or right.
- * @display: Turn display on or off.
- * @cursor: Turn cursor on or off.
- * @blink: Turn cursor blink on or off.
- * @lines: One or two lines.
- * @redefine_char: Redefine the actual pixel matrix of character.
- */
- struct charlcd_ops {
- void (*backlight)(struct charlcd *lcd, enum charlcd_onoff on);
- int (*print)(struct charlcd *lcd, int c);
- int (*gotoxy)(struct charlcd *lcd, unsigned int x, unsigned int y);
- int (*home)(struct charlcd *lcd);
- int (*clear_display)(struct charlcd *lcd);
- int (*init_display)(struct charlcd *lcd);
- int (*shift_cursor)(struct charlcd *lcd, enum charlcd_shift_dir dir);
- int (*shift_display)(struct charlcd *lcd, enum charlcd_shift_dir dir);
- int (*display)(struct charlcd *lcd, enum charlcd_onoff on);
- int (*cursor)(struct charlcd *lcd, enum charlcd_onoff on);
- int (*blink)(struct charlcd *lcd, enum charlcd_onoff on);
- int (*fontsize)(struct charlcd *lcd, enum charlcd_fontsize size);
- int (*lines)(struct charlcd *lcd, enum charlcd_lines lines);
- int (*redefine_char)(struct charlcd *lcd, char *esc);
- };
- void charlcd_backlight(struct charlcd *lcd, enum charlcd_onoff on);
- struct charlcd *charlcd_alloc(unsigned int drvdata_size);
- void charlcd_free(struct charlcd *lcd);
- int charlcd_register(struct charlcd *lcd);
- int charlcd_unregister(struct charlcd *lcd);
- void charlcd_poke(struct charlcd *lcd);
- #endif /* CHARLCD_H */
|