aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/mt9m111.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/media/video/mt9m111.c')
-rw-r--r--drivers/media/video/mt9m111.c86
1 files changed, 42 insertions, 44 deletions
diff --git a/drivers/media/video/mt9m111.c b/drivers/media/video/mt9m111.c
index 0c88e5d6dc44..d99932631050 100644
--- a/drivers/media/video/mt9m111.c
+++ b/drivers/media/video/mt9m111.c
@@ -173,7 +173,7 @@ static int reg_page_map_set(struct i2c_client *client, const u16 reg)
173 return -EINVAL; 173 return -EINVAL;
174 174
175 ret = i2c_smbus_write_word_data(client, MT9M111_PAGE_MAP, swab16(page)); 175 ret = i2c_smbus_write_word_data(client, MT9M111_PAGE_MAP, swab16(page));
176 if (ret >= 0) 176 if (!ret)
177 lastpage = page; 177 lastpage = page;
178 return ret; 178 return ret;
179} 179}
@@ -200,7 +200,7 @@ static int mt9m111_reg_write(struct soc_camera_device *icd, const u16 reg,
200 int ret; 200 int ret;
201 201
202 ret = reg_page_map_set(client, reg); 202 ret = reg_page_map_set(client, reg);
203 if (ret >= 0) 203 if (!ret)
204 ret = i2c_smbus_write_word_data(mt9m111->client, (reg & 0xff), 204 ret = i2c_smbus_write_word_data(mt9m111->client, (reg & 0xff),
205 swab16(data)); 205 swab16(data));
206 dev_dbg(&icd->dev, "write reg.%03x = %04x -> %d\n", reg, data, ret); 206 dev_dbg(&icd->dev, "write reg.%03x = %04x -> %d\n", reg, data, ret);
@@ -246,7 +246,7 @@ static int mt9m111_set_context(struct soc_camera_device *icd,
246static int mt9m111_setup_rect(struct soc_camera_device *icd) 246static int mt9m111_setup_rect(struct soc_camera_device *icd)
247{ 247{
248 struct mt9m111 *mt9m111 = container_of(icd, struct mt9m111, icd); 248 struct mt9m111 *mt9m111 = container_of(icd, struct mt9m111, icd);
249 int ret = 0, is_raw_format; 249 int ret, is_raw_format;
250 int width = mt9m111->width; 250 int width = mt9m111->width;
251 int height = mt9m111->height; 251 int height = mt9m111->height;
252 252
@@ -256,32 +256,31 @@ static int mt9m111_setup_rect(struct soc_camera_device *icd)
256 else 256 else
257 is_raw_format = 0; 257 is_raw_format = 0;
258 258
259 if (ret >= 0) 259 ret = reg_write(COLUMN_START, mt9m111->left);
260 ret = reg_write(COLUMN_START, mt9m111->left); 260 if (!ret)
261 if (ret >= 0)
262 ret = reg_write(ROW_START, mt9m111->top); 261 ret = reg_write(ROW_START, mt9m111->top);
263 262
264 if (is_raw_format) { 263 if (is_raw_format) {
265 if (ret >= 0) 264 if (!ret)
266 ret = reg_write(WINDOW_WIDTH, width); 265 ret = reg_write(WINDOW_WIDTH, width);
267 if (ret >= 0) 266 if (!ret)
268 ret = reg_write(WINDOW_HEIGHT, height); 267 ret = reg_write(WINDOW_HEIGHT, height);
269 } else { 268 } else {
270 if (ret >= 0) 269 if (!ret)
271 ret = reg_write(REDUCER_XZOOM_B, MT9M111_MAX_WIDTH); 270 ret = reg_write(REDUCER_XZOOM_B, MT9M111_MAX_WIDTH);
272 if (ret >= 0) 271 if (!ret)
273 ret = reg_write(REDUCER_YZOOM_B, MT9M111_MAX_HEIGHT); 272 ret = reg_write(REDUCER_YZOOM_B, MT9M111_MAX_HEIGHT);
274 if (ret >= 0) 273 if (!ret)
275 ret = reg_write(REDUCER_XSIZE_B, width); 274 ret = reg_write(REDUCER_XSIZE_B, width);
276 if (ret >= 0) 275 if (!ret)
277 ret = reg_write(REDUCER_YSIZE_B, height); 276 ret = reg_write(REDUCER_YSIZE_B, height);
278 if (ret >= 0) 277 if (!ret)
279 ret = reg_write(REDUCER_XZOOM_A, MT9M111_MAX_WIDTH); 278 ret = reg_write(REDUCER_XZOOM_A, MT9M111_MAX_WIDTH);
280 if (ret >= 0) 279 if (!ret)
281 ret = reg_write(REDUCER_YZOOM_A, MT9M111_MAX_HEIGHT); 280 ret = reg_write(REDUCER_YZOOM_A, MT9M111_MAX_HEIGHT);
282 if (ret >= 0) 281 if (!ret)
283 ret = reg_write(REDUCER_XSIZE_A, width); 282 ret = reg_write(REDUCER_XSIZE_A, width);
284 if (ret >= 0) 283 if (!ret)
285 ret = reg_write(REDUCER_YSIZE_A, height); 284 ret = reg_write(REDUCER_YSIZE_A, height);
286 } 285 }
287 286
@@ -293,7 +292,7 @@ static int mt9m111_setup_pixfmt(struct soc_camera_device *icd, u16 outfmt)
293 int ret; 292 int ret;
294 293
295 ret = reg_write(OUTPUT_FORMAT_CTRL2_A, outfmt); 294 ret = reg_write(OUTPUT_FORMAT_CTRL2_A, outfmt);
296 if (ret >= 0) 295 if (!ret)
297 ret = reg_write(OUTPUT_FORMAT_CTRL2_B, outfmt); 296 ret = reg_write(OUTPUT_FORMAT_CTRL2_B, outfmt);
298 return ret; 297 return ret;
299} 298}
@@ -305,7 +304,6 @@ static int mt9m111_setfmt_bayer8(struct soc_camera_device *icd)
305 304
306static int mt9m111_setfmt_bayer10(struct soc_camera_device *icd) 305static int mt9m111_setfmt_bayer10(struct soc_camera_device *icd)
307{ 306{
308
309 return mt9m111_setup_pixfmt(icd, MT9M111_OUTFMT_BYPASS_IFP); 307 return mt9m111_setup_pixfmt(icd, MT9M111_OUTFMT_BYPASS_IFP);
310} 308}
311 309
@@ -356,7 +354,7 @@ static int mt9m111_enable(struct soc_camera_device *icd)
356 int ret; 354 int ret;
357 355
358 ret = reg_set(RESET, MT9M111_RESET_CHIP_ENABLE); 356 ret = reg_set(RESET, MT9M111_RESET_CHIP_ENABLE);
359 if (ret >= 0) 357 if (!ret)
360 mt9m111->powered = 1; 358 mt9m111->powered = 1;
361 return ret; 359 return ret;
362} 360}
@@ -367,7 +365,7 @@ static int mt9m111_disable(struct soc_camera_device *icd)
367 int ret; 365 int ret;
368 366
369 ret = reg_clear(RESET, MT9M111_RESET_CHIP_ENABLE); 367 ret = reg_clear(RESET, MT9M111_RESET_CHIP_ENABLE);
370 if (ret >= 0) 368 if (!ret)
371 mt9m111->powered = 0; 369 mt9m111->powered = 0;
372 return ret; 370 return ret;
373} 371}
@@ -377,9 +375,9 @@ static int mt9m111_reset(struct soc_camera_device *icd)
377 int ret; 375 int ret;
378 376
379 ret = reg_set(RESET, MT9M111_RESET_RESET_MODE); 377 ret = reg_set(RESET, MT9M111_RESET_RESET_MODE);
380 if (ret >= 0) 378 if (!ret)
381 ret = reg_set(RESET, MT9M111_RESET_RESET_SOC); 379 ret = reg_set(RESET, MT9M111_RESET_RESET_SOC);
382 if (ret >= 0) 380 if (!ret)
383 ret = reg_clear(RESET, MT9M111_RESET_RESET_MODE 381 ret = reg_clear(RESET, MT9M111_RESET_RESET_MODE
384 | MT9M111_RESET_RESET_SOC); 382 | MT9M111_RESET_RESET_SOC);
385 return ret; 383 return ret;
@@ -410,7 +408,7 @@ static int mt9m111_set_bus_param(struct soc_camera_device *icd, unsigned long f)
410static int mt9m111_set_pixfmt(struct soc_camera_device *icd, u32 pixfmt) 408static int mt9m111_set_pixfmt(struct soc_camera_device *icd, u32 pixfmt)
411{ 409{
412 struct mt9m111 *mt9m111 = container_of(icd, struct mt9m111, icd); 410 struct mt9m111 *mt9m111 = container_of(icd, struct mt9m111, icd);
413 int ret = 0; 411 int ret;
414 412
415 switch (pixfmt) { 413 switch (pixfmt) {
416 case V4L2_PIX_FMT_SBGGR8: 414 case V4L2_PIX_FMT_SBGGR8:
@@ -433,7 +431,7 @@ static int mt9m111_set_pixfmt(struct soc_camera_device *icd, u32 pixfmt)
433 ret = -EINVAL; 431 ret = -EINVAL;
434 } 432 }
435 433
436 if (ret >= 0) 434 if (!ret)
437 mt9m111->pixfmt = pixfmt; 435 mt9m111->pixfmt = pixfmt;
438 436
439 return ret; 437 return ret;
@@ -443,7 +441,7 @@ static int mt9m111_set_fmt_cap(struct soc_camera_device *icd,
443 __u32 pixfmt, struct v4l2_rect *rect) 441 __u32 pixfmt, struct v4l2_rect *rect)
444{ 442{
445 struct mt9m111 *mt9m111 = container_of(icd, struct mt9m111, icd); 443 struct mt9m111 *mt9m111 = container_of(icd, struct mt9m111, icd);
446 int ret = 0; 444 int ret;
447 445
448 mt9m111->left = rect->left; 446 mt9m111->left = rect->left;
449 mt9m111->top = rect->top; 447 mt9m111->top = rect->top;
@@ -455,9 +453,9 @@ static int mt9m111_set_fmt_cap(struct soc_camera_device *icd,
455 mt9m111->height); 453 mt9m111->height);
456 454
457 ret = mt9m111_setup_rect(icd); 455 ret = mt9m111_setup_rect(icd);
458 if (ret >= 0) 456 if (!ret)
459 ret = mt9m111_set_pixfmt(icd, pixfmt); 457 ret = mt9m111_set_pixfmt(icd, pixfmt);
460 return ret < 0 ? ret : 0; 458 return ret;
461} 459}
462 460
463static int mt9m111_try_fmt_cap(struct soc_camera_device *icd, 461static int mt9m111_try_fmt_cap(struct soc_camera_device *icd,
@@ -644,7 +642,7 @@ static int mt9m111_set_global_gain(struct soc_camera_device *icd, int gain)
644 if ((gain >= 64 * 2) && (gain < 63 * 2 * 2)) 642 if ((gain >= 64 * 2) && (gain < 63 * 2 * 2))
645 val = (1 << 10) | (1 << 9) | (gain / 4); 643 val = (1 << 10) | (1 << 9) | (gain / 4);
646 else if ((gain >= 64) && (gain < 64 * 2)) 644 else if ((gain >= 64) && (gain < 64 * 2))
647 val = (1<<9) | (gain / 2); 645 val = (1 << 9) | (gain / 2);
648 else 646 else
649 val = gain; 647 val = gain;
650 648
@@ -661,7 +659,7 @@ static int mt9m111_set_autoexposure(struct soc_camera_device *icd, int on)
661 else 659 else
662 ret = reg_clear(OPER_MODE_CTRL, MT9M111_OPMODE_AUTOEXPO_EN); 660 ret = reg_clear(OPER_MODE_CTRL, MT9M111_OPMODE_AUTOEXPO_EN);
663 661
664 if (ret >= 0) 662 if (!ret)
665 mt9m111->autoexposure = on; 663 mt9m111->autoexposure = on;
666 664
667 return ret; 665 return ret;
@@ -711,7 +709,7 @@ static int mt9m111_set_control(struct soc_camera_device *icd,
711{ 709{
712 struct mt9m111 *mt9m111 = container_of(icd, struct mt9m111, icd); 710 struct mt9m111 *mt9m111 = container_of(icd, struct mt9m111, icd);
713 const struct v4l2_queryctrl *qctrl; 711 const struct v4l2_queryctrl *qctrl;
714 int ret = 0; 712 int ret;
715 713
716 qctrl = soc_camera_find_qctrl(&mt9m111_ops, ctrl->id); 714 qctrl = soc_camera_find_qctrl(&mt9m111_ops, ctrl->id);
717 715
@@ -739,7 +737,7 @@ static int mt9m111_set_control(struct soc_camera_device *icd,
739 ret = -EINVAL; 737 ret = -EINVAL;
740 } 738 }
741 739
742 return ret < 0 ? -EIO : 0; 740 return ret;
743} 741}
744 742
745int mt9m111_restore_state(struct soc_camera_device *icd) 743int mt9m111_restore_state(struct soc_camera_device *icd)
@@ -763,10 +761,10 @@ static int mt9m111_resume(struct soc_camera_device *icd)
763 761
764 if (mt9m111->powered) { 762 if (mt9m111->powered) {
765 ret = mt9m111_enable(icd); 763 ret = mt9m111_enable(icd);
766 if (ret >= 0) 764 if (!ret)
767 mt9m111_reset(icd); 765 ret = mt9m111_reset(icd);
768 if (ret >= 0) 766 if (!ret)
769 mt9m111_restore_state(icd); 767 ret = mt9m111_restore_state(icd);
770 } 768 }
771 return ret; 769 return ret;
772} 770}
@@ -778,15 +776,15 @@ static int mt9m111_init(struct soc_camera_device *icd)
778 776
779 mt9m111->context = HIGHPOWER; 777 mt9m111->context = HIGHPOWER;
780 ret = mt9m111_enable(icd); 778 ret = mt9m111_enable(icd);
781 if (ret >= 0) 779 if (!ret)
782 mt9m111_reset(icd); 780 ret = mt9m111_reset(icd);
783 if (ret >= 0) 781 if (!ret)
784 mt9m111_set_context(icd, mt9m111->context); 782 ret = mt9m111_set_context(icd, mt9m111->context);
785 if (ret >= 0) 783 if (!ret)
786 mt9m111_set_autoexposure(icd, mt9m111->autoexposure); 784 ret = mt9m111_set_autoexposure(icd, mt9m111->autoexposure);
787 if (ret < 0) 785 if (ret)
788 dev_err(&icd->dev, "mt9m111 init failed: %d\n", ret); 786 dev_err(&icd->dev, "mt9m111 init failed: %d\n", ret);
789 return ret ? -EIO : 0; 787 return ret;
790} 788}
791 789
792static int mt9m111_release(struct soc_camera_device *icd) 790static int mt9m111_release(struct soc_camera_device *icd)
@@ -797,7 +795,7 @@ static int mt9m111_release(struct soc_camera_device *icd)
797 if (ret < 0) 795 if (ret < 0)
798 dev_err(&icd->dev, "mt9m111 release failed: %d\n", ret); 796 dev_err(&icd->dev, "mt9m111 release failed: %d\n", ret);
799 797
800 return ret ? -EIO : 0; 798 return ret;
801} 799}
802 800
803/* 801/*