Zephyr Project API 4.4.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
display.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2017 Jan Van Winkel <jan.van_winkel@dxplore.eu>
3 * SPDX-FileCopyrightText: 2026 Abderrahmane JARMOUNI
4 *
5 * SPDX-License-Identifier: Apache-2.0
6 */
7
13
14#ifndef ZEPHYR_INCLUDE_DRIVERS_DISPLAY_H_
15#define ZEPHYR_INCLUDE_DRIVERS_DISPLAY_H_
16
30
31#include <zephyr/device.h>
32#include <errno.h>
33#include <stddef.h>
34#include <zephyr/types.h>
36
37#ifdef __cplusplus
38extern "C" {
39#endif
40
250
258#define DISPLAY_BITS_PER_PIXEL(fmt) \
259 ((((fmt & PIXEL_FORMAT_RGB_888) >> 0) * 24U) + \
260 (((fmt & PIXEL_FORMAT_MONO01) >> 1) * 1U) + \
261 (((fmt & PIXEL_FORMAT_MONO10) >> 2) * 1U) + \
262 (((fmt & PIXEL_FORMAT_ARGB_8888) >> 3) * 32U) + \
263 (((fmt & PIXEL_FORMAT_RGB_565) >> 4) * 16U) + \
264 (((fmt & PIXEL_FORMAT_RGB_565X) >> 5) * 16U) + \
265 (((fmt & PIXEL_FORMAT_L_8) >> 6) * 8U) + \
266 (((fmt & PIXEL_FORMAT_AL_88) >> 7) * 16U) + \
267 (((fmt & PIXEL_FORMAT_XRGB_8888) >> 8) * 32U) + \
268 (((fmt & PIXEL_FORMAT_BGR_888) >> 9) * 24U) + \
269 (((fmt & PIXEL_FORMAT_ABGR_8888) >> 10) * 32U) + \
270 (((fmt & PIXEL_FORMAT_RGBA_8888) >> 11) * 32U) + \
271 (((fmt & PIXEL_FORMAT_BGRA_8888) >> 12) * 32U) + \
272 (((fmt & PIXEL_FORMAT_I_4) >> 13) * 4U) + \
273 (((fmt & PIXEL_FORMAT_L_4) >> 14) * 4U))
274
302
312
313#if defined(CONFIG_DISPLAY_COLOR_PALETTE) || defined(__DOXYGEN__)
314
326
327#endif /* defined(CONFIG_DISPLAY_COLOR_PALETTE) || defined(__DOXYGEN__) */
328
343#if defined(CONFIG_DISPLAY_COLOR_PALETTE) || defined(__DOXYGEN__)
345 struct display_palette_color color_palette[CONFIG_DISPLAY_COLOR_PALETTE_MAX_SIZE];
346#endif /* defined(CONFIG_DISPLAY_COLOR_PALETTE) || defined(__DOXYGEN__) */
347};
348
362
377
387
397
413typedef enum display_event_result (*display_event_cb_t)(const struct device *dev,
414 uint32_t evt,
415 const struct display_event_data *data,
416 void *user_data);
417
422
427typedef int (*display_blanking_on_api)(const struct device *dev);
428
433typedef int (*display_blanking_off_api)(const struct device *dev);
434
439typedef int (*display_write_api)(const struct device *dev, const uint16_t x,
440 const uint16_t y,
441 const struct display_buffer_descriptor *desc,
442 const void *buf);
443
448typedef int (*display_read_api)(const struct device *dev, const uint16_t x,
449 const uint16_t y,
450 const struct display_buffer_descriptor *desc,
451 void *buf);
452
457typedef int (*display_clear_api)(const struct device *dev);
458
463typedef void *(*display_get_framebuffer_api)(const struct device *dev);
464
469typedef int (*display_set_brightness_api)(const struct device *dev,
470 const uint8_t brightness);
471
476typedef int (*display_set_contrast_api)(const struct device *dev,
477 const uint8_t contrast);
478
483typedef void (*display_get_capabilities_api)(const struct device *dev,
484 struct display_capabilities *
485 capabilities);
486
491typedef int (*display_set_pixel_format_api)(const struct device *dev,
492 const enum display_pixel_format
493 pixel_format);
494
499typedef int (*display_set_orientation_api)(const struct device *dev,
500 const enum display_orientation
501 orientation);
502
507typedef int (*display_register_event_cb_api)(const struct device *dev,
508 display_event_cb_t cb, void *user_data,
509 uint32_t event_mask, bool in_isr,
510 uint32_t *out_reg_handle);
511
516typedef int (*display_unregister_event_cb_api)(const struct device *dev, uint32_t reg_handle);
517
575
578
590static inline int display_write(const struct device *dev, const uint16_t x,
591 const uint16_t y,
592 const struct display_buffer_descriptor *desc,
593 const void *buf)
594{
595 return DEVICE_API_GET(display, dev)->write(dev, x, y, desc, buf);
596}
597
610static inline int display_read(const struct device *dev, const uint16_t x,
611 const uint16_t y,
612 const struct display_buffer_descriptor *desc,
613 void *buf)
614{
615 const struct display_driver_api *api = DEVICE_API_GET(display, dev);
616
617 if (api->read == NULL) {
618 return -ENOSYS;
619 }
620
621 return api->read(dev, x, y, desc, buf);
622}
623
632static inline int display_clear(const struct device *dev)
633{
634 const struct display_driver_api *api = DEVICE_API_GET(display, dev);
635
636 if (api->clear == NULL) {
637 return -ENOSYS;
638 }
639
640 return api->clear(dev);
641}
642
652static inline void *display_get_framebuffer(const struct device *dev)
653{
654 const struct display_driver_api *api = DEVICE_API_GET(display, dev);
655
656 if (api->get_framebuffer == NULL) {
657 return NULL;
658 }
659
660 return api->get_framebuffer(dev);
661}
662
682static inline int display_blanking_on(const struct device *dev)
683{
684 const struct display_driver_api *api = DEVICE_API_GET(display, dev);
685
686 if (api->blanking_on == NULL) {
687 return -ENOSYS;
688 }
689
690 return api->blanking_on(dev);
691}
692
705static inline int display_blanking_off(const struct device *dev)
706{
707 const struct display_driver_api *api = DEVICE_API_GET(display, dev);
708
709 if (api->blanking_off == NULL) {
710 return -ENOSYS;
711 }
712
713 return api->blanking_off(dev);
714}
715
728static inline int display_set_brightness(const struct device *dev,
729 uint8_t brightness)
730{
731 const struct display_driver_api *api = DEVICE_API_GET(display, dev);
732
733 if (api->set_brightness == NULL) {
734 return -ENOSYS;
735 }
736
737 return api->set_brightness(dev, brightness);
738}
739
752static inline int display_set_contrast(const struct device *dev, uint8_t contrast)
753{
754 const struct display_driver_api *api = DEVICE_API_GET(display, dev);
755
756 if (api->set_contrast == NULL) {
757 return -ENOSYS;
758 }
759
760 return api->set_contrast(dev, contrast);
761}
762
769static inline void display_get_capabilities(const struct device *dev,
770 struct display_capabilities *
771 capabilities)
772{
773 DEVICE_API_GET(display, dev)->get_capabilities(dev, capabilities);
774}
775
785static inline int
787 const enum display_pixel_format pixel_format)
788{
789 const struct display_driver_api *api = DEVICE_API_GET(display, dev);
790
791 if (api->set_pixel_format == NULL) {
792 return -ENOSYS;
793 }
794
795 return api->set_pixel_format(dev, pixel_format);
796}
797
807static inline int display_set_orientation(const struct device *dev,
808 const enum display_orientation
809 orientation)
810{
811 const struct display_driver_api *api = DEVICE_API_GET(display, dev);
812
813 if (api->set_orientation == NULL) {
814 return -ENOSYS;
815 }
816
817 return api->set_orientation(dev, orientation);
818}
819
845static inline int display_register_event_cb(const struct device *dev,
846 display_event_cb_t cb, void *user_data,
847 uint32_t event_mask, bool in_isr,
848 uint32_t *out_reg_handle)
849{
850 __ASSERT(cb != NULL, "Registration failed: callback function pointer is NULL");
851
852 const struct display_driver_api *api = DEVICE_API_GET(display, dev);
853
854 if (api->register_event_cb == NULL) {
855 return -ENOSYS;
856 }
857
858 return api->register_event_cb(dev, cb, user_data, event_mask, in_isr, out_reg_handle);
859}
860
872static inline int display_unregister_event_cb(const struct device *dev, uint32_t reg_handle)
873{
874 const struct display_driver_api *api = DEVICE_API_GET(display, dev);
875
876 if (api->unregister_event_cb == NULL || api->register_event_cb == NULL) {
877 return -ENOSYS;
878 }
879
880 return api->unregister_event_cb(dev, reg_handle);
881}
882
883#ifdef __cplusplus
884}
885#endif
886
890
891#endif /* ZEPHYR_INCLUDE_DRIVERS_DISPLAY_H_ */
#define DEVICE_API_GET(_class, _dev)
Expands to the pointer of a device's API for a given class.
Definition device.h:1425
System error numbers.
display_event
Display event types.
Definition display.h:379
display_screen_info
Display screen information.
Definition display.h:278
int(* display_set_pixel_format_api)(const struct device *dev, const enum display_pixel_format pixel_format)
Callback API to set pixel format used by the display.
Definition display.h:491
static int display_write(const struct device *dev, const uint16_t x, const uint16_t y, const struct display_buffer_descriptor *desc, const void *buf)
Write data to display.
Definition display.h:590
static int display_read(const struct device *dev, const uint16_t x, const uint16_t y, const struct display_buffer_descriptor *desc, void *buf)
Read data from display.
Definition display.h:610
void(* display_get_capabilities_api)(const struct device *dev, struct display_capabilities *capabilities)
Callback API to get display capabilities.
Definition display.h:483
static void * display_get_framebuffer(const struct device *dev)
Get pointer to framebuffer for direct access.
Definition display.h:652
static int display_blanking_off(const struct device *dev)
Turn display blanking off.
Definition display.h:705
static int display_set_orientation(const struct device *dev, const enum display_orientation orientation)
Set display orientation.
Definition display.h:807
display_event_result
Display event callback return flags.
Definition display.h:389
int(* display_write_api)(const struct device *dev, const uint16_t x, const uint16_t y, const struct display_buffer_descriptor *desc, const void *buf)
Callback API for writing data to the display.
Definition display.h:439
static int display_clear(const struct device *dev)
Clear the screen of the display device.
Definition display.h:632
static void display_get_capabilities(const struct device *dev, struct display_capabilities *capabilities)
Get display capabilities.
Definition display.h:769
int(* display_set_brightness_api)(const struct device *dev, const uint8_t brightness)
Callback API to set display brightness.
Definition display.h:469
void *(* display_get_framebuffer_api)(const struct device *dev)
Callback API to get framebuffer pointer.
Definition display.h:463
static int display_set_pixel_format(const struct device *dev, const enum display_pixel_format pixel_format)
Set pixel format used by the display.
Definition display.h:786
static int display_set_contrast(const struct device *dev, uint8_t contrast)
Set the contrast of the display.
Definition display.h:752
static int display_register_event_cb(const struct device *dev, display_event_cb_t cb, void *user_data, uint32_t event_mask, bool in_isr, uint32_t *out_reg_handle)
Register event callback for a display device.
Definition display.h:845
int(* display_read_api)(const struct device *dev, const uint16_t x, const uint16_t y, const struct display_buffer_descriptor *desc, void *buf)
Callback API for reading data from the display.
Definition display.h:448
static int display_unregister_event_cb(const struct device *dev, uint32_t reg_handle)
Unregister event callback for a display device.
Definition display.h:872
int(* display_blanking_off_api)(const struct device *dev)
Callback API to turn off display blanking.
Definition display.h:433
int(* display_register_event_cb_api)(const struct device *dev, display_event_cb_t cb, void *user_data, uint32_t event_mask, bool in_isr, uint32_t *out_reg_handle)
Callback API to register display event callback.
Definition display.h:507
display_pixel_format
Display pixel formats.
Definition display.h:49
display_orientation
Enumeration with possible display orientation.
Definition display.h:306
static int display_blanking_on(const struct device *dev)
Turn display blanking on.
Definition display.h:682
int(* display_blanking_on_api)(const struct device *dev)
@def_driverbackendgroup{Display,display_interface}
Definition display.h:427
static int display_set_brightness(const struct device *dev, uint8_t brightness)
Set the brightness of the display.
Definition display.h:728
enum display_event_result(* display_event_cb_t)(const struct device *dev, uint32_t evt, const struct display_event_data *data, void *user_data)
Called either in ISR context (if arg in_isr=true at register time, see display_register_event_cb ) or...
Definition display.h:413
int(* display_unregister_event_cb_api)(const struct device *dev, uint32_t reg_handle)
Callback API to unregister display event callback.
Definition display.h:516
int(* display_set_contrast_api)(const struct device *dev, const uint8_t contrast)
Callback API to set display contrast.
Definition display.h:476
int(* display_clear_api)(const struct device *dev)
Callback API for clearing the screen of the display.
Definition display.h:457
int(* display_set_orientation_api)(const struct device *dev, const enum display_orientation orientation)
Callback API to set orientation used by the display.
Definition display.h:499
@ DISPLAY_EVENT_LINE_INT
Fired when controller reaches a configured scanline.
Definition display.h:381
@ DISPLAY_EVENT_FRAME_DONE
Fired when a frame transfer to the panel or frame buffer update completes.
Definition display.h:385
@ DISPLAY_EVENT_VSYNC
Fired at vertical sync / start of new frame.
Definition display.h:383
@ SCREEN_INFO_X_ALIGNMENT_WIDTH
Screen has x alignment constrained to width.
Definition display.h:300
@ SCREEN_INFO_EPD
Electrophoretic Display.
Definition display.h:292
@ SCREEN_INFO_DOUBLE_BUFFER
Screen has two alternating ram buffers.
Definition display.h:296
@ SCREEN_INFO_MONO_VTILED
If selected, one octet represents 8 pixels ordered vertically, otherwise ordered horizontally.
Definition display.h:283
@ SCREEN_INFO_MONO_MSB_FIRST
If selected, the MSB represents the first pixel, otherwise MSB represents the last pixel.
Definition display.h:288
@ DISPLAY_EVENT_RESULT_CONTINUE
Let the driver execute its default handling.
Definition display.h:391
@ DISPLAY_EVENT_RESULT_HANDLED
The callback handled the event and the driver should skip its default processing for that event.
Definition display.h:395
@ PIXEL_FORMAT_L_4
4-bit greyscale format with 2 pixels packed per byte.
Definition display.h:248
@ PIXEL_FORMAT_ABGR_8888
32-bit BGR format with 8 bits per component and 8 bits for alpha.
Definition display.h:188
@ PIXEL_FORMAT_RGB_565X
16-bit RGB format packed into two bytes.
Definition display.h:119
@ PIXEL_FORMAT_BGRA_8888
32-bit BGR format with 8 bits per component and 8 bits for alpha.
Definition display.h:216
@ PIXEL_FORMAT_L_8
8-bit Greyscale format
Definition display.h:132
@ PIXEL_FORMAT_XRGB_8888
32-bit RGB format with 8 bits per component and 8 bits unused.
Definition display.h:160
@ PIXEL_FORMAT_BGR_888
24-bit BGR format with 8 bits per component.
Definition display.h:174
@ PIXEL_FORMAT_MONO10
Monochrome (1=Black 0=White).
Definition display.h:78
@ PIXEL_FORMAT_ARGB_8888
32-bit RGB format with 8 bits per component and 8 bits for alpha.
Definition display.h:92
@ PIXEL_FORMAT_AL_88
16-bit Greyscale format with 8-bit luminance and 8-bit for alpha
Definition display.h:146
@ PIXEL_FORMAT_RGBA_8888
32-bit RGB format with 8 bits per component and 8 bits for alpha.
Definition display.h:202
@ PIXEL_FORMAT_MONO01
1-bit monochrome format with 1 bit per pixel, thus each byte represent 8 pixels Two variants,...
Definition display.h:77
@ PIXEL_FORMAT_RGB_565
16-bit RGB format packed into two bytes: 5 red bits [15:11], 6 green bits [10:5], 5 blue bits [4:0].
Definition display.h:107
@ PIXEL_FORMAT_RGB_888
24-bit RGB format with 8 bits per component.
Definition display.h:62
@ PIXEL_FORMAT_I_4
4-bit indexed color format with 2 pixels packed per byte.
Definition display.h:232
@ DISPLAY_ORIENTATION_ROTATED_90
Rotated 90 degrees clockwise.
Definition display.h:308
@ DISPLAY_ORIENTATION_ROTATED_180
Rotated 180 degrees clockwise.
Definition display.h:309
@ DISPLAY_ORIENTATION_NORMAL
No rotation.
Definition display.h:307
@ DISPLAY_ORIENTATION_ROTATED_270
Rotated 270 degrees clockwise.
Definition display.h:310
#define BIT(n)
Unsigned integer with bit position n set (signed in assembly language).
Definition util_macro.h:44
#define ENOSYS
Function not implemented.
Definition errno.h:82
#define NULL
Definition iar_missing_defs.h:20
Devicetree pixel format identifiers for display panels.
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT64_TYPE__ uint64_t
Definition stdint.h:91
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
Runtime device structure (in ROM) per driver instance.
Definition device.h:513
Structure to describe display data buffer layout.
Definition display.h:350
uint16_t pitch
Number of pixels between consecutive rows in the data buffer.
Definition display.h:358
bool frame_incomplete
Indicates that this is not the last write buffer of the frame.
Definition display.h:360
uint16_t height
Data buffer column height in pixels.
Definition display.h:356
uint16_t width
Data buffer row width in pixels.
Definition display.h:354
uint32_t buf_size
Data buffer size in bytes.
Definition display.h:352
Structure holding display capabilities.
Definition display.h:330
uint32_t supported_pixel_formats
Bitwise or of pixel formats supported by the display.
Definition display.h:336
uint16_t x_resolution
Display resolution in the X direction.
Definition display.h:332
enum display_orientation current_orientation
Current display orientation.
Definition display.h:342
uint16_t y_resolution
Display resolution in the Y direction.
Definition display.h:334
uint32_t screen_info
Information about display panel.
Definition display.h:338
struct display_palette_color color_palette[CONFIG_DISPLAY_COLOR_PALETTE_MAX_SIZE]
Color palette supported by the display, indexed by pixel value.
Definition display.h:345
enum display_pixel_format current_pixel_format
Currently active pixel format for the display.
Definition display.h:340
@driver_ops{Display}
Definition display.h:521
display_blanking_off_api blanking_off
@driver_ops_optional Turn display blanking off.
Definition display.h:529
display_register_event_cb_api register_event_cb
@driver_ops_optional Register event callback for a display device.
Definition display.h:569
display_set_pixel_format_api set_pixel_format
@driver_ops_optional Set pixel format used by the display.
Definition display.h:561
display_read_api read
@driver_ops_optional Read data from display.
Definition display.h:537
display_set_orientation_api set_orientation
@driver_ops_optional Set display orientation.
Definition display.h:565
display_write_api write
@driver_ops_mandatory Write data to display.
Definition display.h:533
display_unregister_event_cb_api unregister_event_cb
@driver_ops_optional Unregister event callback for a display device.
Definition display.h:573
display_clear_api clear
@driver_ops_optional Clear the screen of the display device.
Definition display.h:541
display_set_brightness_api set_brightness
@driver_ops_optional Set the brightness of the display.
Definition display.h:549
display_get_framebuffer_api get_framebuffer
@driver_ops_optional Get pointer to framebuffer for direct access.
Definition display.h:545
display_blanking_on_api blanking_on
@driver_ops_optional Turn display blanking on.
Definition display.h:525
display_get_capabilities_api get_capabilities
@driver_ops_mandatory Get display capabilities.
Definition display.h:557
display_set_contrast_api set_contrast
@driver_ops_optional Set the contrast of the display.
Definition display.h:553
Display event payload.
Definition display.h:364
uint64_t timestamp
Timestamp to differentiate between events of the same type.
Definition display.h:368
int buffer_id
For DISPLAY_EVENT_FRAME_DONE events, set to -1 if unavailable.
Definition display.h:374
int line
For DISPLAY_EVENT_LINE_INT events, set to -1 if unavailable.
Definition display.h:372
union display_event_data::@100061017135123320367133017032337244011232371151 info
Event info passed by driver to callback.
Structure representing a color palette entry in ARGB8888 format.
Definition display.h:316
uint8_t r
Red component (0-255).
Definition display.h:322
uint8_t b
Blue component (0-255).
Definition display.h:318
uint8_t a
Alpha component (0-255).
Definition display.h:324
uint8_t g
Green component (0-255).
Definition display.h:320