linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 0/4] media: Fix CSI2 RGB vs BGR pixel order
@ 2025-06-12 12:53 Maxime Ripard
  2025-06-12 12:53 ` [PATCH 1/4] media: uapi: Clarify MBUS color component order for serial buses Maxime Ripard
                   ` (4 more replies)
  0 siblings, 5 replies; 14+ messages in thread
From: Maxime Ripard @ 2025-06-12 12:53 UTC (permalink / raw)
  To: Mauro Carvalho Chehab, Hans Verkuil, Mats Randgaard, Alain Volmat,
	Sakari Ailus
  Cc: linux-media, linux-kernel, Hans Verkuil, Dave Stevenson,
	Maxime Ripard

Hi,

Here's an(other [1]) attempt at fixing the current mess due to the
opposite meaning of what v4l2 and the MIPI-CSI2 spec call "RGB". By v4l2
nomenclature, the format CSI calls RGB is actually BGR.

Unfortunately, a handful of CSI transceivers report through RGB media
bus pixel code, which is then understood as V4L2_PIX_FMT_RGB24 by CSI
receivers.

This is made somewhat worse the fact that media bus codes have been made
mostly with parallel busses in mind, and thus the order of pixels wasn't
clearly defined anywhere.

So the v4l2 vs CSI mismatch was confusing (but there's nothing we can do
about it), but the doc didn't really make an attempt at clearing it up
either.

We did have a convention so far though, that about half the affected
drivers were following. 

This series improves the doc, adds the missing media bus codes, and
converts the transceiver drivers to the rightful media bus format.

We'll also need that series [2] from Laurent to fix all the affected
transceivers. 

Let me know what you think,
Maxime

1: https://lore.kernel.org/r/20250606-rpi-unicam-rgb-bgr-fix-v1-1-9930b963f3eb@kernel.org
2: https://lore.kernel.org/r/20250611181528.19542-1-laurent.pinchart@ideasonboard.com

---
Maxime Ripard (4):
      media: uapi: Clarify MBUS color component order for serial buses
      media: uapi: Introduce MEDIA_BUS_FMT_BGR565_1X16
      media: tc358743: Fix the RGB MBUS format
      media: gc2145: Fix the RGB MBUS format

 .../userspace-api/media/v4l/subdev-formats.rst     | 51 +++++++++++++++++++---
 drivers/media/i2c/gc2145.c                         |  4 +-
 drivers/media/i2c/tc358743.c                       | 10 ++---
 include/uapi/linux/media-bus-format.h              |  3 +-
 4 files changed, 54 insertions(+), 14 deletions(-)
---
base-commit: 6e417fb287553495e43135125d099daf80b63fe1
change-id: 20250612-csi-bgr-rgb-b837980c00b3

Best regards,
-- 
Maxime Ripard <mripard@kernel.org>


^ permalink raw reply	[flat|nested] 14+ messages in thread

end of thread, other threads:[~2025-07-31 13:02 UTC | newest]

Thread overview: 14+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-06-12 12:53 [PATCH 0/4] media: Fix CSI2 RGB vs BGR pixel order Maxime Ripard
2025-06-12 12:53 ` [PATCH 1/4] media: uapi: Clarify MBUS color component order for serial buses Maxime Ripard
2025-06-12 12:53 ` [PATCH 2/4] media: uapi: Introduce MEDIA_BUS_FMT_BGR565_1X16 Maxime Ripard
2025-06-12 12:53 ` [PATCH 3/4] media: tc358743: Fix the RGB MBUS format Maxime Ripard
2025-06-12 17:01   ` Dave Stevenson
2025-06-16  8:02     ` Hans Verkuil
2025-06-18 14:54       ` Maxime Ripard
2025-07-31 10:14         ` Maxime Ripard
2025-07-31 10:38           ` Hans Verkuil
2025-07-31 13:02             ` Maxime Ripard
2025-06-12 12:53 ` [PATCH 4/4] media: gc2145: " Maxime Ripard
2025-06-16  7:42   ` Hans Verkuil
2025-06-16  8:02 ` [PATCH 0/4] media: Fix CSI2 RGB vs BGR pixel order Hans Verkuil
2025-06-18  8:48   ` Maxime Ripard

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).