}
 #endif
 
+static int ov7670_s_power(struct v4l2_subdev *sd, int on)
+{
+       struct ov7670_info *info = to_state(sd);
+
+       if (info->pwdn_gpio)
+               gpiod_set_value(info->pwdn_gpio, !on);
+       if (on && info->resetb_gpio) {
+               gpiod_set_value(info->resetb_gpio, 1);
+               usleep_range(500, 1000);
+               gpiod_set_value(info->resetb_gpio, 0);
+               usleep_range(3000, 5000);
+       }
+
+       return 0;
+}
+
 static void ov7670_get_default_format(struct v4l2_subdev *sd,
                                      struct v4l2_mbus_framefmt *format)
 {
        if (ret)
                return ret;
 
-       ret = ov7670_init_gpio(client, info);
-       if (ret)
-               goto clk_disable;
-
        info->clock_speed = clk_get_rate(info->clk) / 1000000;
        if (info->clock_speed < 10 || info->clock_speed > 48) {
                ret = -EINVAL;
                goto clk_disable;
        }
 
+       ret = ov7670_init_gpio(client, info);
+       if (ret)
+               goto clk_disable;
+
+       ov7670_s_power(sd, 1);
+
        /* Make sure it's an ov7670 */
        ret = ov7670_detect(sd);
        if (ret) {
                v4l_dbg(1, debug, client,
                        "chip found @ 0x%x (%s) is not an ov7670 chip.\n",
                        client->addr << 1, client->adapter->name);
-               goto clk_disable;
+               goto power_off;
        }
        v4l_info(client, "chip found @ 0x%02x (%s)\n",
                        client->addr << 1, client->adapter->name);
 #endif
 hdl_free:
        v4l2_ctrl_handler_free(&info->hdl);
+power_off:
+       ov7670_s_power(sd, 0);
 clk_disable:
        clk_disable_unprepare(info->clk);
        return ret;
 #if defined(CONFIG_MEDIA_CONTROLLER)
        media_entity_cleanup(&info->sd.entity);
 #endif
+       ov7670_s_power(sd, 0);
        return 0;
 }