diff options
| author | kaloz <kaloz@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2008-04-27 16:56:19 +0000 | 
|---|---|---|
| committer | kaloz <kaloz@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2008-04-27 16:56:19 +0000 | 
| commit | c886d2690dae0258d64fef02d8a24c901f7c2d6b (patch) | |
| tree | dbcd5d214918a932007299fa02556ce313a194be /target/linux/pxa/patches-2.6.21/024-bugfix-serial-register-status.patch | |
| parent | 1984be21949bc400d17272b33d7482f0902eec76 (diff) | |
incomplete Gumstix support
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@10955 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux/pxa/patches-2.6.21/024-bugfix-serial-register-status.patch')
| -rw-r--r-- | target/linux/pxa/patches-2.6.21/024-bugfix-serial-register-status.patch | 69 | 
1 files changed, 69 insertions, 0 deletions
| diff --git a/target/linux/pxa/patches-2.6.21/024-bugfix-serial-register-status.patch b/target/linux/pxa/patches-2.6.21/024-bugfix-serial-register-status.patch new file mode 100644 index 000000000..e25436b8e --- /dev/null +++ b/target/linux/pxa/patches-2.6.21/024-bugfix-serial-register-status.patch @@ -0,0 +1,69 @@ +Index: linux-2.6.21gum/drivers/serial/pxa.c +=================================================================== +--- linux-2.6.21gum.orig/drivers/serial/pxa.c ++++ linux-2.6.21gum/drivers/serial/pxa.c +@@ -57,6 +57,8 @@ struct uart_pxa_port { + 	unsigned int            lsr_break_flag; + 	unsigned int		cken; + 	char			*name; ++	unsigned int		msr; ++	unsigned int		lsr; + }; +  + static inline unsigned int serial_in(struct uart_pxa_port *up, int offset) +@@ -159,6 +161,7 @@ static inline void receive_chars(struct  +  + 	ignore_char: + 		*status = serial_in(up, UART_LSR); ++		up->lsr = *status; + 	} while ((*status & UART_LSR_DR) && (max_count-- > 0)); + 	tty_flip_buffer_push(tty); + } +@@ -211,7 +214,7 @@ static inline void check_modem_status(st + 	int status; +  + 	status = serial_in(up, UART_MSR); +- ++	up->msr = status; + 	if ((status & UART_MSR_ANY_DELTA) == 0) + 		return; +  +@@ -242,6 +245,7 @@ static inline irqreturn_t serial_pxa_irq + 		//printk(KERN_WARNING "serial_pxa_irq: odd -- interrupt triggered, but no interrupt in IIR: %08x\n",iir); + 	} + 	lsr = serial_in(up, UART_LSR); ++	up->lsr = lsr; + 	if (lsr & UART_LSR_DR) + 		receive_chars(up, &lsr); + 	check_modem_status(up); +@@ -258,7 +262,7 @@ static unsigned int serial_pxa_tx_empty( + 	unsigned int ret; +  + 	spin_lock_irqsave(&up->port.lock, flags); +-	ret = serial_in(up, UART_LSR) & UART_LSR_TEMT ? TIOCSER_TEMT : 0; ++	ret = up->lsr & UART_LSR_TEMT ? TIOCSER_TEMT : 0; + 	spin_unlock_irqrestore(&up->port.lock, flags); +  + 	return ret; +@@ -270,7 +274,7 @@ static unsigned int serial_pxa_get_mctrl + 	unsigned char status; + 	unsigned int ret; +  +-	status = serial_in(up, UART_MSR); ++	status = up->msr; +  + 	ret = 0; + 	if (status & UART_MSR_DCD) +@@ -400,10 +404,10 @@ static int serial_pxa_startup(struct uar + 	/* + 	 * And clear the interrupt registers again for luck. + 	 */ +-	(void) serial_in(up, UART_LSR); ++	up->lsr = serial_in(up, UART_LSR); + 	(void) serial_in(up, UART_RX); + 	(void) serial_in(up, UART_IIR); +-	(void) serial_in(up, UART_MSR); ++	up->msr = serial_in(up, UART_MSR); +  + 	return 0; + } | 
