Hi Dave On Tue, May 30, 2023 at 06:29:54PM +0100, Dave Stevenson wrote: > Whilst not documented, register 0x0103 bit 0 is the soft > reset for the sensor, so send it before trying to configure > the sensor. > > Signed-off-by: Dave Stevenson <dave.stevenson@xxxxxxxxxxxxxxx> > --- > drivers/media/i2c/imx258.c | 10 ++++++++++ > 1 file changed, 10 insertions(+) > > diff --git a/drivers/media/i2c/imx258.c b/drivers/media/i2c/imx258.c > index 1e424058fcb9..7d6528f9ca4d 100644 > --- a/drivers/media/i2c/imx258.c > +++ b/drivers/media/i2c/imx258.c > @@ -20,6 +20,8 @@ > #define IMX258_MODE_STANDBY 0x00 > #define IMX258_MODE_STREAMING 0x01 > > +#define IMX258_REG_RESET 0x0103 > + > /* Chip ID */ > #define IMX258_REG_CHIP_ID 0x0016 > #define IMX258_CHIP_ID 0x0258 > @@ -1084,6 +1086,14 @@ static int imx258_start_streaming(struct imx258 *imx258) > const struct imx258_link_freq_config *link_freq_cfg; > int ret, link_freq_index; > > + ret = imx258_write_reg(imx258, IMX258_REG_RESET, IMX258_REG_VALUE_08BIT, > + 0x01); > + if (ret) { > + dev_err(&client->dev, "%s failed to reset sensor\n", __func__); > + return ret; > + } > + usleep_range(10000, 15000); Is the reset delay documented as well ? up to 15msec seems a long time. Also, you can use fsleep() if you don't have very precise constraints.. > + > /* Setup PLL */ > link_freq_index = imx258->cur_mode->link_freq_index; > link_freq_cfg = &imx258->link_freq_configs[link_freq_index]; > -- > 2.25.1 >