#include <mach/dma.h>
 #include <linux/platform_data/irda-pxaficp.h>
-#include <mach/regs-ost.h>
 #include <mach/regs-uart.h>
 
 #define FICP           __REG(0x40800000)  /* Start of FICP area */
 struct pxa_irda {
        int                     speed;
        int                     newspeed;
-       unsigned long           last_oscr;
+       unsigned long long      last_clk;
 
        unsigned char           *dma_rx_buff;
        unsigned char           *dma_tx_buff;
                        }
                        lsr = STLSR;
                }
-               si->last_oscr = readl_relaxed(OSCR);
+               si->last_clk = sched_clock();
                break;
 
        case 0x04: /* Received Data Available */
                    dev->stats.rx_bytes++;
                    async_unwrap_char(dev, &dev->stats, &si->rx_buff, STRBR);
                } while (STLSR & LSR_DR);
-               si->last_oscr = readl_relaxed(OSCR);
+               si->last_clk = sched_clock();
                break;
 
        case 0x02: /* Transmit FIFO Data Request */
                         /* We need to ensure that the transmitter has finished. */
                        while ((STLSR & LSR_TEMT) == 0)
                                cpu_relax();
-                       si->last_oscr = readl_relaxed(OSCR);
+                       si->last_clk = sched_clock();
 
                        /*
                        * Ok, we've finished transmitting.  Now enable
 
        while (ICSR1 & ICSR1_TBY)
                cpu_relax();
-       si->last_oscr = readl_relaxed(OSCR);
+       si->last_clk = sched_clock();
 
        /*
         * HACK: It looks like the TBY bit is dropped too soon.
 
        /* stop RX DMA */
        DCSR(si->rxdma) &= ~DCSR_RUN;
-       si->last_oscr = readl_relaxed(OSCR);
        icsr0 = ICSR0;
+       si->last_clk = sched_clock();
 
        if (icsr0 & (ICSR0_FRE | ICSR0_RAB)) {
                if (icsr0 & ICSR0_FRE) {
                skb_copy_from_linear_data(skb, si->dma_tx_buff, skb->len);
 
                if (mtt)
-                       while ((unsigned)(readl_relaxed(OSCR) - si->last_oscr)/4 < mtt)
+                       while ((sched_clock() - si->last_clk) * 1000 < mtt)
                                cpu_relax();
 
                /* stop RX DMA,  disable FICP */