/* Allocate the data buffers
         * Snooping works fine with eth on all au1xxx
         */
-       aup->vaddr = (u32)dma_alloc_noncoherent(NULL, MAX_BUF_SIZE *
-                                               (NUM_TX_BUFFS + NUM_RX_BUFFS),
-                                               &aup->dma_addr, 0);
+       aup->vaddr = (u32)dma_alloc_attrs(NULL, MAX_BUF_SIZE *
+                                         (NUM_TX_BUFFS + NUM_RX_BUFFS),
+                                         &aup->dma_addr, 0,
+                                         DMA_ATTR_NON_CONSISTENT);
        if (!aup->vaddr) {
                dev_err(&pdev->dev, "failed to allocate data buffers\n");
                err = -ENOMEM;
 err_remap2:
        iounmap(aup->mac);
 err_remap1:
-       dma_free_noncoherent(NULL, MAX_BUF_SIZE * (NUM_TX_BUFFS + NUM_RX_BUFFS),
-                            (void *)aup->vaddr, aup->dma_addr);
+       dma_free_attrs(NULL, MAX_BUF_SIZE * (NUM_TX_BUFFS + NUM_RX_BUFFS),
+                       (void *)aup->vaddr, aup->dma_addr,
+                       DMA_ATTR_NON_CONSISTENT);
 err_vaddr:
        free_netdev(dev);
 err_alloc:
                if (aup->tx_db_inuse[i])
                        au1000_ReleaseDB(aup, aup->tx_db_inuse[i]);
 
-       dma_free_noncoherent(NULL, MAX_BUF_SIZE *
-                       (NUM_TX_BUFFS + NUM_RX_BUFFS),
-                       (void *)aup->vaddr, aup->dma_addr);
+       dma_free_attrs(NULL, MAX_BUF_SIZE * (NUM_TX_BUFFS + NUM_RX_BUFFS),
+                       (void *)aup->vaddr, aup->dma_addr,
+                       DMA_ATTR_NON_CONSISTENT);
 
        iounmap(aup->macdma);
        iounmap(aup->mac);