#include <linux/pm_runtime.h>
 #include <linux/regmap.h>
 #include <linux/regulator/consumer.h>
+#include <linux/reset.h>
 #include <linux/slab.h>
 #include <linux/soundwire/sdw.h>
 #include <linux/soundwire/sdw_registers.h>
        struct sdw_stream_runtime *sruntime;
        struct sdw_port_config port_config[WSA884X_MAX_SWR_PORTS];
        struct gpio_desc *sd_n;
+       struct reset_control *sd_reset;
        bool port_prepared[WSA884X_MAX_SWR_PORTS];
        bool port_enable[WSA884X_MAX_SWR_PORTS];
        unsigned int variant;
        },
 };
 
-static void wsa884x_gpio_powerdown(void *data)
+static void wsa884x_reset_powerdown(void *data)
 {
-       gpiod_direction_output(data, 1);
+       struct wsa884x_priv *wsa884x = data;
+
+       if (wsa884x->sd_reset)
+               reset_control_assert(wsa884x->sd_reset);
+       else
+               gpiod_direction_output(wsa884x->sd_n, 1);
+}
+
+static void wsa884x_reset_deassert(struct wsa884x_priv *wsa884x)
+{
+       if (wsa884x->sd_reset)
+               reset_control_deassert(wsa884x->sd_reset);
+       else
+               gpiod_direction_output(wsa884x->sd_n, 0);
 }
 
 static void wsa884x_regulator_disable(void *data)
        regulator_bulk_disable(WSA884X_SUPPLIES_NUM, data);
 }
 
+static int wsa884x_get_reset(struct device *dev, struct wsa884x_priv *wsa884x)
+{
+       wsa884x->sd_reset = devm_reset_control_get_optional_shared(dev, NULL);
+       if (IS_ERR(wsa884x->sd_reset))
+               return dev_err_probe(dev, PTR_ERR(wsa884x->sd_reset),
+                                    "Failed to get reset\n");
+       else if (wsa884x->sd_reset)
+               return 0;
+       /*
+        * else: NULL, so use the backwards compatible way for powerdown-gpios,
+        * which does not handle sharing GPIO properly.
+        */
+       wsa884x->sd_n = devm_gpiod_get_optional(dev, "powerdown",
+                                               GPIOD_OUT_HIGH);
+       if (IS_ERR(wsa884x->sd_n))
+               return dev_err_probe(dev, PTR_ERR(wsa884x->sd_n),
+                                    "Shutdown Control GPIO not found\n");
+
+       return 0;
+}
+
 static int wsa884x_probe(struct sdw_slave *pdev,
                         const struct sdw_device_id *id)
 {
        if (ret)
                return ret;
 
-       wsa884x->sd_n = devm_gpiod_get_optional(dev, "powerdown",
-                                               GPIOD_OUT_HIGH);
-       if (IS_ERR(wsa884x->sd_n))
-               return dev_err_probe(dev, PTR_ERR(wsa884x->sd_n),
-                                    "Shutdown Control GPIO not found\n");
+       ret = wsa884x_get_reset(dev, wsa884x);
+       if (ret)
+               return ret;
 
        dev_set_drvdata(dev, wsa884x);
        wsa884x->slave = pdev;
        pdev->prop.sink_dpn_prop = wsa884x_sink_dpn_prop;
        pdev->prop.scp_int1_mask = SDW_SCP_INT1_BUS_CLASH | SDW_SCP_INT1_PARITY;
 
-       /* Bring out of reset */
-       gpiod_direction_output(wsa884x->sd_n, 0);
-       ret = devm_add_action_or_reset(dev, wsa884x_gpio_powerdown, wsa884x->sd_n);
+       wsa884x_reset_deassert(wsa884x);
+       ret = devm_add_action_or_reset(dev, wsa884x_reset_powerdown, wsa884x);
        if (ret)
                return ret;