#include <linux/clk.h>
 #include <linux/delay.h>
 #include <linux/device.h>
-#include <linux/gpio.h>
+#include <linux/gpio/consumer.h>
 #include <linux/i2c.h>
 #include <linux/log2.h>
 #include <linux/module.h>
 #include <linux/of.h>
-#include <linux/of_gpio.h>
 #include <linux/of_graph.h>
 #include <linux/pm.h>
 #include <linux/regulator/consumer.h>
        struct aptina_pll pll;
        unsigned int clk_div;
        bool use_pll;
-       int reset;
+       struct gpio_desc *reset;
 
        struct v4l2_ctrl_handler ctrls;
        struct v4l2_ctrl *blc_auto;
 {
        int ret;
 
-       /* Ensure RESET_BAR is low */
-       if (gpio_is_valid(mt9p031->reset)) {
-               gpio_set_value(mt9p031->reset, 0);
+       /* Ensure RESET_BAR is active */
+       if (mt9p031->reset) {
+               gpiod_set_value(mt9p031->reset, 1);
                usleep_range(1000, 2000);
        }
 
        }
 
        /* Now RESET_BAR must be high */
-       if (gpio_is_valid(mt9p031->reset)) {
-               gpio_set_value(mt9p031->reset, 1);
+       if (mt9p031->reset) {
+               gpiod_set_value(mt9p031->reset, 0);
                usleep_range(1000, 2000);
        }
 
 
 static void mt9p031_power_off(struct mt9p031 *mt9p031)
 {
-       if (gpio_is_valid(mt9p031->reset)) {
-               gpio_set_value(mt9p031->reset, 0);
+       if (mt9p031->reset) {
+               gpiod_set_value(mt9p031->reset, 1);
                usleep_range(1000, 2000);
        }
 
        if (!pdata)
                goto done;
 
-       pdata->reset = of_get_named_gpio(client->dev.of_node, "reset-gpios", 0);
        of_property_read_u32(np, "input-clock-frequency", &pdata->ext_freq);
        of_property_read_u32(np, "pixel-clock-frequency", &pdata->target_freq);
 
        mt9p031->output_control = MT9P031_OUTPUT_CONTROL_DEF;
        mt9p031->mode2 = MT9P031_READ_MODE_2_ROW_BLC;
        mt9p031->model = did->driver_data;
-       mt9p031->reset = -1;
 
        mt9p031->regulators[0].supply = "vdd";
        mt9p031->regulators[1].supply = "vdd_io";
        mt9p031->format.field = V4L2_FIELD_NONE;
        mt9p031->format.colorspace = V4L2_COLORSPACE_SRGB;
 
-       if (gpio_is_valid(pdata->reset)) {
-               ret = devm_gpio_request_one(&client->dev, pdata->reset,
-                                           GPIOF_OUT_INIT_LOW, "mt9p031_rst");
-               if (ret < 0)
-                       goto done;
-
-               mt9p031->reset = pdata->reset;
-       }
+       mt9p031->reset = devm_gpiod_get_optional(&client->dev, "reset",
+                                                GPIOD_OUT_HIGH);
 
        ret = mt9p031_clk_setup(mt9p031);
        if (ret)