#include <linux/acpi.h>
 #include <linux/clk.h>
+#include <linux/gpio/consumer.h>
 #include <linux/i2c.h>
 #include <linux/mod_devicetable.h>
 #include <linux/module.h>
        /* Regulators */
        struct regulator_bulk_data supplies[OV5670_NUM_SUPPLIES];
 
+       /* Power-down and reset gpios. */
+       struct gpio_desc *pwdn_gpio; /* PWDNB pin. */
+       struct gpio_desc *reset_gpio; /* XSHUTDOWN pin. */
+
        /* To serialize asynchronus callbacks */
        struct mutex mutex;
 
                                       ov5670->supplies);
 }
 
+static int ov5670_gpio_probe(struct ov5670 *ov5670)
+{
+       struct i2c_client *client = v4l2_get_subdevdata(&ov5670->sd);
+
+       ov5670->pwdn_gpio = devm_gpiod_get_optional(&client->dev, "powerdown",
+                                                   GPIOD_OUT_LOW);
+       if (IS_ERR(ov5670->pwdn_gpio))
+               return PTR_ERR(ov5670->pwdn_gpio);
+
+       ov5670->reset_gpio = devm_gpiod_get_optional(&client->dev, "reset",
+                                                    GPIOD_OUT_LOW);
+       if (IS_ERR(ov5670->reset_gpio))
+               return PTR_ERR(ov5670->reset_gpio);
+
+       return 0;
+}
+
 static int ov5670_probe(struct i2c_client *client)
 {
        struct ov5670 *ov5670;
                goto error_print;
        }
 
+       ret = ov5670_gpio_probe(ov5670);
+       if (ret) {
+               err_msg = "GPIO probe failed";
+               goto error_print;
+       }
+
        full_power = acpi_dev_state_d0(&client->dev);
        if (full_power) {
                /* Check module identity */