Re: [PATCH v4 1/3] media: ipu-bridge: Add DMI information of Lenovo X9 to the image upside-down list

From: Sakari Ailus

Date: Thu Jun 11 2026 - 08:49:45 EST


Hi Damjan,

On Thu, Jun 11, 2026 at 11:41:19AM +0200, Damjan Georgievski wrote:
> On Thu, 11 Jun 2026 at 10:24, Sakari Ailus <sakari.ailus@xxxxxxxxxxxxxxx> wrote:
> >
> > Hi Kate,
> >
> > On Thu, Jun 11, 2026 at 03:25:46PM +0800, Kate Hsuan wrote:
> > > Hi Sakari and Mark,
> > >
> > > On Thu, Jun 11, 2026 at 5:59 AM Sakari Ailus
> > > <sakari.ailus@xxxxxxxxxxxxxxx> wrote:
> > > >
> > > > Hi Kate,
> > > >
> > > > I know several people have given you different advices but...
> > > >
> > > > On Tue, Jun 09, 2026 at 08:49:24PM +0800, Kate Hsuan wrote:
> > > > > The Lenovo X9 has an upside-down-mounted Sony IMX471 sensor so the image
> > > > > was displayed upside-down. Add the DMI information of Lenovo X9 to
> > > > > resolve the issue.
> > > > >
> > > > > Signed-off-by: Kate Hsuan <hpa@xxxxxxxxxx>
> > > > > ---
> > > > > drivers/media/pci/intel/ipu-bridge.c | 32 ++++++++++++++++++++++++++++
> > > > > 1 file changed, 32 insertions(+)
> > > > >
> > > > > diff --git a/drivers/media/pci/intel/ipu-bridge.c b/drivers/media/pci/intel/ipu-bridge.c
> > > > > index fc6608e33de4..9e24aaceecdf 100644
> > > > > --- a/drivers/media/pci/intel/ipu-bridge.c
> > > > > +++ b/drivers/media/pci/intel/ipu-bridge.c
> > > > > @@ -134,6 +134,38 @@ static const struct dmi_system_id upside_down_sensor_dmi_ids[] = {
> > > > > },
> > > > > .driver_data = "OVTI02C1",
> > > > > },
> > > > > + {
> > > > > + /* Lenovo X9-14 */
> > > > > + .matches = {
> > > > > + DMI_MATCH(DMI_SYS_VENDOR, "LENOVO"),
> > > > > + DMI_MATCH(DMI_BOARD_NAME, "21QA"),
> > > > > + },
> > > > > + .driver_data = "SONY471A",
> > > > > + },
> > > > > + {
> > > > > + /* Lenovo X9-14 */
> > > >
> > > > How are the two X9-14's different? It'd be good to have some comment here
> > > > which model this actually is: the board name is only available (typically
> > > > at least) in DMI.
> > >
> > > According to the datasheet of X9-14 and 15. Lenovo offers 2 screen
> > > sizes (14-inch and 15-inch) and 2 CPU types (Core Ultra 5 and 7).
> >
> > Is the CPU SKU the difference here? If so, can you add that to the comment?
> >
> > > They may ship customised firmware for a specific purpose with a random
> > > DMI_PRODUCT_VERSION.
> > > So, using the DMI_BOARD_NAME prefix to identify the laptop SKU is
> > > safer and easier.
> > >
> > > I think DMI_MATCH(DMI_BOARD_NAME, "21Q") covers all X9 but I don't
> > > know the side effect :(
> > > They may propose a new model with a different MIPI camera or HID.
> >
> > Indeed. Is the BOARD_NAME guaranteed to be unique by Lenovo? I think I'd
> > use DMI_EXACT_MATCH(), too.
>
> The full board_name is 21QA0048RM (on mine), so 21QA is just the prefix.
> The lenovo support site only requires this prefix to get you to the
> support page for the laptops and they refer to it as "Type 21QA".
>
> Is there DMI_MATCH_PREFIX, for these (if not all) Thinkpads it might
> make the most sense ?

DMI_MATCH() only matches for prefix whereas DMI_EXACT_MATCH() requires an
exact match.

--
Sakari Ailus