|  | /* 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 { | 
|  | 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; | 
|  | }; | 
|  |  | 
|  | /** | 
|  | * 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(void); | 
|  | 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 */ |