{
        struct arc_emac_priv *priv = netdev_priv(ndev);
        struct net_device_stats *stats = &ndev->stats;
+       struct device *dev = ndev->dev.parent;
        unsigned int i;
 
        for (i = 0; i < TX_BD_NUM; i++) {
                        stats->tx_bytes += skb->len;
                }
 
-               dma_unmap_single(&ndev->dev, dma_unmap_addr(tx_buff, addr),
+               dma_unmap_single(dev, dma_unmap_addr(tx_buff, addr),
                                 dma_unmap_len(tx_buff, len), DMA_TO_DEVICE);
 
                /* return the sk_buff to system */
 static int arc_emac_rx(struct net_device *ndev, int budget)
 {
        struct arc_emac_priv *priv = netdev_priv(ndev);
+       struct device *dev = ndev->dev.parent;
        unsigned int work_done;
 
        for (work_done = 0; work_done < budget; work_done++) {
                        continue;
                }
 
-               addr = dma_map_single(&ndev->dev, (void *)skb->data,
+               addr = dma_map_single(dev, (void *)skb->data,
                                      EMAC_BUFFER_SIZE, DMA_FROM_DEVICE);
-               if (dma_mapping_error(&ndev->dev, addr)) {
+               if (dma_mapping_error(dev, addr)) {
                        if (net_ratelimit())
                                netdev_err(ndev, "cannot map dma buffer\n");
                        dev_kfree_skb(skb);
                }
 
                /* unmap previosly mapped skb */
-               dma_unmap_single(&ndev->dev, dma_unmap_addr(rx_buff, addr),
+               dma_unmap_single(dev, dma_unmap_addr(rx_buff, addr),
                                 dma_unmap_len(rx_buff, len), DMA_FROM_DEVICE);
 
                pktlen = info & LEN_MASK;
 {
        struct arc_emac_priv *priv = netdev_priv(ndev);
        struct phy_device *phy_dev = ndev->phydev;
+       struct device *dev = ndev->dev.parent;
        int i;
 
        phy_dev->autoneg = AUTONEG_ENABLE;
                if (unlikely(!rx_buff->skb))
                        return -ENOMEM;
 
-               addr = dma_map_single(&ndev->dev, (void *)rx_buff->skb->data,
+               addr = dma_map_single(dev, (void *)rx_buff->skb->data,
                                      EMAC_BUFFER_SIZE, DMA_FROM_DEVICE);
-               if (dma_mapping_error(&ndev->dev, addr)) {
+               if (dma_mapping_error(dev, addr)) {
                        netdev_err(ndev, "cannot dma map\n");
                        dev_kfree_skb(rx_buff->skb);
                        return -ENOMEM;
 static void arc_free_tx_queue(struct net_device *ndev)
 {
        struct arc_emac_priv *priv = netdev_priv(ndev);
+       struct device *dev = ndev->dev.parent;
        unsigned int i;
 
        for (i = 0; i < TX_BD_NUM; i++) {
                struct buffer_state *tx_buff = &priv->tx_buff[i];
 
                if (tx_buff->skb) {
-                       dma_unmap_single(&ndev->dev,
+                       dma_unmap_single(dev,
                                         dma_unmap_addr(tx_buff, addr),
                                         dma_unmap_len(tx_buff, len),
                                         DMA_TO_DEVICE);
 static void arc_free_rx_queue(struct net_device *ndev)
 {
        struct arc_emac_priv *priv = netdev_priv(ndev);
+       struct device *dev = ndev->dev.parent;
        unsigned int i;
 
        for (i = 0; i < RX_BD_NUM; i++) {
                struct buffer_state *rx_buff = &priv->rx_buff[i];
 
                if (rx_buff->skb) {
-                       dma_unmap_single(&ndev->dev,
+                       dma_unmap_single(dev,
                                         dma_unmap_addr(rx_buff, addr),
                                         dma_unmap_len(rx_buff, len),
                                         DMA_FROM_DEVICE);
        unsigned int len, *txbd_curr = &priv->txbd_curr;
        struct net_device_stats *stats = &ndev->stats;
        __le32 *info = &priv->txbd[*txbd_curr].info;
+       struct device *dev = ndev->dev.parent;
        dma_addr_t addr;
 
        if (skb_padto(skb, ETH_ZLEN))
                return NETDEV_TX_BUSY;
        }
 
-       addr = dma_map_single(&ndev->dev, (void *)skb->data, len,
-                             DMA_TO_DEVICE);
+       addr = dma_map_single(dev, (void *)skb->data, len, DMA_TO_DEVICE);
 
-       if (unlikely(dma_mapping_error(&ndev->dev, addr))) {
+       if (unlikely(dma_mapping_error(dev, addr))) {
                stats->tx_dropped++;
                stats->tx_errors++;
                dev_kfree_skb_any(skb);