14#ifndef ZEPHYR_INCLUDE_DRIVERS_DISPLAY_H_
15#define ZEPHYR_INCLUDE_DRIVERS_DISPLAY_H_
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))
313#if defined(CONFIG_DISPLAY_COLOR_PALETTE) || defined(__DOXYGEN__)
343#if defined(CONFIG_DISPLAY_COLOR_PALETTE) || defined(__DOXYGEN__)
463typedef void *(*display_get_framebuffer_api)(
const struct device *dev);
621 return api->
read(dev, x, y, desc, buf);
640 return api->
clear(dev);
773 DEVICE_API_GET(display, dev)->get_capabilities(dev, capabilities);
850 __ASSERT(cb !=
NULL,
"Registration failed: callback function pointer is NULL");
858 return api->
register_event_cb(dev, cb, user_data, event_mask, in_isr, out_reg_handle);
#define DEVICE_API_GET(_class, _dev)
Expands to the pointer of a device's API for a given class.
Definition device.h:1425
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