Zephyr API Documentation 4.4.0-rc2
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
mipi_dbi.h
Go to the documentation of this file.
1/*
2 * Copyright 2023 NXP
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
21
22#ifndef ZEPHYR_INCLUDE_DRIVERS_MIPI_DBI_H_
23#define ZEPHYR_INCLUDE_DRIVERS_MIPI_DBI_H_
24
33
34#include <zephyr/device.h>
37#include <zephyr/drivers/spi.h>
39
40#ifdef __cplusplus
41extern "C" {
42#endif
43
45#define MIPI_DBI_DT_SPI_DEV(node_id) \
46 DT_PHANDLE(DT_PARENT(node_id), spi_dev)
47
48#define MIPI_DBI_SPI_CS_GPIOS_DT_SPEC_GET(node_id) \
49 GPIO_DT_SPEC_GET_BY_IDX_OR(MIPI_DBI_DT_SPI_DEV(node_id), \
50 cs_gpios, DT_REG_ADDR_RAW(node_id), {})
51
52#define MIPI_DBI_SPI_CS_CONTROL_INIT_GPIO(node_id, delay_) \
53 .gpio = MIPI_DBI_SPI_CS_GPIOS_DT_SPEC_GET(node_id), \
54 .delay = delay_,
56
68#define MIPI_DBI_SPI_CONFIG_DT(node_id, operation_, delay_) \
69 { \
70 .frequency = DT_PROP(node_id, mipi_max_frequency), \
71 .operation = (operation_) | \
72 DT_PROP_OR(node_id, duplex, 0) | \
73 COND_CODE_1(DT_PROP(node_id, mipi_cpol), SPI_MODE_CPOL, (0)) | \
74 COND_CODE_1(DT_PROP(node_id, mipi_cpha), SPI_MODE_CPHA, (0)) | \
75 COND_CODE_1(DT_PROP(node_id, mipi_hold_cs), SPI_HOLD_ON_CS, (0)), \
76 .slave = DT_REG_ADDR(node_id), \
77 .cs = { \
78 COND_CODE_1(DT_SPI_HAS_CS_GPIOS(MIPI_DBI_DT_SPI_DEV(node_id)), \
79 (MIPI_DBI_SPI_CS_CONTROL_INIT_GPIO(node_id, delay_)), \
80 (SPI_CS_CONTROL_INIT_NATIVE(node_id))) \
81 .cs_is_gpio = DT_SPI_HAS_CS_GPIOS(MIPI_DBI_DT_SPI_DEV(node_id)),\
82 }, \
83 }
84
95#define MIPI_DBI_SPI_CONFIG_DT_INST(inst, operation_, delay_) \
96 MIPI_DBI_SPI_CONFIG_DT(DT_DRV_INST(inst), operation_, delay_)
97
110#define MIPI_DBI_CONFIG_DT(node_id, operation_, delay_) \
111 { \
112 .mode = DT_STRING_UPPER_TOKEN(node_id, mipi_mode), \
113 .config = MIPI_DBI_SPI_CONFIG_DT(node_id, operation_, delay_), \
114 }
115
125#define MIPI_DBI_CONFIG_DT_INST(inst, operation_, delay_) \
126 MIPI_DBI_CONFIG_DT(DT_DRV_INST(inst), operation_, delay_)
127
137#define MIPI_DBI_TE_MODE_DT(node_id, edge_prop) \
138 DT_STRING_UPPER_TOKEN(node_id, edge_prop)
139
149#define MIPI_DBI_TE_MODE_DT_INST(inst, edge_prop) \
150 DT_STRING_UPPER_TOKEN(DT_DRV_INST(inst), edge_prop)
151
156
170
175typedef int (*mipi_dbi_command_write_t)(const struct device *dev,
176 const struct mipi_dbi_config *config, uint8_t cmd,
177 const uint8_t *data, size_t len);
178
183typedef int (*mipi_dbi_command_read_t)(const struct device *dev,
184 const struct mipi_dbi_config *config, uint8_t *cmds,
185 size_t num_cmds, uint8_t *response, size_t len);
186
191typedef int (*mipi_dbi_write_display_t)(const struct device *dev,
192 const struct mipi_dbi_config *config,
193 const uint8_t *framebuf,
194 struct display_buffer_descriptor *desc,
195 enum display_pixel_format pixfmt);
196
201typedef int (*mipi_dbi_reset_t)(const struct device *dev, k_timeout_t delay);
202
207typedef int (*mipi_dbi_release_t)(const struct device *dev, const struct mipi_dbi_config *config);
208
213typedef int (*mipi_dbi_configure_te_t)(const struct device *dev, uint8_t edge, k_timeout_t delay);
214
244
247
268static inline int mipi_dbi_command_write(const struct device *dev,
269 const struct mipi_dbi_config *config,
270 uint8_t cmd, const uint8_t *data,
271 size_t len)
272{
273 const struct mipi_dbi_driver_api *api =
274 (const struct mipi_dbi_driver_api *)dev->api;
275
276 if (api->command_write == NULL) {
277 return -ENOSYS;
278 }
279 return api->command_write(dev, config, cmd, data, len);
280}
281
299static inline int mipi_dbi_command_read(const struct device *dev,
300 const struct mipi_dbi_config *config,
301 uint8_t *cmds, size_t num_cmd,
302 uint8_t *response, size_t len)
303{
304 const struct mipi_dbi_driver_api *api =
305 (const struct mipi_dbi_driver_api *)dev->api;
306
307 if (api->command_read == NULL) {
308 return -ENOSYS;
309 }
310 return api->command_read(dev, config, cmds, num_cmd, response, len);
311}
312
332static inline int mipi_dbi_write_display(const struct device *dev,
333 const struct mipi_dbi_config *config,
334 const uint8_t *framebuf,
335 struct display_buffer_descriptor *desc,
336 enum display_pixel_format pixfmt)
337{
338 const struct mipi_dbi_driver_api *api =
339 (const struct mipi_dbi_driver_api *)dev->api;
340
341 if (api->write_display == NULL) {
342 return -ENOSYS;
343 }
344 return api->write_display(dev, config, framebuf, desc, pixfmt);
345}
346
358static inline int mipi_dbi_reset(const struct device *dev, uint32_t delay_ms)
359{
360 const struct mipi_dbi_driver_api *api =
361 (const struct mipi_dbi_driver_api *)dev->api;
362
363 if (api->reset == NULL) {
364 return -ENOSYS;
365 }
366 return api->reset(dev, K_MSEC(delay_ms));
367}
368
386static inline int mipi_dbi_release(const struct device *dev,
387 const struct mipi_dbi_config *config)
388{
389 const struct mipi_dbi_driver_api *api =
390 (const struct mipi_dbi_driver_api *)dev->api;
391
392 if (api->release == NULL) {
393 return -ENOSYS;
394 }
395 return api->release(dev, config);
396}
397
424static inline int mipi_dbi_configure_te(const struct device *dev,
425 uint8_t edge,
426 uint32_t delay_us)
427{
428 const struct mipi_dbi_driver_api *api =
429 (const struct mipi_dbi_driver_api *)dev->api;
430
431 if (api->configure_te == NULL) {
432 return -ENOSYS;
433 }
434 return api->configure_te(dev, edge, K_USEC(delay_us));
435}
436
437#ifdef __cplusplus
438}
439#endif
440
444
445#endif /* ZEPHYR_INCLUDE_DRIVERS_MIPI_DBI_H_ */
Main header file for display driver API.
Main header file for SPI (Serial Peripheral Interface) driver API.
#define K_MSEC(ms)
Generate timeout delay from milliseconds.
Definition kernel.h:1618
#define K_USEC(t)
Generate timeout delay from microseconds.
Definition kernel.h:1582
display_pixel_format
Display pixel formats.
Definition display.h:49
static void cmd(uint32_t command)
Execute a display list command by co-processor engine.
Definition ft8xx_reference_api.h:153
int(* mipi_dbi_release_t)(const struct device *dev, const struct mipi_dbi_config *config)
Callback API to release a locked MIPI DBI device.
Definition mipi_dbi.h:207
int(* mipi_dbi_configure_te_t)(const struct device *dev, uint8_t edge, k_timeout_t delay)
Callback API to configure the MIPI DBI tearing effect signal.
Definition mipi_dbi.h:213
int(* mipi_dbi_reset_t)(const struct device *dev, k_timeout_t delay)
Callback API to reset the attached display controller.
Definition mipi_dbi.h:201
int(* mipi_dbi_command_write_t)(const struct device *dev, const struct mipi_dbi_config *config, uint8_t cmd, const uint8_t *data, size_t len)
Callback API to write a command to the display controller.
Definition mipi_dbi.h:175
int(* mipi_dbi_command_read_t)(const struct device *dev, const struct mipi_dbi_config *config, uint8_t *cmds, size_t num_cmds, uint8_t *response, size_t len)
Callback API to read a command response from the display controller.
Definition mipi_dbi.h:183
int(* mipi_dbi_write_display_t)(const struct device *dev, const struct mipi_dbi_config *config, const uint8_t *framebuf, struct display_buffer_descriptor *desc, enum display_pixel_format pixfmt)
Callback API to write a display buffer to the display controller.
Definition mipi_dbi.h:191
static int mipi_dbi_reset(const struct device *dev, uint32_t delay_ms)
Resets attached display controller.
Definition mipi_dbi.h:358
static int mipi_dbi_write_display(const struct device *dev, const struct mipi_dbi_config *config, const uint8_t *framebuf, struct display_buffer_descriptor *desc, enum display_pixel_format pixfmt)
Write a display buffer to the display controller.
Definition mipi_dbi.h:332
static int mipi_dbi_configure_te(const struct device *dev, uint8_t edge, uint32_t delay_us)
Configures MIPI DBI tearing effect signal.
Definition mipi_dbi.h:424
static int mipi_dbi_command_write(const struct device *dev, const struct mipi_dbi_config *config, uint8_t cmd, const uint8_t *data, size_t len)
Write a command to the display controller.
Definition mipi_dbi.h:268
static int mipi_dbi_release(const struct device *dev, const struct mipi_dbi_config *config)
Releases a locked MIPI DBI device.
Definition mipi_dbi.h:386
static int mipi_dbi_command_read(const struct device *dev, const struct mipi_dbi_config *config, uint8_t *cmds, size_t num_cmd, uint8_t *response, size_t len)
Read a command response from the display controller.
Definition mipi_dbi.h:299
#define ENOSYS
Function not implemented.
Definition errno.h:82
#define NULL
Definition iar_missing_defs.h:20
Display definitions for MIPI devices.
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
Runtime device structure (in ROM) per driver instance.
Definition device.h:513
const void * api
Address of the API structure exposed by the device instance.
Definition device.h:519
Structure to describe display data buffer layout.
Definition display.h:302
Kernel timeout type.
Definition clock.h:65
MIPI DBI controller configuration.
Definition mipi_dbi.h:162
uint8_t mode
MIPI DBI mode.
Definition mipi_dbi.h:164
struct spi_config config
SPI configuration.
Definition mipi_dbi.h:168
uint8_t color_coding
MIPI DBI color coding for Type A or Type B(6800/8080) interface.
Definition mipi_dbi.h:166
<span class="mlabel">Driver Operations</span> MIPI-DBI driver operations
Definition mipi_dbi.h:218
mipi_dbi_write_display_t write_display
<span class="op-badge op-opt" title="This operation MAY optionally be implemented by the driver....
Definition mipi_dbi.h:230
mipi_dbi_command_write_t command_write
<span class="op-badge op-opt" title="This operation MAY optionally be implemented by the driver....
Definition mipi_dbi.h:222
mipi_dbi_reset_t reset
<span class="op-badge op-opt" title="This operation MAY optionally be implemented by the driver....
Definition mipi_dbi.h:234
mipi_dbi_command_read_t command_read
<span class="op-badge op-opt" title="This operation MAY optionally be implemented by the driver....
Definition mipi_dbi.h:226
mipi_dbi_configure_te_t configure_te
<span class="op-badge op-opt" title="This operation MAY optionally be implemented by the driver....
Definition mipi_dbi.h:242
mipi_dbi_release_t release
<span class="op-badge op-opt" title="This operation MAY optionally be implemented by the driver....
Definition mipi_dbi.h:238
SPI controller configuration structure.
Definition spi.h:438