]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/bridge: it66121: acquire reset GPIO in probe
authorJulien Chauveau <chauveau.julien@gmail.com>
Tue, 24 Mar 2026 19:30:11 +0000 (20:30 +0100)
committerJavier Martinez Canillas <javierm@redhat.com>
Mon, 18 May 2026 09:27:47 +0000 (11:27 +0200)
The it66121_ctx structure has a gpio_reset field, and it66121_hw_reset()
calls gpiod_set_value() on it. However, the GPIO descriptor is never
acquired via devm_gpiod_get(), leaving gpio_reset as NULL throughout
the driver lifetime.

gpiod_set_value() silently returns when passed a NULL descriptor, so
the hardware reset sequence in it66121_hw_reset() is a no-op. This
leaves the chip in an undefined state at probe time, which can prevent
it from responding on the I2C bus.

The DT binding marks reset-gpios as a required property, so all
compliant device trees provide this GPIO. Add the missing
devm_gpiod_get() call after enabling power supplies and before the
hardware reset, so the chip is properly reset with power applied.

Fixes: 988156dc2fc9 ("drm: bridge: add it66121 driver")
Cc: stable@vger.kernel.org
Signed-off-by: Julien Chauveau <chauveau.julien@gmail.com>
Reviewed-by: Javier Martinez Canillas <javierm@redhat.com>
Tested-by: Javier Martinez Canillas <javierm@redhat.com>
Link: https://patch.msgid.link/20260324193011.16583-1-chauveau.julien@gmail.com
Signed-off-by: Javier Martinez Canillas <javierm@redhat.com>
drivers/gpu/drm/bridge/ite-it66121.c

index 9246e9c15a6ef588d18d5a67234e836e50ac96f4..ed21f09cd19a33a75b8db3584041e493cda3a959 100644 (file)
@@ -1559,6 +1559,11 @@ static int it66121_probe(struct i2c_client *client)
                return ret;
        }
 
+       ctx->gpio_reset = devm_gpiod_get(dev, "reset", GPIOD_OUT_LOW);
+       if (IS_ERR(ctx->gpio_reset))
+               return dev_err_probe(dev, PTR_ERR(ctx->gpio_reset),
+                                    "Failed to get reset GPIO\n");
+
        it66121_hw_reset(ctx);
 
        ctx->regmap = devm_regmap_init_i2c(client, &it66121_regmap_config);