NLA_POLICY_NESTED(ethnl_header_policy_stats),
 };
 
-static int linkstate_get_sqi(struct net_device *dev)
+static int linkstate_get_sqi(struct phy_device *phydev)
 {
-       struct phy_device *phydev = dev->phydev;
        int ret;
 
        if (!phydev)
        return ret;
 }
 
-static int linkstate_get_sqi_max(struct net_device *dev)
+static int linkstate_get_sqi_max(struct phy_device *phydev)
 {
-       struct phy_device *phydev = dev->phydev;
        int ret;
 
        if (!phydev)
 {
        struct linkstate_reply_data *data = LINKSTATE_REPDATA(reply_base);
        struct net_device *dev = reply_base->dev;
+       struct nlattr **tb = info->attrs;
+       struct phy_device *phydev;
        int ret;
 
+       phydev = ethnl_req_get_phydev(req_base, tb[ETHTOOL_A_LINKSTATE_HEADER],
+                                     info->extack);
+       if (IS_ERR(phydev)) {
+               ret = PTR_ERR(phydev);
+               goto out;
+       }
+
        ret = ethnl_ops_begin(dev);
        if (ret < 0)
                return ret;
        data->link = __ethtool_get_link(dev);
 
-       ret = linkstate_get_sqi(dev);
+       ret = linkstate_get_sqi(phydev);
        if (linkstate_sqi_critical_error(ret))
                goto out;
        data->sqi = ret;
 
-       ret = linkstate_get_sqi_max(dev);
+       ret = linkstate_get_sqi_max(phydev);
        if (linkstate_sqi_critical_error(ret))
                goto out;
        data->sqi_max = ret;
                           sizeof(data->link_stats) / 8);
 
        if (req_base->flags & ETHTOOL_FLAG_STATS) {
-               if (dev->phydev)
+               if (phydev)
                        data->link_stats.link_down_events =
-                               READ_ONCE(dev->phydev->link_down_events);
+                               READ_ONCE(phydev->link_down_events);
 
                if (dev->ethtool_ops->get_link_ext_stats)
                        dev->ethtool_ops->get_link_ext_stats(dev,