else
                        bd_status = R_E_S | R_I_S | R_W_S;
 
-               iowrite16be(bd_status, &priv->rx_bd_base[i].status);
-               iowrite32be(priv->dma_rx_addr + i * MAX_RX_BUF_LENGTH,
-                           &priv->rx_bd_base[i].buf);
+               priv->rx_bd_base[i].status = cpu_to_be16(bd_status);
+               priv->rx_bd_base[i].buf = cpu_to_be32(priv->dma_rx_addr + i * MAX_RX_BUF_LENGTH);
        }
 
        for (i = 0; i < TX_BD_RING_LEN; i++) {
                else
                        bd_status =  T_I_S | T_TC_S | T_W_S;
 
-               iowrite16be(bd_status, &priv->tx_bd_base[i].status);
-               iowrite32be(priv->dma_tx_addr + i * MAX_RX_BUF_LENGTH,
-                           &priv->tx_bd_base[i].buf);
+               priv->tx_bd_base[i].status = cpu_to_be16(bd_status);
+               priv->tx_bd_base[i].buf = cpu_to_be32(priv->dma_tx_addr + i * MAX_RX_BUF_LENGTH);
        }
+       dma_wmb();
 
        return 0;
 
 {
        hdlc_device *hdlc = dev_to_hdlc(dev);
        struct ucc_hdlc_private *priv = (struct ucc_hdlc_private *)hdlc->priv;
-       struct qe_bd __iomem *bd;
+       struct qe_bd *bd;
        u16 bd_status;
        unsigned long flags;
-       u16 *proto_head;
+       __be16 *proto_head;
 
        switch (dev->type) {
        case ARPHRD_RAWHDLC:
 
                skb_push(skb, HDLC_HEAD_LEN);
 
-               proto_head = (u16 *)skb->data;
+               proto_head = (__be16 *)skb->data;
                *proto_head = htons(DEFAULT_HDLC_HEAD);
 
                dev->stats.tx_bytes += skb->len;
                break;
 
        case ARPHRD_PPP:
-               proto_head = (u16 *)skb->data;
+               proto_head = (__be16 *)skb->data;
                if (*proto_head != htons(DEFAULT_PPP_HEAD)) {
                        dev->stats.tx_dropped++;
                        dev_kfree_skb(skb);
        netdev_sent_queue(dev, skb->len);
        spin_lock_irqsave(&priv->lock, flags);
 
+       dma_rmb();
        /* Start from the next BD that should be filled */
        bd = priv->curtx_bd;
-       bd_status = ioread16be(&bd->status);
+       bd_status = be16_to_cpu(bd->status);
        /* Save the skb pointer so we can free it later */
        priv->tx_skbuff[priv->skb_curtx] = skb;
 
        /* set bd status and length */
        bd_status = (bd_status & T_W_S) | T_R_S | T_I_S | T_L_S | T_TC_S;
 
-       iowrite16be(skb->len, &bd->length);
-       iowrite16be(bd_status, &bd->status);
+       bd->length = cpu_to_be16(skb->len);
+       bd->status = cpu_to_be16(bd_status);
 
        /* Move to next BD in the ring */
        if (!(bd_status & T_W_S))
        u16 bd_status;
        int tx_restart = 0;
 
+       dma_rmb();
        bd = priv->dirty_tx;
-       bd_status = ioread16be(&bd->status);
+       bd_status = be16_to_cpu(bd->status);
 
        /* Normal processing. */
        while ((bd_status & T_R_S) == 0) {
                        bd += 1;
                else
                        bd = priv->tx_bd_base;
-               bd_status = ioread16be(&bd->status);
+               bd_status = be16_to_cpu(bd->status);
        }
        priv->dirty_tx = bd;
 
        u16 length, howmany = 0;
        u8 *bdbuffer;
 
+       dma_rmb();
        bd = priv->currx_bd;
-       bd_status = ioread16be(&bd->status);
+       bd_status = be16_to_cpu(bd->status);
 
        /* while there are received buffers and BD is full (~R_E) */
        while (!((bd_status & (R_E_S)) || (--rx_work_limit < 0))) {
                }
                bdbuffer = priv->rx_buffer +
                        (priv->currx_bdnum * MAX_RX_BUF_LENGTH);
-               length = ioread16be(&bd->length);
+               length = be16_to_cpu(bd->length);
 
                switch (dev->type) {
                case ARPHRD_RAWHDLC:
                netif_receive_skb(skb);
 
 recycle:
-               iowrite16be((bd_status & R_W_S) | R_E_S | R_I_S, &bd->status);
+               bd->status = cpu_to_be16((bd_status & R_W_S) | R_E_S | R_I_S);
 
                /* update to point at the next bd */
                if (bd_status & R_W_S) {
                        bd += 1;
                }
 
-               bd_status = ioread16be(&bd->status);
+               bd_status = be16_to_cpu(bd->status);
        }
+       dma_rmb();
 
        priv->currx_bd = bd;
        return howmany;
 
                /* Enable the TDM port */
                if (priv->tsa)
-                       utdm->si_regs->siglmr1_h |= (0x1 << utdm->tdm_port);
+                       qe_setbits_8(&utdm->si_regs->siglmr1_h, 0x1 << utdm->tdm_port);
 
                priv->hdlc_busy = 1;
                netif_device_attach(priv->ndev);
                     (u8)QE_CR_PROTOCOL_UNSPECIFIED, 0);
 
        if (priv->tsa)
-               utdm->si_regs->siglmr1_h &= ~(0x1 << utdm->tdm_port);
+               qe_clrbits_8(&utdm->si_regs->siglmr1_h, 0x1 << utdm->tdm_port);
 
        ucc_fast_disable(priv->uccf, COMM_DIR_RX | COMM_DIR_TX);
 
 #ifdef CONFIG_PM
 static void store_clk_config(struct ucc_hdlc_private *priv)
 {
-       struct qe_mux *qe_mux_reg = &qe_immr->qmx;
+       struct qe_mux __iomem *qe_mux_reg = &qe_immr->qmx;
 
        /* store si clk */
        priv->cmxsi1cr_h = ioread32be(&qe_mux_reg->cmxsi1cr_h);
 
 static void resume_clk_config(struct ucc_hdlc_private *priv)
 {
-       struct qe_mux *qe_mux_reg = &qe_immr->qmx;
+       struct qe_mux __iomem *qe_mux_reg = &qe_immr->qmx;
 
        memcpy_toio(qe_mux_reg->cmxucr, priv->cmxucr, 4 * sizeof(u32));
 
                else
                        bd_status = R_E_S | R_I_S | R_W_S;
 
-               iowrite16be(bd_status, &priv->rx_bd_base[i].status);
-               iowrite32be(priv->dma_rx_addr + i * MAX_RX_BUF_LENGTH,
-                           &priv->rx_bd_base[i].buf);
+               priv->rx_bd_base[i].status = cpu_to_be16(bd_status);
+               priv->rx_bd_base[i].buf = cpu_to_be32(priv->dma_rx_addr + i * MAX_RX_BUF_LENGTH);
        }
 
        for (i = 0; i < TX_BD_RING_LEN; i++) {
                else
                        bd_status =  T_I_S | T_TC_S | T_W_S;
 
-               iowrite16be(bd_status, &priv->tx_bd_base[i].status);
-               iowrite32be(priv->dma_tx_addr + i * MAX_RX_BUF_LENGTH,
-                           &priv->tx_bd_base[i].buf);
+               priv->tx_bd_base[i].status = cpu_to_be16(bd_status);
+               priv->tx_bd_base[i].buf = cpu_to_be32(priv->dma_tx_addr + i * MAX_RX_BUF_LENGTH);
        }
+       dma_wmb();
 
        /* if hdlc is busy enable TX and RX */
        if (priv->hdlc_busy == 1) {
 
                /* Enable the TDM port */
                if (priv->tsa)
-                       utdm->si_regs->siglmr1_h |= (0x1 << utdm->tdm_port);
+                       qe_setbits_8(&utdm->si_regs->siglmr1_h, 0x1 << utdm->tdm_port);
        }
 
        napi_enable(&priv->napi);