#define STMMAC_MAC_FPE_CTRL_STS_SVER   BIT(1)
 #define STMMAC_MAC_FPE_CTRL_STS_EFPE   BIT(0)
 
+bool stmmac_fpe_supported(struct stmmac_priv *priv)
+{
+       return priv->dma_cap.fpesel;
+}
+
 void dwmac5_fpe_configure(void __iomem *ioaddr, struct stmmac_fpe_cfg *cfg,
                          u32 num_txq, u32 num_rxq,
                          bool tx_enable, bool pmac_enable)
 
 
 void stmmac_fpe_link_state_handle(struct stmmac_priv *priv, bool is_up);
 void stmmac_fpe_event_status(struct stmmac_priv *priv, int status);
+bool stmmac_fpe_supported(struct stmmac_priv *priv);
 void stmmac_fpe_init(struct stmmac_priv *priv);
 void stmmac_fpe_apply(struct stmmac_priv *priv);
 
 
        priv->eee_enabled = stmmac_eee_init(priv);
        stmmac_set_eee_pls(priv, priv->hw, false);
 
-       if (priv->dma_cap.fpesel)
+       if (stmmac_fpe_supported(priv))
                stmmac_fpe_link_state_handle(priv, false);
 }
 
                stmmac_set_eee_pls(priv, priv->hw, true);
        }
 
-       if (priv->dma_cap.fpesel)
+       if (stmmac_fpe_supported(priv))
                stmmac_fpe_link_state_handle(priv, true);
 
        if (priv->plat->flags & STMMAC_FLAG_HWTSTAMP_CORRECT_LATENCY)
 
        stmmac_release_ptp(priv);
 
-       if (priv->dma_cap.fpesel)
+       if (stmmac_fpe_supported(priv))
                timer_shutdown_sync(&priv->fpe_cfg.verify_timer);
 
        pm_runtime_put(priv->device);
                stmmac_est_irq_status(priv, priv, priv->dev,
                                      &priv->xstats, tx_cnt);
 
-       if (priv->dma_cap.fpesel) {
+       if (stmmac_fpe_supported(priv)) {
                int status = stmmac_fpe_irq_status(priv, priv->ioaddr,
                                                   priv->dev);
 
        }
        rtnl_unlock();
 
-       if (priv->dma_cap.fpesel)
+       if (stmmac_fpe_supported(priv))
                timer_shutdown_sync(&priv->fpe_cfg.verify_timer);
 
        priv->speed = SPEED_UNKNOWN;