13#ifndef ZEPHYR_INCLUDE_DRIVERS_AUXDISPLAY_H_
14#define ZEPHYR_INCLUDE_DRIVERS_AUXDISPLAY_H_
35#define AUXDISPLAY_LIGHT_NOT_SUPPORTED 0
148typedef int (*auxdisplay_display_on_t)(
const struct device *dev);
155typedef int (*auxdisplay_display_off_t)(
const struct device *dev);
162typedef int (*auxdisplay_cursor_set_enabled_t)(
const struct device *dev,
bool enabled);
169typedef int (*auxdisplay_position_blinking_set_enabled_t)(
const struct device *dev,
177typedef int (*auxdisplay_cursor_shift_set_t)(
const struct device *dev,
uint8_t direction,
185typedef int (*auxdisplay_cursor_position_set_t)(
const struct device *dev,
194typedef int (*auxdisplay_cursor_position_get_t)(
const struct device *dev,
int16_t *x,
202typedef int (*auxdisplay_display_position_set_t)(
const struct device *dev,
211typedef int (*auxdisplay_display_position_get_t)(
const struct device *dev,
int16_t *x,
219typedef int (*auxdisplay_capabilities_get_t)(
const struct device *dev,
227typedef int (*auxdisplay_clear_t)(
const struct device *dev);
235typedef int (*auxdisplay_brightness_get_t)(
const struct device *dev,
uint8_t *brightness);
242typedef int (*auxdisplay_brightness_set_t)(
const struct device *dev,
uint8_t brightness);
250typedef int (*auxdisplay_backlight_get_t)(
const struct device *dev,
uint8_t *backlight);
257typedef int (*auxdisplay_backlight_set_t)(
const struct device *dev,
uint8_t backlight);
264typedef int (*auxdisplay_is_busy_t)(
const struct device *dev);
271typedef int (*auxdisplay_custom_character_set_t)(
const struct device *dev,
286typedef int (*auxdisplay_custom_command_t)(
const struct device *dev,
289__subsystem
struct auxdisplay_driver_api {
290 auxdisplay_display_on_t display_on;
291 auxdisplay_display_off_t display_off;
292 auxdisplay_cursor_set_enabled_t cursor_set_enabled;
293 auxdisplay_position_blinking_set_enabled_t position_blinking_set_enabled;
294 auxdisplay_cursor_shift_set_t cursor_shift_set;
295 auxdisplay_cursor_position_set_t cursor_position_set;
296 auxdisplay_cursor_position_get_t cursor_position_get;
297 auxdisplay_display_position_set_t display_position_set;
298 auxdisplay_display_position_get_t display_position_get;
299 auxdisplay_capabilities_get_t capabilities_get;
300 auxdisplay_clear_t clear;
301 auxdisplay_brightness_get_t brightness_get;
302 auxdisplay_brightness_set_t brightness_set;
303 auxdisplay_backlight_get_t backlight_get;
304 auxdisplay_backlight_set_t backlight_set;
305 auxdisplay_is_busy_t is_busy;
306 auxdisplay_custom_character_set_t custom_character_set;
307 auxdisplay_write_t write;
308 auxdisplay_custom_command_t custom_command;
326static inline int z_impl_auxdisplay_display_on(
const struct device *dev)
328 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
330 if (!api->display_on) {
334 return api->display_on(dev);
348static inline int z_impl_auxdisplay_display_off(
const struct device *dev)
350 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
352 if (!api->display_off) {
356 return api->display_off(dev);
372static inline int z_impl_auxdisplay_cursor_set_enabled(
const struct device *dev,
375 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
377 if (!api->cursor_set_enabled) {
381 return api->cursor_set_enabled(dev, enabled);
397static inline int z_impl_auxdisplay_position_blinking_set_enabled(
const struct device *dev,
400 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
402 if (!api->position_blinking_set_enabled) {
406 return api->position_blinking_set_enabled(dev, enabled);
423 uint8_t direction,
bool display_shift);
425static inline int z_impl_auxdisplay_cursor_shift_set(
const struct device *dev,
429 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
431 if (!api->cursor_shift_set) {
439 return api->cursor_shift_set(dev, direction, display_shift);
459static inline int z_impl_auxdisplay_cursor_position_set(
const struct device *dev,
463 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
465 if (!api->cursor_position_set) {
473 return api->cursor_position_set(dev, type, x, y);
491static inline int z_impl_auxdisplay_cursor_position_get(
const struct device *dev,
494 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
496 if (!api->cursor_position_get) {
500 return api->cursor_position_get(dev, x, y);
520static inline int z_impl_auxdisplay_display_position_set(
const struct device *dev,
524 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
526 if (!api->display_position_set) {
534 return api->display_position_set(dev, type, x, y);
552static inline int z_impl_auxdisplay_display_position_get(
const struct device *dev,
555 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
557 if (!api->display_position_get) {
561 return api->display_position_get(dev, x, y);
576static inline int z_impl_auxdisplay_capabilities_get(
const struct device *dev,
579 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
581 return api->capabilities_get(dev, capabilities);
596static inline int z_impl_auxdisplay_clear(
const struct device *dev)
598 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
600 return api->clear(dev);
616static inline int z_impl_auxdisplay_brightness_get(
const struct device *dev,
619 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
621 if (!api->brightness_get) {
625 return api->brightness_get(dev, brightness);
642static inline int z_impl_auxdisplay_brightness_set(
const struct device *dev,
645 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
647 if (!api->brightness_set) {
651 return api->brightness_set(dev, brightness);
667static inline int z_impl_auxdisplay_backlight_get(
const struct device *dev,
670 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
672 if (!api->backlight_get) {
676 return api->backlight_get(dev, backlight);
693static inline int z_impl_auxdisplay_backlight_set(
const struct device *dev,
696 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
698 if (!api->backlight_set) {
702 return api->backlight_set(dev, backlight);
717static inline int z_impl_auxdisplay_is_busy(
const struct device *dev)
719 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
725 return api->is_busy(dev);
751static inline int z_impl_auxdisplay_custom_character_set(
const struct device *dev,
754 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
756 if (!api->custom_character_set) {
760 return api->custom_character_set(dev, character);
777static inline int z_impl_auxdisplay_write(
const struct device *dev,
780 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
782 return api->write(dev, data, len);
799static inline int z_impl_auxdisplay_custom_command(
const struct device *dev,
802 struct auxdisplay_driver_api *api = (
struct auxdisplay_driver_api *)dev->
api;
804 if (!api->custom_command) {
808 return api->custom_command(dev, data);
819#include <zephyr/syscalls/auxdisplay.h>
int auxdisplay_display_position_set(const struct device *dev, enum auxdisplay_position type, int16_t x, int16_t y)
Set display position on an auxiliary display.
int auxdisplay_brightness_get(const struct device *dev, uint8_t *brightness)
Get the current brightness level of an auxiliary display.
int auxdisplay_display_position_get(const struct device *dev, int16_t *x, int16_t *y)
Get current display position on an auxiliary display.
int auxdisplay_write(const struct device *dev, const uint8_t *data, uint16_t len)
Write data to auxiliary display screen at current position.
int auxdisplay_backlight_set(const struct device *dev, uint8_t backlight)
Update the backlight level of an auxiliary display.
int auxdisplay_is_busy(const struct device *dev)
Check if an auxiliary display driver is busy.
int auxdisplay_brightness_set(const struct device *dev, uint8_t brightness)
Update the brightness level of an auxiliary display.
int auxdisplay_cursor_position_get(const struct device *dev, int16_t *x, int16_t *y)
Get current cursor on an auxiliary display.
int auxdisplay_capabilities_get(const struct device *dev, struct auxdisplay_capabilities *capabilities)
Fetch capabilities (and details) of auxiliary display.
auxdisplay_direction
Used for setting character append position.
Definition auxdisplay.h:59
int auxdisplay_display_off(const struct device *dev)
Turn display off.
int auxdisplay_position_blinking_set_enabled(const struct device *dev, bool enabled)
Set cursor blinking status on an auxiliary display.
int auxdisplay_cursor_set_enabled(const struct device *dev, bool enabled)
Set cursor enabled status on an auxiliary display.
uint32_t auxdisplay_mode_t
Used to describe the mode of an auxiliary (text) display.
Definition auxdisplay.h:38
int auxdisplay_custom_command(const struct device *dev, struct auxdisplay_custom_data *data)
Send a custom command to the display (if supported by driver)
auxdisplay_position
Used for moving the cursor or display position.
Definition auxdisplay.h:41
int auxdisplay_cursor_position_set(const struct device *dev, enum auxdisplay_position type, int16_t x, int16_t y)
Set cursor (and write position) on an auxiliary display.
int auxdisplay_clear(const struct device *dev)
Clear display of auxiliary display and return to home position (note that this does not reset the dis...
int auxdisplay_custom_character_set(const struct device *dev, struct auxdisplay_character *character)
Sets a custom character in the display, the custom character struct must contain the pixel data for t...
int auxdisplay_backlight_get(const struct device *dev, uint8_t *backlight)
Get the backlight level details of an auxiliary display.
int auxdisplay_cursor_shift_set(const struct device *dev, uint8_t direction, bool display_shift)
Set cursor shift after character write and display shift.
int auxdisplay_display_on(const struct device *dev)
Turn display on.
@ AUXDISPLAY_DIRECTION_LEFT
Each character will be placed to the left of existing characters.
Definition auxdisplay.h:64
@ AUXDISPLAY_DIRECTION_COUNT
Definition auxdisplay.h:66
@ AUXDISPLAY_DIRECTION_RIGHT
Each character will be placed to the right of existing characters.
Definition auxdisplay.h:61
@ AUXDISPLAY_POSITION_COUNT
Definition auxdisplay.h:55
@ AUXDISPLAY_POSITION_ABSOLUTE
Moves to specified X,Y position.
Definition auxdisplay.h:43
@ AUXDISPLAY_POSITION_RELATIVE
Shifts current position by +/- X,Y position, does not take display direction into consideration.
Definition auxdisplay.h:48
@ AUXDISPLAY_POSITION_RELATIVE_DIRECTION
Shifts current position by +/- X,Y position, takes display direction into consideration.
Definition auxdisplay.h:53
#define EINVAL
Invalid argument.
Definition errno.h:60
#define ENOSYS
Function not implemented.
Definition errno.h:82
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
__INT16_TYPE__ int16_t
Definition stdint.h:73
Structure holding display capabilities.
Definition auxdisplay.h:81
struct auxdisplay_light brightness
Brightness details for display (if supported)
Definition auxdisplay.h:92
uint8_t custom_characters
Number of custom characters supported by display (0 if unsupported)
Definition auxdisplay.h:98
auxdisplay_mode_t mode
Display-specific data (e.g.
Definition auxdisplay.h:89
uint16_t columns
Number of character columns.
Definition auxdisplay.h:83
struct auxdisplay_light backlight
Backlight details for display (if supported)
Definition auxdisplay.h:95
uint8_t custom_character_width
Width (in pixels) of a custom character, supplied custom characters should match.
Definition auxdisplay.h:101
uint8_t custom_character_height
Height (in pixels) of a custom character, supplied custom characters should match.
Definition auxdisplay.h:104
uint16_t rows
Number of character rows.
Definition auxdisplay.h:86
Structure for a custom character.
Definition auxdisplay.h:120
uint8_t character_code
Will be updated with custom character index to use in the display write function to disaplay this cus...
Definition auxdisplay.h:134
uint8_t * data
Custom character pixel data, a character must be valid for a display consisting of a uint8 array of s...
Definition auxdisplay.h:129
uint8_t index
Custom character index on the display.
Definition auxdisplay.h:122
Structure for a custom command.
Definition auxdisplay.h:108
uint32_t options
Display-driver specific options for command.
Definition auxdisplay.h:116
uint16_t len
Length of supplied data.
Definition auxdisplay.h:113
uint8_t * data
Raw command data to be sent.
Definition auxdisplay.h:110
Light levels for brightness and/or backlight.
Definition auxdisplay.h:72
uint8_t minimum
Minimum light level supported.
Definition auxdisplay.h:74
uint8_t maximum
Maximum light level supported.
Definition auxdisplay.h:77
Runtime device structure (in ROM) per driver instance.
Definition device.h:510
void * data
Address of the device instance private data.
Definition device.h:520
const void * api
Address of the API structure exposed by the device instance.
Definition device.h:516