On Wed, Jul 23, 2025 at 11:29:27AM +0200, Fabian Pfitzner wrote:I do not want to do both. Only one of them.
On 7/23/25 11:17, Jacopo Mondi wrote:180 degress rotation = HFLIP + VFLIP
Hi FabianIf you simply want to flip the output (e. g. horizontally), you cannot do
On Wed, Jul 23, 2025 at 10:58:28AM +0200, Fabian Pfitzner wrote:
There are cameras containing a mirror on their optical path e. g. whenHow is this different from 'rotation = 180' ?
mounted upside down.
this with a rotation.
The camera I'm referring to is not only upside down, but also flipped
horizontally.
I have a camera that does a horizontal flip in its hardware, so the output is not what I want. My example above was misleading. The rotation fixes the "upside down" problem, but does not fix the flip.
Yes, you can't express 'mirror' in DTS, because DTS are about the
physical mounting rotation of the camera. Sensor drivers shall not
apply any flip control automatically, it's userspace that by parsing
the rotation property through the associated v4l2 controls should decide
if it has to apply flips or not to correct the images.
What is the use case you had in mind ? Tell the driver through a DTS
property it has to apply flips to auto-compensate ? Because I think we
shouldn't and if I'm not mistaken we also document it:
https://www.kernel.org/doc/html/latest/userspace-api/media/drivers/camera-sensor.html#rotation-orientation-and-flipping
--
TL;DR drivers shall not flip, userspace should. Mirroring is an effect
of drivers applying an HFLIP, because unless I'm missing something
obvious, 'mirror' is not a physical mounting configuration of the camera
sensor.
FIY we're talking about something similar in libcamera
https://lists.libcamera.org/pipermail/libcamera-devel/2025-July/051533.html
--Introduce two options to change the device's flip property via device tree.
As there is already support for the panel-common driver [1], add it for cameras in the same way.
[1] commit 3c0ecd83eee9 ("dt-bindings: display: panel: Move flip properties to panel-common")
Signed-off-by: Fabian Pfitzner <f.pfitzner@xxxxxxxxxxxxxx>
---
Fabian Pfitzner (2):
media: dt-bindings: add flip properties
media: v4l: fwnode: parse horizontal/vertical flip properties
.../devicetree/bindings/media/video-interface-devices.yaml | 8 ++++++++
drivers/media/v4l2-core/v4l2-fwnode.c | 3 +++
include/media/v4l2-fwnode.h | 4 ++++
3 files changed, 15 insertions(+)
---
base-commit: 6832a9317eee280117cd695fa885b2b7a7a38daf
change-id: 20250718-fpf-media-dt-flip-7fcad30bcfb7
Best regards,
--
Fabian Pfitzner <f.pfitzner@xxxxxxxxxxxxxx>
Pengutronix e.K. | Fabian Pfitzner |
Steuerwalder Str. 21 | https://www.pengutronix.de/ |
31137 Hildesheim, Germany | Phone: +49-5121-206917-0 |
Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-9 |