}
 }
 
+static void enh_desc_display_ring(void *head, unsigned int size, bool rx)
+{
+       struct dma_extended_desc *ep = (struct dma_extended_desc *)head;
+       int i;
+
+       pr_info("Extended %s descriptor ring:\n", rx ? "RX" : "TX");
+
+       for (i = 0; i < size; i++) {
+               u64 x;
+
+               x = *(u64 *)ep;
+               pr_info("%d [0x%x]: 0x%x 0x%x 0x%x 0x%x\n",
+                       i, (unsigned int)virt_to_phys(ep),
+                       (unsigned int)x, (unsigned int)(x >> 32),
+                       ep->basic.des2, ep->basic.des3);
+               ep++;
+       }
+       pr_info("\n");
+}
+
 const struct stmmac_desc_ops enh_desc_ops = {
        .tx_status = enh_desc_get_tx_status,
        .rx_status = enh_desc_get_rx_status,
        .get_tx_timestamp_status = enh_desc_get_tx_timestamp_status,
        .get_timestamp = enh_desc_get_timestamp,
        .get_rx_timestamp_status = enh_desc_get_rx_timestamp_status,
+       .display_ring = enh_desc_display_ring,
 };
 
                return 1;
 }
 
+static void ndesc_display_ring(void *head, unsigned int size, bool rx)
+{
+       struct dma_desc *p = (struct dma_desc *)head;
+       int i;
+
+       pr_info("%s descriptor ring:\n", rx ? "RX" : "TX");
+
+       for (i = 0; i < size; i++) {
+               u64 x;
+
+               x = *(u64 *)p;
+               pr_info("%d [0x%x]: 0x%x 0x%x 0x%x 0x%x",
+                       i, (unsigned int)virt_to_phys(p),
+                       (unsigned int)x, (unsigned int)(x >> 32),
+                       p->des2, p->des3);
+               p++;
+       }
+       pr_info("\n");
+}
+
 const struct stmmac_desc_ops ndesc_ops = {
        .tx_status = ndesc_get_tx_status,
        .rx_status = ndesc_get_rx_status,
        .get_tx_timestamp_status = ndesc_get_tx_timestamp_status,
        .get_timestamp = ndesc_get_timestamp,
        .get_rx_timestamp_status = ndesc_get_rx_timestamp_status,
+       .display_ring = ndesc_display_ring,
 };
 
        return 0;
 }
 
-/**
- * stmmac_display_ring - display ring
- * @head: pointer to the head of the ring passed.
- * @size: size of the ring.
- * @extend_desc: to verify if extended descriptors are used.
- * Description: display the control/status and buffer descriptors.
- */
-static void stmmac_display_ring(void *head, int size, int extend_desc)
-{
-       int i;
-       struct dma_extended_desc *ep = (struct dma_extended_desc *)head;
-       struct dma_desc *p = (struct dma_desc *)head;
-
-       for (i = 0; i < size; i++) {
-               u64 x;
-               if (extend_desc) {
-                       x = *(u64 *) ep;
-                       pr_info("%d [0x%x]: 0x%x 0x%x 0x%x 0x%x\n",
-                               i, (unsigned int)virt_to_phys(ep),
-                               (unsigned int)x, (unsigned int)(x >> 32),
-                               ep->basic.des2, ep->basic.des3);
-                       ep++;
-               } else {
-                       x = *(u64 *) p;
-                       pr_info("%d [0x%x]: 0x%x 0x%x 0x%x 0x%x",
-                               i, (unsigned int)virt_to_phys(p),
-                               (unsigned int)x, (unsigned int)(x >> 32),
-                               p->des2, p->des3);
-                       p++;
-               }
-               pr_info("\n");
-       }
-}
-
 static void stmmac_display_rings(struct stmmac_priv *priv)
 {
+       void *head_rx, *head_tx;
+
        if (priv->extend_desc) {
-               pr_info("Extended RX descriptor ring:\n");
-               stmmac_display_ring((void *)priv->dma_erx, DMA_RX_SIZE, 1);
-               pr_info("Extended TX descriptor ring:\n");
-               stmmac_display_ring((void *)priv->dma_etx, DMA_TX_SIZE, 1);
+               head_rx = (void *)priv->dma_erx;
+               head_tx = (void *)priv->dma_etx;
        } else {
-               pr_info("RX descriptor ring:\n");
-               stmmac_display_ring((void *)priv->dma_rx, DMA_RX_SIZE, 0);
-               pr_info("TX descriptor ring:\n");
-               stmmac_display_ring((void *)priv->dma_tx, DMA_TX_SIZE, 0);
+               head_rx = (void *)priv->dma_rx;
+               head_tx = (void *)priv->dma_tx;
        }
+
+       /* Display Rx ring */
+       priv->hw->desc->display_ring(head_rx, DMA_RX_SIZE, true);
+       /* Display Tx ring */
+       priv->hw->desc->display_ring(head_tx, DMA_TX_SIZE, false);
 }
 
 static int stmmac_set_bfsize(int mtu, int bufsize)
        priv->cur_tx = entry;
 
        if (netif_msg_pktdata(priv)) {
+               void *tx_head;
+
                pr_debug("%s: curr=%d dirty=%d f=%d, e=%d, first=%p, nfrags=%d",
                         __func__, priv->cur_tx, priv->dirty_tx, first_entry,
                         entry, first, nfrags);
 
                if (priv->extend_desc)
-                       stmmac_display_ring((void *)priv->dma_etx,
-                                           DMA_TX_SIZE, 1);
+                       tx_head = (void *)priv->dma_etx;
                else
-                       stmmac_display_ring((void *)priv->dma_tx,
-                                           DMA_TX_SIZE, 0);
+                       tx_head = (void *)priv->dma_tx;
+
+               priv->hw->desc->display_ring(tx_head, DMA_TX_SIZE, false);
 
                pr_debug(">>> frame to be transmitted: ");
                print_pkt(skb->data, skb->len);
        int coe = priv->hw->rx_csum;
 
        if (netif_msg_rx_status(priv)) {
+               void *rx_head;
+
                pr_debug("%s: descriptor ring:\n", __func__);
                if (priv->extend_desc)
-                       stmmac_display_ring((void *)priv->dma_erx,
-                                           DMA_RX_SIZE, 1);
+                       rx_head = (void *)priv->dma_erx;
                else
-                       stmmac_display_ring((void *)priv->dma_rx,
-                                           DMA_RX_SIZE, 0);
+                       rx_head = (void *)priv->dma_rx;
+
+               priv->hw->desc->display_ring(rx_head, DMA_RX_SIZE, true);
        }
        while (count < limit) {
                int status;