| /* SPDX-License-Identifier: GPL-2.0-or-later */ |
| /* |
| * Character line display core support |
| * |
| * Copyright (C) 2016 Imagination Technologies |
| * Author: Paul Burton <paul.burton@mips.com> |
| * |
| * Copyright (C) 2021 Glider bv |
| */ |
| |
| #ifndef _LINEDISP_H |
| #define _LINEDISP_H |
| |
| #include <linux/device.h> |
| #include <linux/timer_types.h> |
| |
| #include <linux/map_to_7segment.h> |
| #include <linux/map_to_14segment.h> |
| |
| struct linedisp; |
| |
| /** |
| * enum linedisp_map_type - type of the character mapping |
| * @LINEDISP_MAP_SEG7: Map characters to 7 segment display |
| * @LINEDISP_MAP_SEG14: Map characters to 14 segment display |
| */ |
| enum linedisp_map_type { |
| LINEDISP_MAP_SEG7, |
| LINEDISP_MAP_SEG14, |
| }; |
| |
| /** |
| * struct linedisp_map - character mapping |
| * @type: type of the character mapping |
| * @map: conversion character mapping |
| * @size: size of the @map |
| */ |
| struct linedisp_map { |
| enum linedisp_map_type type; |
| union { |
| struct seg7_conversion_map seg7; |
| struct seg14_conversion_map seg14; |
| } map; |
| unsigned int size; |
| }; |
| |
| /** |
| * struct linedisp_ops - character line display operations |
| * @get_map_type: Function called to get the character mapping, if required |
| * @update: Function called to update the display. This must not sleep! |
| */ |
| struct linedisp_ops { |
| int (*get_map_type)(struct linedisp *linedisp); |
| void (*update)(struct linedisp *linedisp); |
| }; |
| |
| /** |
| * struct linedisp - character line display private data structure |
| * @dev: the line display device |
| * @timer: timer used to implement scrolling |
| * @ops: character line display operations |
| * @buf: pointer to the buffer for the string currently displayed |
| * @message: the full message to display or scroll on the display |
| * @num_chars: the number of characters that can be displayed |
| * @message_len: the length of the @message string |
| * @scroll_pos: index of the first character of @message currently displayed |
| * @scroll_rate: scroll interval in jiffies |
| * @id: instance id of this display |
| */ |
| struct linedisp { |
| struct device dev; |
| struct timer_list timer; |
| const struct linedisp_ops *ops; |
| struct linedisp_map *map; |
| char *buf; |
| char *message; |
| unsigned int num_chars; |
| unsigned int message_len; |
| unsigned int scroll_pos; |
| unsigned int scroll_rate; |
| unsigned int id; |
| }; |
| |
| int linedisp_register(struct linedisp *linedisp, struct device *parent, |
| unsigned int num_chars, const struct linedisp_ops *ops); |
| void linedisp_unregister(struct linedisp *linedisp); |
| |
| #endif /* LINEDISP_H */ |