out_8(®s->wkup_dvo, chip->shadow_dvo);
 }
 
-static void
+static int
 mpc52xx_wkup_gpio_set(struct gpio_chip *gc, unsigned int gpio, int val)
 {
        unsigned long flags;
        spin_unlock_irqrestore(&gpio_lock, flags);
 
        pr_debug("%s: gpio: %d val: %d\n", __func__, gpio, val);
+
+       return 0;
 }
 
 static int mpc52xx_wkup_gpio_dir_in(struct gpio_chip *gc, unsigned int gpio)
        gc->direction_input  = mpc52xx_wkup_gpio_dir_in;
        gc->direction_output = mpc52xx_wkup_gpio_dir_out;
        gc->get              = mpc52xx_wkup_gpio_get;
-       gc->set              = mpc52xx_wkup_gpio_set;
+       gc->set_rv           = mpc52xx_wkup_gpio_set;
 
        ret = of_mm_gpiochip_add_data(ofdev->dev.of_node, &chip->mmchip, chip);
        if (ret)
        out_be32(®s->simple_dvo, chip->shadow_dvo);
 }
 
-static void
+static int
 mpc52xx_simple_gpio_set(struct gpio_chip *gc, unsigned int gpio, int val)
 {
        unsigned long flags;
        spin_unlock_irqrestore(&gpio_lock, flags);
 
        pr_debug("%s: gpio: %d val: %d\n", __func__, gpio, val);
+
+       return 0;
 }
 
 static int mpc52xx_simple_gpio_dir_in(struct gpio_chip *gc, unsigned int gpio)
        gc->direction_input  = mpc52xx_simple_gpio_dir_in;
        gc->direction_output = mpc52xx_simple_gpio_dir_out;
        gc->get              = mpc52xx_simple_gpio_get;
-       gc->set              = mpc52xx_simple_gpio_set;
+       gc->set_rv           = mpc52xx_simple_gpio_set;
 
        ret = of_mm_gpiochip_add_data(ofdev->dev.of_node, &chip->mmchip, chip);
        if (ret)