summaryrefslogtreecommitdiffstats
path: root/drivers/media
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/media')
-rw-r--r--drivers/media/i2c/ov10823.c73
1 files changed, 36 insertions, 37 deletions
diff --git a/drivers/media/i2c/ov10823.c b/drivers/media/i2c/ov10823.c
index e1b81ddc7..ca92e4194 100644
--- a/drivers/media/i2c/ov10823.c
+++ b/drivers/media/i2c/ov10823.c
@@ -272,10 +272,11 @@ static int ov10823_write_reg(struct camera_common_data *s_data,
272{ 272{
273 int err; 273 int err;
274 struct ov10823 *priv = (struct ov10823 *)s_data->priv; 274 struct ov10823 *priv = (struct ov10823 *)s_data->priv;
275 struct device *dev = &priv->i2c_client->dev;
275 276
276 err = regmap_write(priv->regmap, addr, val); 277 err = regmap_write(priv->regmap, addr, val);
277 if (err) 278 if (err)
278 pr_err("%s:i2c write failed, %x = %x\n", 279 dev_err(dev, "%s: i2c write failed, %x = %x\n",
279 __func__, addr, val); 280 __func__, addr, val);
280 281
281 return err; 282 return err;
@@ -296,13 +297,14 @@ static int ov10823_power_on(struct camera_common_data *s_data)
296 int err = 0; 297 int err = 0;
297 struct ov10823 *priv = (struct ov10823 *)s_data->priv; 298 struct ov10823 *priv = (struct ov10823 *)s_data->priv;
298 struct camera_common_power_rail *pw = &priv->power; 299 struct camera_common_power_rail *pw = &priv->power;
300 struct device *dev = &priv->i2c_client->dev;
299 301
300 dev_dbg(&priv->i2c_client->dev, "%s: power on\n", __func__); 302 dev_dbg(dev, "%s: power on\n", __func__);
301 303
302 if (priv->pdata->power_on) { 304 if (priv->pdata->power_on) {
303 err = priv->pdata->power_on(pw); 305 err = priv->pdata->power_on(pw);
304 if (err) 306 if (err)
305 pr_err("%s failed.\n", __func__); 307 dev_err(dev, "%s failed.\n", __func__);
306 else 308 else
307 pw->state = SWITCH_ON; 309 pw->state = SWITCH_ON;
308 return err; 310 return err;
@@ -318,14 +320,15 @@ static int ov10823_power_off(struct camera_common_data *s_data)
318 int err = 0; 320 int err = 0;
319 struct ov10823 *priv = (struct ov10823 *)s_data->priv; 321 struct ov10823 *priv = (struct ov10823 *)s_data->priv;
320 struct camera_common_power_rail *pw = &priv->power; 322 struct camera_common_power_rail *pw = &priv->power;
323 struct device *dev = &priv->i2c_client->dev;
321 324
322 dev_dbg(&priv->i2c_client->dev, "%s: power off\n", __func__); 325 dev_dbg(dev, "%s: power off\n", __func__);
323 ov10823_write_table(priv, mode_table[OV10823_MODE_STOP_STREAM]); 326 ov10823_write_table(priv, mode_table[OV10823_MODE_STOP_STREAM]);
324 327
325 if (priv->pdata->power_off) { 328 if (priv->pdata->power_off) {
326 err = priv->pdata->power_off(pw); 329 err = priv->pdata->power_off(pw);
327 if (err) 330 if (err)
328 pr_err("%s failed.\n", __func__); 331 dev_err(dev, "%s failed.\n", __func__);
329 else 332 else
330 goto power_off_done; 333 goto power_off_done;
331 } 334 }
@@ -345,15 +348,15 @@ static int ov10823_power_put(struct ov10823 *priv)
345static int ov10823_power_get(struct ov10823 *priv) 348static int ov10823_power_get(struct ov10823 *priv)
346{ 349{
347 struct camera_common_power_rail *pw = &priv->power; 350 struct camera_common_power_rail *pw = &priv->power;
351 struct device *dev = &priv->i2c_client->dev;
348 const char *mclk_name; 352 const char *mclk_name;
349 int err = 0; 353 int err = 0;
350 354
351 mclk_name = priv->pdata->mclk_name ? 355 mclk_name = priv->pdata->mclk_name ?
352 priv->pdata->mclk_name : "cam_mclk1"; 356 priv->pdata->mclk_name : "cam_mclk1";
353 pw->mclk = devm_clk_get(&priv->i2c_client->dev, mclk_name); 357 pw->mclk = devm_clk_get(dev, mclk_name);
354 if (IS_ERR(pw->mclk)) { 358 if (IS_ERR(pw->mclk)) {
355 dev_err(&priv->i2c_client->dev, 359 dev_err(dev, "unable to get clock %s\n", mclk_name);
356 "unable to get clock %s\n", mclk_name);
357 return PTR_ERR(pw->mclk); 360 return PTR_ERR(pw->mclk);
358 } 361 }
359 362
@@ -580,6 +583,7 @@ static struct camera_common_sensor_ops ov10823_common_ops = {
580 583
581static int ov10823_set_group_hold(struct ov10823 *priv) 584static int ov10823_set_group_hold(struct ov10823 *priv)
582{ 585{
586 struct device *dev = &priv->i2c_client->dev;
583 int err; 587 int err;
584 int gh_prev = switch_ctrl_qmenu[priv->group_hold_prev]; 588 int gh_prev = switch_ctrl_qmenu[priv->group_hold_prev];
585 589
@@ -605,13 +609,13 @@ static int ov10823_set_group_hold(struct ov10823 *priv)
605 return 0; 609 return 0;
606 610
607fail: 611fail:
608 dev_dbg(&priv->i2c_client->dev, 612 dev_dbg(dev, "%s: Group hold control error\n", __func__);
609 "%s: Group hold control error\n", __func__);
610 return err; 613 return err;
611} 614}
612 615
613static int ov10823_set_gain(struct ov10823 *priv, s32 val) 616static int ov10823_set_gain(struct ov10823 *priv, s32 val)
614{ 617{
618 struct device *dev = &priv->i2c_client->dev;
615 ov10823_reg reg_list[3]; 619 ov10823_reg reg_list[3];
616 int err; 620 int err;
617 u16 gain; 621 u16 gain;
@@ -621,8 +625,7 @@ static int ov10823_set_gain(struct ov10823 *priv, s32 val)
621 /* translate value */ 625 /* translate value */
622 gain = ov10823_to_gain((u32)val, OV10823_GAIN_SHIFT); 626 gain = ov10823_to_gain((u32)val, OV10823_GAIN_SHIFT);
623 627
624 dev_dbg(&priv->i2c_client->dev, 628 dev_dbg(dev, "%s: gain: %d\n", __func__, gain);
625 "%s: gain: %d\n", __func__, gain);
626 629
627 ov10823_get_gain_reg(reg_list, gain); 630 ov10823_get_gain_reg(reg_list, gain);
628 ov10823_set_group_hold(priv); 631 ov10823_set_group_hold(priv);
@@ -633,21 +636,20 @@ static int ov10823_set_gain(struct ov10823 *priv, s32 val)
633 return 0; 636 return 0;
634 637
635fail: 638fail:
636 dev_dbg(&priv->i2c_client->dev, 639 dev_dbg(dev, "%s: GAIN control error\n", __func__);
637 "%s: GAIN control error\n", __func__);
638 return err; 640 return err;
639} 641}
640 642
641static int ov10823_set_frame_length(struct ov10823 *priv, s32 val) 643static int ov10823_set_frame_length(struct ov10823 *priv, s32 val)
642{ 644{
645 struct device *dev = &priv->i2c_client->dev;
643 ov10823_reg reg_list[5]; 646 ov10823_reg reg_list[5];
644 int err; 647 int err;
645 u16 frame_length; 648 u16 frame_length;
646 649
647 frame_length = (u16)val; 650 frame_length = (u16)val;
648 651
649 dev_dbg(&priv->i2c_client->dev, 652 dev_dbg(dev, "%s: frame_length: %d\n", __func__, frame_length);
650 "%s: frame_length: %d\n", __func__, frame_length);
651 653
652 ov10823_get_frame_length_regs(reg_list, frame_length, priv->fsync); 654 ov10823_get_frame_length_regs(reg_list, frame_length, priv->fsync);
653 ov10823_set_group_hold(priv); 655 ov10823_set_group_hold(priv);
@@ -658,21 +660,20 @@ static int ov10823_set_frame_length(struct ov10823 *priv, s32 val)
658 return 0; 660 return 0;
659 661
660fail: 662fail:
661 dev_dbg(&priv->i2c_client->dev, 663 dev_dbg(dev, "%s: FRAME_LENGTH control error\n", __func__);
662 "%s: FRAME_LENGTH control error\n", __func__);
663 return err; 664 return err;
664} 665}
665 666
666static int ov10823_set_coarse_time(struct ov10823 *priv, s32 val) 667static int ov10823_set_coarse_time(struct ov10823 *priv, s32 val)
667{ 668{
669 struct device *dev = &priv->i2c_client->dev;
668 ov10823_reg reg_list[4]; 670 ov10823_reg reg_list[4];
669 int err; 671 int err;
670 u16 coarse_time; 672 u16 coarse_time;
671 673
672 coarse_time = (u16)val; 674 coarse_time = (u16)val;
673 675
674 dev_dbg(&priv->i2c_client->dev, 676 dev_dbg(dev, "%s: coarse_time: %d\n", __func__, coarse_time);
675 "%s: coarse_time: %d\n", __func__, coarse_time);
676 677
677 ov10823_get_coarse_time_regs(reg_list, coarse_time); 678 ov10823_get_coarse_time_regs(reg_list, coarse_time);
678 ov10823_set_group_hold(priv); 679 ov10823_set_group_hold(priv);
@@ -683,8 +684,7 @@ static int ov10823_set_coarse_time(struct ov10823 *priv, s32 val)
683 return 0; 684 return 0;
684 685
685fail: 686fail:
686 dev_dbg(&priv->i2c_client->dev, 687 dev_dbg(dev, "%s: COARSE_TIME control error\n", __func__);
687 "%s: COARSE_TIME control error\n", __func__);
688 return err; 688 return err;
689} 689}
690 690
@@ -724,6 +724,7 @@ static int ov10823_read_otp(struct ov10823 *priv, u8 *buf,
724 724
725static int ov10823_otp_setup(struct ov10823 *priv) 725static int ov10823_otp_setup(struct ov10823 *priv)
726{ 726{
727 struct device *dev = &priv->i2c_client->dev;
727 int err; 728 int err;
728 int i; 729 int i;
729 struct v4l2_ctrl *ctrl; 730 struct v4l2_ctrl *ctrl;
@@ -739,8 +740,7 @@ static int ov10823_otp_setup(struct ov10823 *priv)
739 740
740 ctrl = v4l2_ctrl_find(&priv->ctrl_handler, TEGRA_CAMERA_CID_OTP_DATA); 741 ctrl = v4l2_ctrl_find(&priv->ctrl_handler, TEGRA_CAMERA_CID_OTP_DATA);
741 if (!ctrl) { 742 if (!ctrl) {
742 dev_err(&priv->i2c_client->dev, 743 dev_err(dev, "could not find device ctrl.\n");
743 "could not find device ctrl.\n");
744 return -EINVAL; 744 return -EINVAL;
745 } 745 }
746 746
@@ -758,6 +758,7 @@ static int ov10823_otp_setup(struct ov10823 *priv)
758 758
759static int ov10823_fuse_id_setup(struct ov10823 *priv) 759static int ov10823_fuse_id_setup(struct ov10823 *priv)
760{ 760{
761 struct device *dev = &priv->i2c_client->dev;
761 int err; 762 int err;
762 int i; 763 int i;
763 struct v4l2_ctrl *ctrl; 764 struct v4l2_ctrl *ctrl;
@@ -773,8 +774,7 @@ static int ov10823_fuse_id_setup(struct ov10823 *priv)
773 774
774 ctrl = v4l2_ctrl_find(&priv->ctrl_handler, TEGRA_CAMERA_CID_FUSE_ID); 775 ctrl = v4l2_ctrl_find(&priv->ctrl_handler, TEGRA_CAMERA_CID_FUSE_ID);
775 if (!ctrl) { 776 if (!ctrl) {
776 dev_err(&priv->i2c_client->dev, 777 dev_err(dev, "could not find device ctrl.\n");
777 "could not find device ctrl.\n");
778 return -EINVAL; 778 return -EINVAL;
779 } 779 }
780 780
@@ -794,6 +794,7 @@ static int ov10823_g_volatile_ctrl(struct v4l2_ctrl *ctrl)
794{ 794{
795 struct ov10823 *priv = 795 struct ov10823 *priv =
796 container_of(ctrl->handler, struct ov10823, ctrl_handler); 796 container_of(ctrl->handler, struct ov10823, ctrl_handler);
797 struct device *dev = &priv->i2c_client->dev;
797 int err = 0; 798 int err = 0;
798 799
799 if (priv->power.state == SWITCH_OFF) 800 if (priv->power.state == SWITCH_OFF)
@@ -801,7 +802,7 @@ static int ov10823_g_volatile_ctrl(struct v4l2_ctrl *ctrl)
801 802
802 switch (ctrl->id) { 803 switch (ctrl->id) {
803 default: 804 default:
804 pr_err("%s: unknown ctrl id.\n", __func__); 805 dev_err(dev, "%s: unknown ctrl id.\n", __func__);
805 return -EINVAL; 806 return -EINVAL;
806 } 807 }
807 808
@@ -812,6 +813,7 @@ static int ov10823_s_ctrl(struct v4l2_ctrl *ctrl)
812{ 813{
813 struct ov10823 *priv = 814 struct ov10823 *priv =
814 container_of(ctrl->handler, struct ov10823, ctrl_handler); 815 container_of(ctrl->handler, struct ov10823, ctrl_handler);
816 struct device *dev = &priv->i2c_client->dev;
815 int err = 0; 817 int err = 0;
816 818
817 if (priv->power.state == SWITCH_OFF) 819 if (priv->power.state == SWITCH_OFF)
@@ -845,7 +847,7 @@ static int ov10823_s_ctrl(struct v4l2_ctrl *ctrl)
845 case TEGRA_CAMERA_CID_HDR_EN: 847 case TEGRA_CAMERA_CID_HDR_EN:
846 break; 848 break;
847 default: 849 default:
848 pr_err("%s: unknown ctrl id.\n", __func__); 850 dev_err(dev, "%s: unknown ctrl id.\n", __func__);
849 return -EINVAL; 851 return -EINVAL;
850 } 852 }
851 853
@@ -957,6 +959,7 @@ static int ov10823_parse_dt(struct i2c_client *client, struct ov10823 *priv)
957 959
958static int ov10823_i2c_addr_assign(struct ov10823 *priv, u8 i2c_addr) 960static int ov10823_i2c_addr_assign(struct ov10823 *priv, u8 i2c_addr)
959{ 961{
962 struct device *dev = &priv->i2c_client->dev;
960 struct i2c_msg msg; 963 struct i2c_msg msg;
961 unsigned char data[3]; 964 unsigned char data[3];
962 int err; 965 int err;
@@ -992,16 +995,14 @@ static int ov10823_i2c_addr_assign(struct ov10823 *priv, u8 i2c_addr)
992 */ 995 */
993 996
994 if (i2c_addr == OV10823_DEFAULT_I2C_ADDRESS_20) { 997 if (i2c_addr == OV10823_DEFAULT_I2C_ADDRESS_20) {
995 dev_info(&priv->i2c_client->dev, 998 dev_info(dev, "Using default I2C address 0x%02x\n", i2c_addr);
996 "Using default I2C address 0x%02x\n", i2c_addr);
997 if (gpio_is_valid(priv->cam_sid_gpio)) { 999 if (gpio_is_valid(priv->cam_sid_gpio)) {
998 gpio_set_value(priv->cam_sid_gpio, 0); 1000 gpio_set_value(priv->cam_sid_gpio, 0);
999 msleep_range(1); 1001 msleep_range(1);
1000 } 1002 }
1001 return 0; 1003 return 0;
1002 } else if (i2c_addr == OV10823_DEFAULT_I2C_ADDRESS_6C) { 1004 } else if (i2c_addr == OV10823_DEFAULT_I2C_ADDRESS_6C) {
1003 dev_info(&priv->i2c_client->dev, 1005 dev_info(dev, "Using default I2C address 0x%02x\n", i2c_addr);
1004 "Using default I2C address 0x%02x\n", i2c_addr);
1005 if (gpio_is_valid(priv->cam_sid_gpio)) { 1006 if (gpio_is_valid(priv->cam_sid_gpio)) {
1006 gpio_set_value(priv->cam_sid_gpio, 1); 1007 gpio_set_value(priv->cam_sid_gpio, 1);
1007 msleep_range(1); 1008 msleep_range(1);
@@ -1014,16 +1015,14 @@ static int ov10823_i2c_addr_assign(struct ov10823 *priv, u8 i2c_addr)
1014 * slave address. We necessarily need to have a cam-sid-gpio for this. 1015 * slave address. We necessarily need to have a cam-sid-gpio for this.
1015 */ 1016 */
1016 if (!gpio_is_valid(priv->cam_sid_gpio)) { 1017 if (!gpio_is_valid(priv->cam_sid_gpio)) {
1017 dev_err(&priv->i2c_client->dev, 1018 dev_err(dev, "Missing cam-sid-gpio, cannot program I2C addr\n");
1018 "Missing cam-sid-gpio, cannot program I2C address\n");
1019 return -EINVAL; 1019 return -EINVAL;
1020 } 1020 }
1021 1021
1022 gpio_set_value(priv->cam_sid_gpio, 1); 1022 gpio_set_value(priv->cam_sid_gpio, 1);
1023 msleep_range(1); 1023 msleep_range(1);
1024 1024
1025 dev_info(&priv->i2c_client->dev, "Changing I2C address to 0x%02x\n", 1025 dev_info(dev, "Changing I2C address to 0x%02x\n", i2c_addr);
1026 i2c_addr);
1027 1026
1028 /* 1027 /*
1029 * Have to make the I2C message manually because we are using a 1028 * Have to make the I2C message manually because we are using a
@@ -1084,7 +1083,7 @@ static int ov10823_probe(struct i2c_client *client,
1084 struct ov10823 *priv; 1083 struct ov10823 *priv;
1085 int err; 1084 int err;
1086 1085
1087 pr_info("[OV10823]: probing v4l2 sensor.\n"); 1086 dev_info(&client->dev, "probing v4l2 sensor.\n");
1088 1087
1089 common_data = devm_kzalloc(&client->dev, 1088 common_data = devm_kzalloc(&client->dev,
1090 sizeof(struct camera_common_data), GFP_KERNEL); 1089 sizeof(struct camera_common_data), GFP_KERNEL);