drm/tinydrm Tiny DRM drivers¶
tinydrm is a collection of DRM drivers that are so small they can fit in a single source file.
Helpers¶
-
bool
tinydrm_machine_little_endian
(void)¶ Machine is little endian
Parameters
void
- no arguments
Return
true if defined(__LITTLE_ENDIAN), false otherwise
-
void
tinydrm_dbg_spi_message
(struct spi_device * spi, struct spi_message * m)¶ Dump SPI message
Parameters
struct spi_device * spi
- SPI device
struct spi_message * m
- SPI message
Description
Dumps info about the transfers in a SPI message including buffer content.
DEBUG has to be defined for this function to be enabled alongside setting
the DRM_UT_DRIVER bit of drm_debug
.
-
size_t
tinydrm_spi_max_transfer_size
(struct spi_device * spi, size_t max_len)¶ Determine max SPI transfer size
Parameters
struct spi_device * spi
- SPI device
size_t max_len
- Maximum buffer size needed (optional)
Description
This function returns the maximum size to use for SPI transfers. It checks the SPI master, the optional max_len and the module parameter spi_max and returns the smallest.
Return
Maximum size for SPI transfers
-
bool
tinydrm_spi_bpw_supported
(struct spi_device * spi, u8 bpw)¶ Check if bits per word is supported
Parameters
struct spi_device * spi
- SPI device
u8 bpw
- Bits per word
Description
This function checks to see if the SPI master driver supports bpw.
Return
True if bpw is supported, false otherwise.
-
int
tinydrm_spi_transfer
(struct spi_device * spi, u32 speed_hz, struct spi_transfer * header, u8 bpw, const void * buf, size_t len)¶ SPI transfer helper
Parameters
struct spi_device * spi
- SPI device
u32 speed_hz
- Override speed (optional)
struct spi_transfer * header
- Optional header transfer
u8 bpw
- Bits per word
const void * buf
- Buffer to transfer
size_t len
- Buffer length
Description
This SPI transfer helper breaks up the transfer of buf into chunks which the SPI master driver can handle. If the machine is Little Endian and the SPI master driver doesn’t support 16 bits per word, it swaps the bytes and does a 8-bit transfer. If header is set, it is prepended to each SPI message.
Return
Zero on success, negative error code on failure.
-
int
tinydrm_display_pipe_init
(struct drm_device * drm, struct drm_simple_display_pipe * pipe, const struct drm_simple_display_pipe_funcs * funcs, int connector_type, const uint32_t * formats, unsigned int format_count, const struct drm_display_mode * mode, unsigned int rotation)¶ Initialize display pipe
Parameters
struct drm_device * drm
- DRM device
struct drm_simple_display_pipe * pipe
- Display pipe
const struct drm_simple_display_pipe_funcs * funcs
- Display pipe functions
int connector_type
- Connector type
const uint32_t * formats
- Array of supported formats (DRM_FORMAT_*)
unsigned int format_count
- Number of elements in formats
const struct drm_display_mode * mode
- Supported mode
unsigned int rotation
- Initial mode rotation in degrees Counter Clock Wise
Description
This function sets up a drm_simple_display_pipe
with a drm_connector
that
has one fixed drm_display_mode
which is rotated according to rotation.
Return
Zero on success, negative error code on failure.
MIPI DBI Compatible Controllers¶
This library provides helpers for MIPI Display Bus Interface (DBI) compatible display controllers.
Many controllers for tiny lcd displays are MIPI compliant and can use this library. If a controller uses registers 0x2A and 0x2B to set the area to update and uses register 0x2C to write to frame memory, it is most likely MIPI compliant.
Only MIPI Type 1 displays are supported since a full frame memory is needed.
There are 3 MIPI DBI implementation types:
- Motorola 6800 type parallel bus
- Intel 8080 type parallel bus
- SPI type with 3 options:
- 9-bit with the Data/Command signal as the ninth bit
- Same as above except it’s sent as 16 bits
- 8-bit with the Data/Command signal as a separate D/CX pin
Currently mipi_dbi only supports Type C options 1 and 3 with
mipi_dbi_spi_init()
.
-
struct
mipi_dbi
¶ MIPI DBI controller
Definition
struct mipi_dbi {
struct drm_device drm;
struct drm_simple_display_pipe pipe;
struct spi_device *spi;
bool enabled;
struct mutex cmdlock;
int (*command)(struct mipi_dbi *mipi, u8 *cmd, u8 *param, size_t num);
const u8 *read_commands;
struct gpio_desc *dc;
u16 *tx_buf;
void *tx_buf9;
size_t tx_buf9_len;
bool swap_bytes;
struct gpio_desc *reset;
unsigned int rotation;
struct backlight_device *backlight;
struct regulator *regulator;
};
Members
drm
- DRM device
pipe
- Display pipe structure
spi
- SPI device
enabled
- Pipeline is enabled
cmdlock
- Command lock
command
- Bus specific callback executing commands.
read_commands
- Array of read commands terminated by a zero entry. Reading is disabled if this is NULL.
dc
- Optional D/C gpio.
tx_buf
- Buffer used for transfer (copy clip rect area)
tx_buf9
- Buffer used for Option 1 9-bit conversion
tx_buf9_len
- Size of tx_buf9.
swap_bytes
- Swap bytes in buffer before transfer
reset
- Optional reset gpio
rotation
- initial rotation in degrees Counter Clock Wise
backlight
- backlight device (optional)
regulator
- power regulator (optional)
-
mipi_dbi_command
(mipi, cmd, seq…)¶ MIPI DCS command with optional parameter(s)
Parameters
mipi
- MIPI structure
cmd
- Command
seq...
- Optional parameter(s)
Description
Send MIPI DCS command to the controller. Use mipi_dbi_command_read()
for
get/read.
Return
Zero on success, negative error code on failure.
Parameters
struct mipi_dbi * mipi
- MIPI structure
u8 cmd
- Command
u8 * val
- Value read
Description
Send MIPI DCS read command to the controller.
Return
Zero on success, negative error code on failure.
-
int
mipi_dbi_command_buf
(struct mipi_dbi * mipi, u8 cmd, u8 * data, size_t len)¶ MIPI DCS command with parameter(s) in an array
Parameters
struct mipi_dbi * mipi
- MIPI structure
u8 cmd
- Command
u8 * data
- Parameter buffer
size_t len
- Buffer length
Return
Zero on success, negative error code on failure.
-
int
mipi_dbi_buf_copy
(void * dst, struct drm_framebuffer * fb, struct drm_rect * clip, bool swap)¶ Copy a framebuffer, transforming it if necessary
Parameters
void * dst
- The destination buffer
struct drm_framebuffer * fb
- The source framebuffer
struct drm_rect * clip
- Clipping rectangle of the area to be copied
bool swap
- When true, swap MSB/LSB of 16-bit values
Return
Zero on success, negative error code on failure.
-
void
mipi_dbi_pipe_update
(struct drm_simple_display_pipe * pipe, struct drm_plane_state * old_state)¶ Display pipe update helper
Parameters
struct drm_simple_display_pipe * pipe
- Simple display pipe
struct drm_plane_state * old_state
- Old plane state
Description
This function handles framebuffer flushing and vblank events. Drivers can use
this as their drm_simple_display_pipe_funcs->update
callback.
-
void
mipi_dbi_enable_flush
(struct mipi_dbi * mipi, struct drm_crtc_state * crtc_state, struct drm_plane_state * plane_state)¶ MIPI DBI enable helper
Parameters
struct mipi_dbi * mipi
- MIPI DBI structure
struct drm_crtc_state * crtc_state
- CRTC state
struct drm_plane_state * plane_state
- Plane state
Description
This function sets mipi_dbi->enabled
, flushes the whole framebuffer and
enables the backlight. Drivers can use this in their
drm_simple_display_pipe_funcs->enable
callback.
Note
Drivers which don’t use mipi_dbi_pipe_update()
because they have custom
framebuffer flushing, can’t use this function since they both use the same
flushing code.
-
void
mipi_dbi_pipe_disable
(struct drm_simple_display_pipe * pipe)¶ MIPI DBI pipe disable helper
Parameters
struct drm_simple_display_pipe * pipe
- Display pipe
Description
This function disables backlight if present, if not the display memory is
blanked. The regulator is disabled if in use. Drivers can use this as their
drm_simple_display_pipe_funcs->disable
callback.
-
int
mipi_dbi_init
(struct mipi_dbi * mipi, const struct drm_simple_display_pipe_funcs * funcs, const struct drm_display_mode * mode, unsigned int rotation)¶ MIPI DBI initialization
Parameters
struct mipi_dbi * mipi
mipi_dbi
structure to initializeconst struct drm_simple_display_pipe_funcs * funcs
- Display pipe functions
const struct drm_display_mode * mode
- Display mode
unsigned int rotation
- Initial rotation in degrees Counter Clock Wise
Description
This function sets up a drm_simple_display_pipe
with a drm_connector
that
has one fixed drm_display_mode
which is rotated according to rotation.
This mode is used to set the mode config min/max width/height properties.
Additionally mipi_dbi.tx_buf
is allocated.
Supported formats: Native RGB565 and emulated XRGB8888.
Return
Zero on success, negative error code on failure.
-
void
mipi_dbi_release
(struct drm_device * drm)¶ DRM driver release helper
Parameters
struct drm_device * drm
- DRM device
Description
This function finalizes and frees mipi_dbi
.
Drivers can use this as their drm_driver->release
callback.
Parameters
struct mipi_dbi * mipi
- MIPI DBI structure
Description
Reset controller if the mipi_dbi->reset
gpio is set.
Parameters
struct mipi_dbi * mipi
- MIPI DBI structure
Description
This function checks the Power Mode register (if readable) to see if display output is turned on. This can be used to see if the bootloader has already turned on the display avoiding flicker when the pipeline is enabled.
Return
true if the display can be verified to be on, false otherwise.
Parameters
struct mipi_dbi * mipi
- MIPI DBI structure
Description
This function enables the regulator if used and does a hardware and software reset.
Return
Zero on success, or a negative error code.
-
int
mipi_dbi_poweron_conditional_reset
(struct mipi_dbi * mipi)¶ MIPI DBI poweron and conditional reset
Parameters
struct mipi_dbi * mipi
- MIPI DBI structure
Description
This function enables the regulator if used and if the display is off, it
does a hardware and software reset. If mipi_dbi_display_is_on()
determines
that the display is on, no reset is performed.
Return
Zero if the controller was reset, 1 if the display was already on, or a negative error code.
-
u32
mipi_dbi_spi_cmd_max_speed
(struct spi_device * spi, size_t len)¶ get the maximum SPI bus speed
Parameters
struct spi_device * spi
- SPI device
size_t len
- The transfer buffer length.
Description
Many controllers have a max speed of 10MHz, but can be pushed way beyond that. Increase reliability by running pixel data at max speed and the rest at 10MHz, preventing transfer glitches from messing up the init settings.
-
int
mipi_dbi_spi_init
(struct spi_device * spi, struct mipi_dbi * mipi, struct gpio_desc * dc)¶ Initialize MIPI DBI SPI interfaced controller
Parameters
struct spi_device * spi
- SPI device
struct mipi_dbi * mipi
mipi_dbi
structure to initializestruct gpio_desc * dc
- D/C gpio (optional)
Description
This function sets mipi_dbi->command
, enables mipi->read_commands
for the
usual read commands. It should be followed by a call to mipi_dbi_init()
or
a driver-specific init.
If dc is set, a Type C Option 3 interface is assumed, if not Type C Option 1.
If the SPI master driver doesn’t support the necessary bits per word, the following transformation is used:
- 9-bit: reorder buffer as 9x 8-bit words, padded with no-op command.
- 16-bit: if big endian send as 8-bit, if little endian swap bytes
Return
Zero on success, negative error code on failure.
Parameters
struct drm_minor * minor
- DRM minor
Description
This function creates a ‘command’ debugfs file for sending commands to the
controller or getting the read command values.
Drivers can use this as their drm_driver->debugfs_init
callback.
Return
Zero on success, negative error code on failure.