void bcmgenet_get_wol(struct net_device *dev, struct ethtool_wolinfo *wol)
 {
        struct bcmgenet_priv *priv = netdev_priv(dev);
-       u32 reg;
 
        wol->supported = WAKE_MAGIC | WAKE_MAGICSECURE;
        wol->wolopts = priv->wolopts;
        memset(wol->sopass, 0, sizeof(wol->sopass));
 
-       if (wol->wolopts & WAKE_MAGICSECURE) {
-               reg = bcmgenet_umac_readl(priv, UMAC_MPD_PW_MS);
-               put_unaligned_be16(reg, &wol->sopass[0]);
-               reg = bcmgenet_umac_readl(priv, UMAC_MPD_PW_LS);
-               put_unaligned_be32(reg, &wol->sopass[2]);
-       }
+       if (wol->wolopts & WAKE_MAGICSECURE)
+               memcpy(wol->sopass, priv->sopass, sizeof(priv->sopass));
 }
 
 /* ethtool function - set WOL (Wake on LAN) settings.
 {
        struct bcmgenet_priv *priv = netdev_priv(dev);
        struct device *kdev = &priv->pdev->dev;
-       u32 reg;
 
        if (!device_can_wakeup(kdev))
                return -ENOTSUPP;
        if (wol->wolopts & ~(WAKE_MAGIC | WAKE_MAGICSECURE))
                return -EINVAL;
 
-       reg = bcmgenet_umac_readl(priv, UMAC_MPD_CTRL);
-       if (wol->wolopts & WAKE_MAGICSECURE) {
-               bcmgenet_umac_writel(priv, get_unaligned_be16(&wol->sopass[0]),
-                                    UMAC_MPD_PW_MS);
-               bcmgenet_umac_writel(priv, get_unaligned_be32(&wol->sopass[2]),
-                                    UMAC_MPD_PW_LS);
-               reg |= MPD_PW_EN;
-       } else {
-               reg &= ~MPD_PW_EN;
-       }
-       bcmgenet_umac_writel(priv, reg, UMAC_MPD_CTRL);
+       if (wol->wolopts & WAKE_MAGICSECURE)
+               memcpy(priv->sopass, wol->sopass, sizeof(priv->sopass));
 
        /* Flag the device and relevant IRQ as wakeup capable */
        if (wol->wolopts) {
        return retries;
 }
 
+static void bcmgenet_set_mpd_password(struct bcmgenet_priv *priv)
+{
+       bcmgenet_umac_writel(priv, get_unaligned_be16(&priv->sopass[0]),
+                            UMAC_MPD_PW_MS);
+       bcmgenet_umac_writel(priv, get_unaligned_be32(&priv->sopass[2]),
+                            UMAC_MPD_PW_LS);
+}
+
 int bcmgenet_wol_power_down_cfg(struct bcmgenet_priv *priv,
                                enum bcmgenet_power_mode mode)
 {
 
        reg = bcmgenet_umac_readl(priv, UMAC_MPD_CTRL);
        reg |= MPD_EN;
+       if (priv->wolopts & WAKE_MAGICSECURE) {
+               bcmgenet_set_mpd_password(priv);
+               reg |= MPD_PW_EN;
+       }
        bcmgenet_umac_writel(priv, reg, UMAC_MPD_CTRL);
 
        /* Do not leave UniMAC in MPD mode only */
        retries = bcmgenet_poll_wol_status(priv);
        if (retries < 0) {
                reg = bcmgenet_umac_readl(priv, UMAC_MPD_CTRL);
-               reg &= ~MPD_EN;
+               reg &= ~(MPD_EN | MPD_PW_EN);
                bcmgenet_umac_writel(priv, reg, UMAC_MPD_CTRL);
                return retries;
        }
        reg = bcmgenet_umac_readl(priv, UMAC_MPD_CTRL);
        if (!(reg & MPD_EN))
                return; /* already powered up so skip the rest */
-       reg &= ~MPD_EN;
+       reg &= ~(MPD_EN | MPD_PW_EN);
        bcmgenet_umac_writel(priv, reg, UMAC_MPD_CTRL);
 
        /* Disable CRC Forward */