提交 11211641 编写于 作者: G Guennadi Liakhovetski 提交者: Mauro Carvalho Chehab

V4L/DVB (8685): mt9m001, mt9v022: Simplify return code checking

i2c_smbus_write_word_data() returns 0 or a negative error, hence no need to
check for "> 0".
Signed-off-by: NGuennadi Liakhovetski <g.liakhovetski@gmx.de>
Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
上级 77110abb
...@@ -119,16 +119,16 @@ static int mt9m001_init(struct soc_camera_device *icd) ...@@ -119,16 +119,16 @@ static int mt9m001_init(struct soc_camera_device *icd)
{ {
int ret; int ret;
/* Disable chip, synchronous option update */
dev_dbg(icd->vdev->parent, "%s\n", __func__); dev_dbg(icd->vdev->parent, "%s\n", __func__);
ret = reg_write(icd, MT9M001_RESET, 1); ret = reg_write(icd, MT9M001_RESET, 1);
if (ret >= 0) if (!ret)
ret = reg_write(icd, MT9M001_RESET, 0); ret = reg_write(icd, MT9M001_RESET, 0);
if (ret >= 0) /* Disable chip, synchronous option update */
if (!ret)
ret = reg_write(icd, MT9M001_OUTPUT_CONTROL, 0); ret = reg_write(icd, MT9M001_OUTPUT_CONTROL, 0);
return ret >= 0 ? 0 : -EIO; return ret;
} }
static int mt9m001_release(struct soc_camera_device *icd) static int mt9m001_release(struct soc_camera_device *icd)
...@@ -267,24 +267,24 @@ static int mt9m001_set_fmt_cap(struct soc_camera_device *icd, ...@@ -267,24 +267,24 @@ static int mt9m001_set_fmt_cap(struct soc_camera_device *icd,
/* Blanking and start values - default... */ /* Blanking and start values - default... */
ret = reg_write(icd, MT9M001_HORIZONTAL_BLANKING, hblank); ret = reg_write(icd, MT9M001_HORIZONTAL_BLANKING, hblank);
if (ret >= 0) if (!ret)
ret = reg_write(icd, MT9M001_VERTICAL_BLANKING, vblank); ret = reg_write(icd, MT9M001_VERTICAL_BLANKING, vblank);
/* The caller provides a supported format, as verified per /* The caller provides a supported format, as verified per
* call to icd->try_fmt_cap() */ * call to icd->try_fmt_cap() */
if (ret >= 0) if (!ret)
ret = reg_write(icd, MT9M001_COLUMN_START, rect->left); ret = reg_write(icd, MT9M001_COLUMN_START, rect->left);
if (ret >= 0) if (!ret)
ret = reg_write(icd, MT9M001_ROW_START, rect->top); ret = reg_write(icd, MT9M001_ROW_START, rect->top);
if (ret >= 0) if (!ret)
ret = reg_write(icd, MT9M001_WINDOW_WIDTH, rect->width - 1); ret = reg_write(icd, MT9M001_WINDOW_WIDTH, rect->width - 1);
if (ret >= 0) if (!ret)
ret = reg_write(icd, MT9M001_WINDOW_HEIGHT, ret = reg_write(icd, MT9M001_WINDOW_HEIGHT,
rect->height + icd->y_skip_top - 1); rect->height + icd->y_skip_top - 1);
if (ret >= 0 && mt9m001->autoexposure) { if (!ret && mt9m001->autoexposure) {
ret = reg_write(icd, MT9M001_SHUTTER_WIDTH, ret = reg_write(icd, MT9M001_SHUTTER_WIDTH,
rect->height + icd->y_skip_top + vblank); rect->height + icd->y_skip_top + vblank);
if (ret >= 0) { if (!ret) {
const struct v4l2_queryctrl *qctrl = const struct v4l2_queryctrl *qctrl =
soc_camera_find_qctrl(icd->ops, soc_camera_find_qctrl(icd->ops,
V4L2_CID_EXPOSURE); V4L2_CID_EXPOSURE);
...@@ -295,7 +295,7 @@ static int mt9m001_set_fmt_cap(struct soc_camera_device *icd, ...@@ -295,7 +295,7 @@ static int mt9m001_set_fmt_cap(struct soc_camera_device *icd,
} }
} }
return ret < 0 ? ret : 0; return ret;
} }
static int mt9m001_try_fmt_cap(struct soc_camera_device *icd, static int mt9m001_try_fmt_cap(struct soc_camera_device *icd,
......
...@@ -141,22 +141,22 @@ static int mt9v022_init(struct soc_camera_device *icd) ...@@ -141,22 +141,22 @@ static int mt9v022_init(struct soc_camera_device *icd)
* plus snapshot mode to disable scan for now */ * plus snapshot mode to disable scan for now */
mt9v022->chip_control |= 0x10; mt9v022->chip_control |= 0x10;
ret = reg_write(icd, MT9V022_CHIP_CONTROL, mt9v022->chip_control); ret = reg_write(icd, MT9V022_CHIP_CONTROL, mt9v022->chip_control);
if (ret >= 0) if (!ret)
reg_write(icd, MT9V022_READ_MODE, 0x300); ret = reg_write(icd, MT9V022_READ_MODE, 0x300);
/* All defaults */ /* All defaults */
if (ret >= 0) if (!ret)
/* AEC, AGC on */ /* AEC, AGC on */
ret = reg_set(icd, MT9V022_AEC_AGC_ENABLE, 0x3); ret = reg_set(icd, MT9V022_AEC_AGC_ENABLE, 0x3);
if (ret >= 0) if (!ret)
ret = reg_write(icd, MT9V022_MAX_TOTAL_SHUTTER_WIDTH, 480); ret = reg_write(icd, MT9V022_MAX_TOTAL_SHUTTER_WIDTH, 480);
if (ret >= 0) if (!ret)
/* default - auto */ /* default - auto */
ret = reg_clear(icd, MT9V022_BLACK_LEVEL_CALIB_CTRL, 1); ret = reg_clear(icd, MT9V022_BLACK_LEVEL_CALIB_CTRL, 1);
if (ret >= 0) if (!ret)
ret = reg_write(icd, MT9V022_DIGITAL_TEST_PATTERN, 0); ret = reg_write(icd, MT9V022_DIGITAL_TEST_PATTERN, 0);
return ret >= 0 ? 0 : -EIO; return ret;
} }
static int mt9v022_release(struct soc_camera_device *icd) static int mt9v022_release(struct soc_camera_device *icd)
...@@ -352,21 +352,21 @@ static int mt9v022_set_fmt_cap(struct soc_camera_device *icd, ...@@ -352,21 +352,21 @@ static int mt9v022_set_fmt_cap(struct soc_camera_device *icd,
rect->height + icd->y_skip_top + 43); rect->height + icd->y_skip_top + 43);
} }
/* Setup frame format: defaults apart from width and height */ /* Setup frame format: defaults apart from width and height */
if (ret >= 0) if (!ret)
ret = reg_write(icd, MT9V022_COLUMN_START, rect->left); ret = reg_write(icd, MT9V022_COLUMN_START, rect->left);
if (ret >= 0) if (!ret)
ret = reg_write(icd, MT9V022_ROW_START, rect->top); ret = reg_write(icd, MT9V022_ROW_START, rect->top);
if (ret >= 0) if (!ret)
/* Default 94, Phytec driver says: /* Default 94, Phytec driver says:
* "width + horizontal blank >= 660" */ * "width + horizontal blank >= 660" */
ret = reg_write(icd, MT9V022_HORIZONTAL_BLANKING, ret = reg_write(icd, MT9V022_HORIZONTAL_BLANKING,
rect->width > 660 - 43 ? 43 : rect->width > 660 - 43 ? 43 :
660 - rect->width); 660 - rect->width);
if (ret >= 0) if (!ret)
ret = reg_write(icd, MT9V022_VERTICAL_BLANKING, 45); ret = reg_write(icd, MT9V022_VERTICAL_BLANKING, 45);
if (ret >= 0) if (!ret)
ret = reg_write(icd, MT9V022_WINDOW_WIDTH, rect->width); ret = reg_write(icd, MT9V022_WINDOW_WIDTH, rect->width);
if (ret >= 0) if (!ret)
ret = reg_write(icd, MT9V022_WINDOW_HEIGHT, ret = reg_write(icd, MT9V022_WINDOW_HEIGHT,
rect->height + icd->y_skip_top); rect->height + icd->y_skip_top);
...@@ -717,7 +717,7 @@ static int mt9v022_video_probe(struct soc_camera_device *icd) ...@@ -717,7 +717,7 @@ static int mt9v022_video_probe(struct soc_camera_device *icd)
icd->num_formats = 1; icd->num_formats = 1;
} }
if (ret >= 0) if (!ret)
ret = soc_camera_video_start(icd); ret = soc_camera_video_start(icd);
if (ret < 0) if (ret < 0)
goto eisis; goto eisis;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册