Noralf Trønnes wrote: > > I forgot, but I have a two-tone (black/red) e-ink display here, and I > > also have a 3-bpp RGB TFT display. > > I've been anticipating the need for more formats, but I didn't want to > add them without having a user. Otherwise I could end up adding stuff > that would never be used. If you can test, there's no problem adding > support for more formats now. That's great! I can't promise to to test the three-color (b/w/r) e-ink but I'll prepare a test setup for the RGB-TFT on the weekend. > Building on that I would define a 2 bpp RG format like this in the driver: > > static const struct drm_format_info gud_drm_format_rg11 = { > .format = GUD_DRM_FORMAT_RG11, > .num_planes = 1, > .char_per_block = { 1, 0, 0 }, > .block_w = { 4, 0, 0 }, /* 4 pixels per block/byte */ > .block_h = { 1, 0, 0 }, > .hsub = 1, > .vsub = 1, > }; > > And a 3 bpp RGB format like this: > > static const struct drm_format_info gud_drm_format_rgb111 = { > .format = GUD_DRM_FORMAT_RGB111, > .num_planes = 1, > .char_per_block = { 1, 0, 0 }, > .block_w = { 2, 0, 0 }, /* 2 pixels per block/byte */ > .block_h = { 1, 0, 0 }, > .hsub = 1, > .vsub = 1, > }; I can't really comment; I know next to nothing about the drm subsystem. :) > The MIPI DBI standard defines 2 ways to transmit 2x 3-bpp pixels in one > byte (X=pad bit): > - Option 1: X X R1 G1 B1 R2 G2 B2 > - Option 2: X R1 G1 B1 X R2 G2 B2 > > So maybe we should have GUD_DRM_FORMAT_RGB111_OPTION1 and > GUD_DRM_FORMAT_RGB111_OPTION2? > Or just use option 2 and let the display fix it up if needed? It would of course be lovely to be able to set up an automated DMA from a USB endpoint to the panel in the device and not have to touch the data, but that would require the DRM driver to support all the combinations, which quickly becomes complicated. > What format does your 3 bpp display use? It supports three formats: - R1 G1 B1 R2 G2 B2 - R1 G1 B1 X R2 G2 B2 X (your option 2) - R1 R2 R3 (simulated monochrome, same data bit to all three subpixels) > And then something like this for the conversion function: > > static size_t gud_xrgb8888_to_color(u8 *dst, const struct All right! //Peter