{
        struct hclge_vport *vport = hclge_get_vport(handle);
        struct hclge_dev *hdev = vport->back;
-       struct phy_device *phydev = hdev->hw.mac.phydev;
+       u8 media_type = hdev->hw.mac.media_type;
 
-       *auto_neg = phydev ? hclge_get_autoneg(handle) : 0;
+       *auto_neg = (media_type == HNAE3_MEDIA_TYPE_COPPER) ?
+                   hclge_get_autoneg(handle) : 0;
 
        if (hdev->tm_info.fc_mode == HCLGE_FC_PFC) {
                *rx_en = 0;
        struct phy_device *phydev = hdev->hw.mac.phydev;
        u32 fc_autoneg;
 
-       if (phydev) {
+       if (phydev || hnae3_dev_phy_imp_supported(hdev)) {
                fc_autoneg = hclge_get_autoneg(handle);
                if (auto_neg != fc_autoneg) {
                        dev_info(&hdev->pdev->dev,
 
        hclge_record_user_pauseparam(hdev, rx_en, tx_en);
 
-       if (!auto_neg)
+       if (!auto_neg || hnae3_dev_phy_imp_supported(hdev))
                return hclge_cfg_pauseparam(hdev, rx_en, tx_en);
 
        if (phydev)