linux 2.6.16.38 w/ vs2.0.3-rc1
[linux-2.6.git] / drivers / serial / crisv10.c
index 8970014..be12623 100644 (file)
@@ -481,6 +481,8 @@ static char *serial_version = "$Revision: 1.25 $";
 #include "serial_compat.h"
 #endif
 
+#define _INLINE_ inline
+
 struct tty_driver *serial_driver;
 
 /* serial subtype definitions */
@@ -589,6 +591,8 @@ static void rs_throttle(struct tty_struct * tty);
 static void rs_wait_until_sent(struct tty_struct *tty, int timeout);
 static int rs_write(struct tty_struct * tty, int from_user,
                     const unsigned char *buf, int count);
+extern _INLINE_ int rs_raw_write(struct tty_struct * tty, int from_user,
+                            const unsigned char *buf, int count);
 #ifdef CONFIG_ETRAX_RS485
 static int e100_write_rs485(struct tty_struct * tty, int from_user,
                             const unsigned char *buf, int count);
@@ -1534,7 +1538,8 @@ e100_enable_rxdma_irq(struct e100_serial *info)
 
 /* the tx DMA uses only dma_descr interrupt */
 
-static void e100_disable_txdma_irq(struct e100_serial *info)
+static _INLINE_ void
+e100_disable_txdma_irq(struct e100_serial *info)
 {
 #ifdef SERIAL_DEBUG_INTR
        printk("txdma_irq(%d): 0\n",info->line);
@@ -1543,7 +1548,8 @@ static void e100_disable_txdma_irq(struct e100_serial *info)
        *R_IRQ_MASK2_CLR = info->irq;
 }
 
-static void e100_enable_txdma_irq(struct e100_serial *info)
+static _INLINE_ void
+e100_enable_txdma_irq(struct e100_serial *info)
 {
 #ifdef SERIAL_DEBUG_INTR
        printk("txdma_irq(%d): 1\n",info->line);
@@ -1552,7 +1558,8 @@ static void e100_enable_txdma_irq(struct e100_serial *info)
        *R_IRQ_MASK2_SET = info->irq;
 }
 
-static void e100_disable_txdma_channel(struct e100_serial *info)
+static _INLINE_ void
+e100_disable_txdma_channel(struct e100_serial *info)
 {
        unsigned long flags;
 
@@ -1592,7 +1599,8 @@ static void e100_disable_txdma_channel(struct e100_serial *info)
 }
 
 
-static void e100_enable_txdma_channel(struct e100_serial *info)
+static _INLINE_ void
+e100_enable_txdma_channel(struct e100_serial *info)
 {
        unsigned long flags;
 
@@ -1617,7 +1625,8 @@ static void e100_enable_txdma_channel(struct e100_serial *info)
        restore_flags(flags);
 }
 
-static void e100_disable_rxdma_channel(struct e100_serial *info)
+static _INLINE_ void
+e100_disable_rxdma_channel(struct e100_serial *info)
 {
        unsigned long flags;
 
@@ -1656,7 +1665,8 @@ static void e100_disable_rxdma_channel(struct e100_serial *info)
 }
 
 
-static void e100_enable_rxdma_channel(struct e100_serial *info)
+static _INLINE_ void
+e100_enable_rxdma_channel(struct e100_serial *info)
 {
        unsigned long flags;
 
@@ -1903,7 +1913,9 @@ rs_start(struct tty_struct *tty)
  * This routine is used by the interrupt handler to schedule
  * processing in the software interrupt portion of the driver.
  */
-static void rs_sched_event(struct e100_serial *info, int event)
+static _INLINE_ void
+rs_sched_event(struct e100_serial *info,
+                                   int event)
 {
        if (info->event & (1 << event))
                return;
@@ -2143,9 +2155,8 @@ add_char_and_flag(struct e100_serial *info, unsigned char data, unsigned char fl
        return 1;
 }
 
-static unsigned int handle_descr_data(struct e100_serial *info,
-                                     struct etrax_dma_descr *descr,
-                                     unsigned int recvl)
+extern _INLINE_ unsigned int
+handle_descr_data(struct e100_serial *info, struct etrax_dma_descr *descr, unsigned int recvl)
 {
        struct etrax_recv_buffer *buffer = phys_to_virt(descr->buf) - sizeof *buffer;
 
@@ -2171,7 +2182,8 @@ static unsigned int handle_descr_data(struct e100_serial *info,
        return recvl;
 }
 
-static unsigned int handle_all_descr_data(struct e100_serial *info)
+static _INLINE_ unsigned int
+handle_all_descr_data(struct e100_serial *info)
 {
        struct etrax_dma_descr *descr;
        unsigned int recvl;
@@ -2218,7 +2230,8 @@ static unsigned int handle_all_descr_data(struct e100_serial *info)
        return ret;
 }
 
-static void receive_chars_dma(struct e100_serial *info)
+static _INLINE_ void
+receive_chars_dma(struct e100_serial *info)
 {
        struct tty_struct *tty;
        unsigned char rstat;
@@ -2279,7 +2292,8 @@ static void receive_chars_dma(struct e100_serial *info)
        *info->icmdadr = IO_STATE(R_DMA_CH6_CMD, cmd, restart);
 }
 
-static int start_recv_dma(struct e100_serial *info)
+static _INLINE_ int
+start_recv_dma(struct e100_serial *info)
 {
        struct etrax_dma_descr *descr = info->rec_descr;
        struct etrax_recv_buffer *buffer;
@@ -2334,6 +2348,11 @@ start_receive(struct e100_serial *info)
 }
 
 
+static _INLINE_ void
+status_handle(struct e100_serial *info, unsigned short status)
+{
+}
+
 /* the bits in the MASK2 register are laid out like this:
    DMAI_EOP DMAI_DESCR DMAO_EOP DMAO_DESCR
    where I is the input channel and O is the output channel for the port.
@@ -2435,7 +2454,8 @@ rec_interrupt(int irq, void *dev_id, struct pt_regs * regs)
        return IRQ_RETVAL(handled);
 } /* rec_interrupt */
 
-static int force_eop_if_needed(struct e100_serial *info)
+static _INLINE_ int
+force_eop_if_needed(struct e100_serial *info)
 {
        /* We check data_avail bit to determine if data has
         * arrived since last time
@@ -2479,7 +2499,8 @@ static int force_eop_if_needed(struct e100_serial *info)
        return 1;
 }
 
-static void flush_to_flip_buffer(struct e100_serial *info)
+extern _INLINE_ void
+flush_to_flip_buffer(struct e100_serial *info)
 {
        struct tty_struct *tty;
        struct etrax_recv_buffer *buffer;
@@ -2590,7 +2611,8 @@ static void flush_to_flip_buffer(struct e100_serial *info)
        tty_flip_buffer_push(tty);
 }
 
-static void check_flush_timeout(struct e100_serial *info)
+static _INLINE_ void
+check_flush_timeout(struct e100_serial *info)
 {
        /* Flip what we've got (if we can) */
        flush_to_flip_buffer(info);
@@ -2719,7 +2741,7 @@ TODO: The break will be delayed until an F or V character is received.
 
 */
 
-static
+extern _INLINE_
 struct e100_serial * handle_ser_rx_interrupt_no_dma(struct e100_serial *info)
 {
        unsigned long data_read;
@@ -2853,7 +2875,8 @@ more_data:
        return info;
 }
 
-static struct e100_serial* handle_ser_rx_interrupt(struct e100_serial *info)
+extern _INLINE_
+struct e100_serial* handle_ser_rx_interrupt(struct e100_serial *info)
 {
        unsigned char rstat;
 
@@ -2972,7 +2995,7 @@ static struct e100_serial* handle_ser_rx_interrupt(struct e100_serial *info)
        return info;
 } /* handle_ser_rx_interrupt */
 
-static void handle_ser_tx_interrupt(struct e100_serial *info)
+extern _INLINE_ void handle_ser_tx_interrupt(struct e100_serial *info)
 {
        unsigned long flags;
 
@@ -3598,8 +3621,9 @@ rs_flush_chars(struct tty_struct *tty)
        restore_flags(flags);
 }
 
-static int rs_raw_write(struct tty_struct * tty, int from_user,
-                       const unsigned char *buf, int count)
+extern _INLINE_ int
+rs_raw_write(struct tty_struct * tty, int from_user,
+         const unsigned char *buf, int count)
 {
        int     c, ret = 0;
        struct e100_serial *info = (struct e100_serial *)tty->driver_data;
@@ -4686,7 +4710,7 @@ rs_open(struct tty_struct *tty, struct file * filp)
  * /proc fs routines....
  */
 
-static int line_info(char *buf, struct e100_serial *info)
+extern _INLINE_ int line_info(char *buf, struct e100_serial *info)
 {
        char    stat_buf[30];
        int     ret;