imx296_write(sensor, IMX296_CTRL00, 0, &ret);
usleep_range(2000, 5000);
- if (trigger_mode == 1) {
- imx296_write(sensor, IMX296_CTRL0B, IMX296_CTRL0B_TRIGEN, &ret);
- imx296_write(sensor, IMX296_LOWLAGTRG, IMX296_LOWLAGTRG_FAST, &ret);
- }
+ /* external trigger mode: 0=normal, 1=triggered */
+ imx296_write(sensor, IMX296_CTRL0B,
+ (trigger_mode == 1) ? IMX296_CTRL0B_TRIGEN : 0, &ret);
+ imx296_write(sensor, IMX296_LOWLAGTRG,
+ (trigger_mode == 1) ? IMX296_LOWLAGTRG_FAST : 0, &ret);
imx296_write(sensor, IMX296_CTRL0A, 0, &ret);
imx477_write_reg(imx477, 0x0b05, IMX477_REG_VALUE_08BIT, !!dpc_enable);
imx477_write_reg(imx477, 0x0b06, IMX477_REG_VALUE_08BIT, !!dpc_enable);
- /* Set vsync trigger mode */
- if (trigger_mode != 0) {
- /* trigger_mode == 1 for source, 2 for sink */
- const u32 val = (trigger_mode == 1) ? 1 : 0;
-
- imx477_write_reg(imx477, IMX477_REG_MC_MODE,
- IMX477_REG_VALUE_08BIT, 1);
- imx477_write_reg(imx477, IMX477_REG_MS_SEL,
- IMX477_REG_VALUE_08BIT, val);
- imx477_write_reg(imx477, IMX477_REG_XVS_IO_CTRL,
- IMX477_REG_VALUE_08BIT, val);
- imx477_write_reg(imx477, IMX477_REG_EXTOUT_EN,
- IMX477_REG_VALUE_08BIT, val);
- }
-
/* Apply customized values from user */
ret = __v4l2_ctrl_handler_setup(imx477->sd.ctrl_handler);
if (ret)
return ret;
+ /* Set vsync trigger mode: 0=standalone, 1=source, 2=sink */
+ imx477_write_reg(imx477, IMX477_REG_MC_MODE,
+ IMX477_REG_VALUE_08BIT, (trigger_mode > 0) ? 1 : 0);
+ imx477_write_reg(imx477, IMX477_REG_MS_SEL,
+ IMX477_REG_VALUE_08BIT, (trigger_mode <= 1) ? 1 : 0);
+ imx477_write_reg(imx477, IMX477_REG_XVS_IO_CTRL,
+ IMX477_REG_VALUE_08BIT, (trigger_mode == 1) ? 1 : 0);
+ imx477_write_reg(imx477, IMX477_REG_EXTOUT_EN,
+ IMX477_REG_VALUE_08BIT, (trigger_mode == 1) ? 1 : 0);
+
/* set stream on register */
return imx477_write_reg(imx477, IMX477_REG_MODE_SELECT,
IMX477_REG_VALUE_08BIT, IMX477_MODE_STREAMING);
IMX477_REG_VALUE_08BIT, IMX477_MODE_STANDBY);
if (ret)
dev_err(&client->dev, "%s failed to set stream\n", __func__);
+
+ /* Stop driving XVS out (there is still a weak pull-up) */
+ imx477_write_reg(imx477, IMX477_REG_EXTOUT_EN,
+ IMX477_REG_VALUE_08BIT, 0);
}
static int imx477_set_stream(struct v4l2_subdev *sd, int enable)