Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
2d202ddc
Commit
2d202ddc
authored
20 years ago
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge
bk://bk.arm.linux.org.uk/linux-2.6-serial
into ppc970.osdl.org:/home/torvalds/v2.6/linux
parents
2e3a2627
4b355b37
Changes
14
Hide whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
199 additions
and
246 deletions
+199
-246
drivers/serial/21285.c
drivers/serial/21285.c
+15
-18
drivers/serial/8250.c
drivers/serial/8250.c
+23
-24
drivers/serial/8250_pci.c
drivers/serial/8250_pci.c
+3
-3
drivers/serial/amba-pl010.c
drivers/serial/amba-pl010.c
+22
-26
drivers/serial/amba-pl011.c
drivers/serial/amba-pl011.c
+22
-27
drivers/serial/clps711x.c
drivers/serial/clps711x.c
+11
-17
drivers/serial/dz.c
drivers/serial/dz.c
+11
-16
drivers/serial/imx.c
drivers/serial/imx.c
+10
-11
drivers/serial/pxa.c
drivers/serial/pxa.c
+19
-28
drivers/serial/s3c2410.c
drivers/serial/s3c2410.c
+14
-18
drivers/serial/sa1100.c
drivers/serial/sa1100.c
+11
-16
drivers/serial/serial_lh7a40x.c
drivers/serial/serial_lh7a40x.c
+22
-26
drivers/serial/uart00.c
drivers/serial/uart00.c
+12
-15
include/linux/serial_core.h
include/linux/serial_core.h
+4
-1
No files found.
drivers/serial/21285.c
View file @
2d202ddc
...
...
@@ -13,12 +13,14 @@
#include <linux/ioport.h>
#include <linux/init.h>
#include <linux/console.h>
#include <linux/device.h>
#include <linux/tty_flip.h>
#include <linux/serial_core.h>
#include <linux/serial.h>
#include <linux/device.h>
#include <asm/io.h>
#include <asm/irq.h>
#include <asm/mach-types.h>
#include <asm/hardware/dec21285.h>
#include <asm/hardware.h>
...
...
@@ -90,22 +92,21 @@ static irqreturn_t serial21285_rx_chars(int irq, void *dev_id, struct pt_regs *r
{
struct
uart_port
*
port
=
dev_id
;
struct
tty_struct
*
tty
=
port
->
info
->
tty
;
unsigned
int
status
,
ch
,
rxs
,
max_count
=
256
;
unsigned
int
status
,
ch
,
flag
,
rxs
,
max_count
=
256
;
status
=
*
CSR_UARTFLG
;
while
(
!
(
status
&
0x10
)
&&
max_count
--
)
{
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
{
tty
->
flip
.
work
.
func
((
void
*
)
tty
);
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
{
printk
(
KERN_WARNING
"TTY_DONT_FLIP set
\n
"
);
goto
out
;
}
if
(
tty
->
low_latency
)
tty_flip_buffer_push
(
tty
);
/*
* If this failed then we will throw away the
* bytes but must do so to clear interrupts
*/
}
ch
=
*
CSR_UARTDR
;
*
tty
->
flip
.
char_buf_ptr
=
ch
;
*
tty
->
flip
.
flag_buf_ptr
=
TTY_NORMAL
;
flag
=
TTY_NORMAL
;
port
->
icount
.
rx
++
;
rxs
=
*
CSR_RXSTAT
|
RXSTAT_DUMMY_READ
;
...
...
@@ -120,15 +121,13 @@ static irqreturn_t serial21285_rx_chars(int irq, void *dev_id, struct pt_regs *r
rxs
&=
port
->
read_status_mask
;
if
(
rxs
&
RXSTAT_PARITY
)
*
tty
->
flip
.
flag_buf_ptr
=
TTY_PARITY
;
flag
=
TTY_PARITY
;
else
if
(
rxs
&
RXSTAT_FRAME
)
*
tty
->
flip
.
flag_buf_ptr
=
TTY_FRAME
;
flag
=
TTY_FRAME
;
}
if
((
rxs
&
port
->
ignore_status_mask
)
==
0
)
{
tty
->
flip
.
flag_buf_ptr
++
;
tty
->
flip
.
char_buf_ptr
++
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
ch
,
flag
);
}
if
((
rxs
&
RXSTAT_OVERRUN
)
&&
tty
->
flip
.
count
<
TTY_FLIPBUF_SIZE
)
{
...
...
@@ -137,9 +136,7 @@ static irqreturn_t serial21285_rx_chars(int irq, void *dev_id, struct pt_regs *r
* immediately, and doesn't affect the current
* character.
*/
*
tty
->
flip
.
char_buf_ptr
++
=
0
;
*
tty
->
flip
.
flag_buf_ptr
++
=
TTY_OVERRUN
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
0
,
TTY_OVERRUN
);
}
status
=
*
CSR_UARTFLG
;
}
...
...
This diff is collapsed.
Click to expand it.
drivers/serial/8250.c
View file @
2d202ddc
...
...
@@ -20,28 +20,29 @@
* membase is an 'ioremapped' cookie.
*/
#include <linux/config.h>
#if defined(CONFIG_SERIAL_8250_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/module.h>
#include <linux/moduleparam.h>
#include <linux/tty.h>
#include <linux/ioport.h>
#include <linux/init.h>
#include <linux/console.h>
#include <linux/sysrq.h>
#include <linux/delay.h>
#include <linux/device.h>
#include <linux/tty.h>
#include <linux/tty_flip.h>
#include <linux/serial_reg.h>
#include <linux/serial_core.h>
#include <linux/serial.h>
#include <linux/serial_8250.h>
#include <linux/circ_buf.h>
#include <linux/delay.h>
#include <linux/device.h>
#include <asm/io.h>
#include <asm/irq.h>
#if defined(CONFIG_SERIAL_8250_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/serial_core.h>
#include "8250.h"
/*
...
...
@@ -979,16 +980,19 @@ receive_chars(struct uart_8250_port *up, int *status, struct pt_regs *regs)
struct
tty_struct
*
tty
=
up
->
port
.
info
->
tty
;
unsigned
char
ch
,
lsr
=
*
status
;
int
max_count
=
256
;
char
flag
;
do
{
/* The following is not allowed by the tty layer and
unsafe. It should be fixed ASAP */
if
(
unlikely
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
))
{
tty
->
flip
.
work
.
func
((
void
*
)
tty
);
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
return
;
// if TTY_DONT_FLIP is set
if
(
tty
->
low_latency
)
tty_flip_buffer_push
(
tty
);
/* If this failed then we will throw away the
bytes but must do so to clear interrupts */
}
ch
=
serial_inp
(
up
,
UART_RX
);
*
tty
->
flip
.
char_buf_ptr
=
ch
;
*
tty
->
flip
.
flag_buf_ptr
=
TTY_NORMAL
;
flag
=
TTY_NORMAL
;
up
->
port
.
icount
.
rx
++
;
#ifdef CONFIG_SERIAL_8250_CONSOLE
...
...
@@ -1031,18 +1035,16 @@ receive_chars(struct uart_8250_port *up, int *status, struct pt_regs *regs)
if
(
lsr
&
UART_LSR_BI
)
{
DEBUG_INTR
(
"handling break...."
);
*
tty
->
flip
.
flag_buf_ptr
=
TTY_BREAK
;
flag
=
TTY_BREAK
;
}
else
if
(
lsr
&
UART_LSR_PE
)
*
tty
->
flip
.
flag_buf_ptr
=
TTY_PARITY
;
flag
=
TTY_PARITY
;
else
if
(
lsr
&
UART_LSR_FE
)
*
tty
->
flip
.
flag_buf_ptr
=
TTY_FRAME
;
flag
=
TTY_FRAME
;
}
if
(
uart_handle_sysrq_char
(
&
up
->
port
,
ch
,
regs
))
goto
ignore_char
;
if
((
lsr
&
up
->
port
.
ignore_status_mask
)
==
0
)
{
tty
->
flip
.
flag_buf_ptr
++
;
tty
->
flip
.
char_buf_ptr
++
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
ch
,
flag
);
}
if
((
lsr
&
UART_LSR_OE
)
&&
tty
->
flip
.
count
<
TTY_FLIPBUF_SIZE
)
{
...
...
@@ -1051,10 +1053,7 @@ receive_chars(struct uart_8250_port *up, int *status, struct pt_regs *regs)
* immediately, and doesn't affect the current
* character.
*/
*
tty
->
flip
.
flag_buf_ptr
=
TTY_OVERRUN
;
tty
->
flip
.
flag_buf_ptr
++
;
tty
->
flip
.
char_buf_ptr
++
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
0
,
TTY_OVERRUN
);
}
ignore_char:
lsr
=
serial_inp
(
up
,
UART_LSR
);
...
...
This diff is collapsed.
Click to expand it.
drivers/serial/8250_pci.c
View file @
2d202ddc
...
...
@@ -283,7 +283,7 @@ static int __devinit pci_plx9050_init(struct pci_dev *dev)
static
void
__devexit
pci_plx9050_exit
(
struct
pci_dev
*
dev
)
{
u8
*
p
;
u8
__iomem
*
p
;
if
((
pci_resource_flags
(
dev
,
0
)
&
IORESOURCE_MEM
)
==
0
)
return
;
...
...
@@ -336,7 +336,7 @@ sbs_setup(struct pci_dev *dev, struct pci_board *board,
static
int
__devinit
sbs_init
(
struct
pci_dev
*
dev
)
{
u8
*
p
;
u8
__iomem
*
p
;
p
=
ioremap
(
pci_resource_start
(
dev
,
0
),
pci_resource_len
(
dev
,
0
));
...
...
@@ -360,7 +360,7 @@ static int __devinit sbs_init(struct pci_dev *dev)
static
void
__devexit
sbs_exit
(
struct
pci_dev
*
dev
)
{
u8
*
p
;
u8
__iomem
*
p
;
p
=
ioremap
(
pci_resource_start
(
dev
,
0
),
pci_resource_len
(
dev
,
0
));
if
(
p
!=
NULL
)
{
...
...
This diff is collapsed.
Click to expand it.
drivers/serial/amba-pl010.c
View file @
2d202ddc
...
...
@@ -32,25 +32,25 @@
* and hooked into this driver.
*/
#include <linux/config.h>
#if defined(CONFIG_SERIAL_AMBA_PL010_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/module.h>
#include <linux/tty.h>
#include <linux/ioport.h>
#include <linux/init.h>
#include <linux/serial.h>
#include <linux/console.h>
#include <linux/sysrq.h>
#include <linux/device.h>
#include <linux/tty.h>
#include <linux/tty_flip.h>
#include <linux/serial_core.h>
#include <linux/serial.h>
#include <asm/io.h>
#include <asm/irq.h>
#include <asm/hardware/amba.h>
#if defined(CONFIG_SERIAL_AMBA_PL010_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/serial_core.h>
#include <asm/hardware/amba_serial.h>
#define UART_NR 2
...
...
@@ -149,22 +149,22 @@ pl010_rx_chars(struct uart_port *port)
#endif
{
struct
tty_struct
*
tty
=
port
->
info
->
tty
;
unsigned
int
status
,
ch
,
rsr
,
max_count
=
256
;
unsigned
int
status
,
ch
,
flag
,
rsr
,
max_count
=
256
;
status
=
UART_GET_FR
(
port
);
while
(
UART_RX_DATA
(
status
)
&&
max_count
--
)
{
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
{
tty
->
flip
.
work
.
func
((
void
*
)
tty
);
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
{
printk
(
KERN_WARNING
"TTY_DONT_FLIP set
\n
"
);
return
;
}
if
(
tty
->
low_latency
)
tty_flip_buffer_push
(
tty
);
/*
* If this failed then we will throw away the
* bytes but must do so to clear interrupts.
*/
}
ch
=
UART_GET_CHAR
(
port
);
flag
=
TTY_NORMAL
;
*
tty
->
flip
.
char_buf_ptr
=
ch
;
*
tty
->
flip
.
flag_buf_ptr
=
TTY_NORMAL
;
port
->
icount
.
rx
++
;
/*
...
...
@@ -188,20 +188,18 @@ pl010_rx_chars(struct uart_port *port)
rsr
&=
port
->
read_status_mask
;
if
(
rsr
&
UART01x_RSR_BE
)
*
tty
->
flip
.
flag_buf_ptr
=
TTY_BREAK
;
flag
=
TTY_BREAK
;
else
if
(
rsr
&
UART01x_RSR_PE
)
*
tty
->
flip
.
flag_buf_ptr
=
TTY_PARITY
;
flag
=
TTY_PARITY
;
else
if
(
rsr
&
UART01x_RSR_FE
)
*
tty
->
flip
.
flag_buf_ptr
=
TTY_FRAME
;
flag
=
TTY_FRAME
;
}
if
(
uart_handle_sysrq_char
(
port
,
ch
,
regs
))
goto
ignore_char
;
if
((
rsr
&
port
->
ignore_status_mask
)
==
0
)
{
tty
->
flip
.
flag_buf_ptr
++
;
tty
->
flip
.
char_buf_ptr
++
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
ch
,
flag
);
}
if
((
rsr
&
UART01x_RSR_OE
)
&&
tty
->
flip
.
count
<
TTY_FLIPBUF_SIZE
)
{
...
...
@@ -210,9 +208,7 @@ pl010_rx_chars(struct uart_port *port)
* immediately, and doesn't affect the current
* character
*/
*
tty
->
flip
.
char_buf_ptr
++
=
0
;
*
tty
->
flip
.
flag_buf_ptr
++
=
TTY_OVERRUN
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
0
,
TTY_OVERRUN
);
}
ignore_char:
status
=
UART_GET_FR
(
port
);
...
...
This diff is collapsed.
Click to expand it.
drivers/serial/amba-pl011.c
View file @
2d202ddc
...
...
@@ -32,26 +32,26 @@
* and hooked into this driver.
*/
#include <linux/config.h>
#if defined(CONFIG_SERIAL_AMBA_PL011_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/module.h>
#include <linux/tty.h>
#include <linux/ioport.h>
#include <linux/init.h>
#include <linux/serial.h>
#include <linux/console.h>
#include <linux/sysrq.h>
#include <linux/device.h>
#include <linux/tty.h>
#include <linux/tty_flip.h>
#include <linux/serial_core.h>
#include <linux/serial.h>
#include <asm/io.h>
#include <asm/irq.h>
#include <asm/hardware/amba.h>
#include <asm/hardware/clock.h>
#if defined(CONFIG_SERIAL_AMBA_PL011_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/serial_core.h>
#include <asm/hardware/amba_serial.h>
#define UART_NR 14
...
...
@@ -115,22 +115,21 @@ pl011_rx_chars(struct uart_amba_port *uap)
#endif
{
struct
tty_struct
*
tty
=
uap
->
port
.
info
->
tty
;
unsigned
int
status
,
ch
,
rsr
,
max_count
=
256
;
unsigned
int
status
,
ch
,
flag
,
rsr
,
max_count
=
256
;
status
=
readw
(
uap
->
port
.
membase
+
UART01x_FR
);
while
((
status
&
UART01x_FR_RXFE
)
==
0
&&
max_count
--
)
{
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
{
tty
->
flip
.
work
.
func
((
void
*
)
tty
);
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
{
printk
(
KERN_WARNING
"TTY_DONT_FLIP set
\n
"
);
return
;
}
if
(
tty
->
low_latency
)
tty_flip_buffer_push
(
tty
);
/*
* If this failed then we will throw away the
* bytes but must do so to clear interrupts
*/
}
ch
=
readw
(
uap
->
port
.
membase
+
UART01x_DR
);
*
tty
->
flip
.
char_buf_ptr
=
ch
;
*
tty
->
flip
.
flag_buf_ptr
=
TTY_NORMAL
;
flag
=
TTY_NORMAL
;
uap
->
port
.
icount
.
rx
++
;
/*
...
...
@@ -154,20 +153,18 @@ pl011_rx_chars(struct uart_amba_port *uap)
rsr
&=
uap
->
port
.
read_status_mask
;
if
(
rsr
&
UART01x_RSR_BE
)
*
tty
->
flip
.
flag_buf_ptr
=
TTY_BREAK
;
flag
=
TTY_BREAK
;
else
if
(
rsr
&
UART01x_RSR_PE
)
*
tty
->
flip
.
flag_buf_ptr
=
TTY_PARITY
;
flag
=
TTY_PARITY
;
else
if
(
rsr
&
UART01x_RSR_FE
)
*
tty
->
flip
.
flag_buf_ptr
=
TTY_FRAME
;
flag
=
TTY_FRAME
;
}
if
(
uart_handle_sysrq_char
(
&
uap
->
port
,
ch
,
regs
))
goto
ignore_char
;
if
((
rsr
&
uap
->
port
.
ignore_status_mask
)
==
0
)
{
tty
->
flip
.
flag_buf_ptr
++
;
tty
->
flip
.
char_buf_ptr
++
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
ch
,
flag
);
}
if
((
rsr
&
UART01x_RSR_OE
)
&&
tty
->
flip
.
count
<
TTY_FLIPBUF_SIZE
)
{
...
...
@@ -176,9 +173,7 @@ pl011_rx_chars(struct uart_amba_port *uap)
* immediately, and doesn't affect the current
* character
*/
*
tty
->
flip
.
char_buf_ptr
++
=
0
;
*
tty
->
flip
.
flag_buf_ptr
++
=
TTY_OVERRUN
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
0
,
TTY_OVERRUN
);
}
ignore_char:
status
=
readw
(
uap
->
port
.
membase
+
UART01x_FR
);
...
...
This diff is collapsed.
Click to expand it.
drivers/serial/clps711x.c
View file @
2d202ddc
...
...
@@ -26,26 +26,26 @@
*
*/
#include <linux/config.h>
#if defined(CONFIG_SERIAL_CLPS711X_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/module.h>
#include <linux/tty.h>
#include <linux/ioport.h>
#include <linux/init.h>
#include <linux/serial.h>
#include <linux/console.h>
#include <linux/sysrq.h>
#include <linux/spinlock.h>
#include <linux/device.h>
#include <linux/tty.h>
#include <linux/tty_flip.h>
#include <linux/serial_core.h>
#include <linux/serial.h>
#include <asm/hardware.h>
#include <asm/io.h>
#include <asm/irq.h>
#if defined(CONFIG_SERIAL_CLPS711X_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/serial_core.h>
#include <asm/hardware/clps7111.h>
#define UART_NR 2
...
...
@@ -123,9 +123,7 @@ static irqreturn_t clps711xuart_int_rx(int irq, void *dev_id, struct pt_regs *re
goto
ignore_char
;
error_return:
*
tty
->
flip
.
flag_buf_ptr
++
=
flg
;
*
tty
->
flip
.
char_buf_ptr
++
=
ch
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
ch
,
flg
);
ignore_char:
status
=
clps_readl
(
SYSFLG
(
port
));
}
...
...
@@ -158,11 +156,7 @@ static irqreturn_t clps711xuart_int_rx(int irq, void *dev_id, struct pt_regs *re
* CHECK: does overrun affect the current character?
* ASSUMPTION: it does not.
*/
*
tty
->
flip
.
flag_buf_ptr
++
=
flg
;
*
tty
->
flip
.
char_buf_ptr
++
=
ch
;
tty
->
flip
.
count
++
;
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
goto
ignore_char
;
tty_insert_flip_char
(
tty
,
ch
,
flg
);
ch
=
0
;
flg
=
TTY_OVERRUN
;
}
...
...
This diff is collapsed.
Click to expand it.
drivers/serial/dz.c
View file @
2d202ddc
...
...
@@ -28,12 +28,13 @@
#include <linux/config.h>
#include <linux/module.h>
#include <linux/tty.h>
#include <linux/interrupt.h>
#include <linux/init.h>
#include <linux/console.h>
#include <linux/serial.h>
#include <linux/tty.h>
#include <linux/tty_flip.h>
#include <linux/serial_core.h>
#include <linux/serial.h>
#include <asm/bootinfo.h>
#include <asm/dec/interrupts.h>
...
...
@@ -186,7 +187,7 @@ static inline void dz_receive_chars(struct dz_port *dport)
struct
uart_icount
*
icount
;
int
ignore
=
0
;
unsigned
short
status
,
tmp
;
unsigned
char
ch
;
unsigned
char
ch
,
flag
;
/* this code is going to be a problem...
the call to tty_flip_buffer is going to need
...
...
@@ -201,6 +202,7 @@ static inline void dz_receive_chars(struct dz_port *dport)
ch
=
UCHAR
(
status
);
/* grab the char */
flag
=
TTY_NORMAL
;
#if 0
if (info->is_console) {
...
...
@@ -217,8 +219,6 @@ static inline void dz_receive_chars(struct dz_port *dport)
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
break
;
*
tty
->
flip
.
char_buf_ptr
=
ch
;
*
tty
->
flip
.
flag_buf_ptr
=
0
;
icount
->
rx
++
;
/* keep track of the statistics */
...
...
@@ -243,12 +243,12 @@ static inline void dz_receive_chars(struct dz_port *dport)
tmp
=
status
&
dport
->
port
.
read_status_mask
;
if
(
tmp
&
DZ_PERR
)
{
*
tty
->
flip
.
flag_buf_ptr
=
TTY_PARITY
;
flag
=
TTY_PARITY
;
#ifdef DEBUG_DZ
debug_console
(
"PERR
\n
"
,
5
);
#endif
}
else
if
(
tmp
&
DZ_FERR
)
{
*
tty
->
flip
.
flag_buf_ptr
=
TTY_FRAME
;
flag
=
TTY_FRAME
;
#ifdef DEBUG_DZ
debug_console
(
"FERR
\n
"
,
5
);
#endif
...
...
@@ -257,17 +257,12 @@ static inline void dz_receive_chars(struct dz_port *dport)
#ifdef DEBUG_DZ
debug_console
(
"OERR
\n
"
,
5
);
#endif
if
(
tty
->
flip
.
count
<
TTY_FLIPBUF_SIZE
)
{
tty
->
flip
.
count
++
;
tty
->
flip
.
flag_buf_ptr
++
;
tty
->
flip
.
char_buf_ptr
++
;
*
tty
->
flip
.
flag_buf_ptr
=
TTY_OVERRUN
;
}
tty_insert_flip_char
(
tty
,
ch
,
flag
);
ch
=
0
;
flag
=
TTY_OVERRUN
;
}
}
tty
->
flip
.
flag_buf_ptr
++
;
tty
->
flip
.
char_buf_ptr
++
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
ch
,
flag
);
ignore_char:
}
while
(
status
&
DZ_DVAL
);
...
...
This diff is collapsed.
Click to expand it.
drivers/serial/imx.c
View file @
2d202ddc
...
...
@@ -24,14 +24,21 @@
*
*/
#include <linux/config.h>
#if defined(CONFIG_SERIAL_IMX_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/module.h>
#include <linux/tty.h>
#include <linux/ioport.h>
#include <linux/init.h>
#include <linux/serial.h>
#include <linux/console.h>
#include <linux/sysrq.h>
#include <linux/device.h>
#include <linux/tty.h>
#include <linux/tty_flip.h>
#include <linux/serial_core.h>
#include <linux/serial.h>
#include <asm/io.h>
#include <asm/irq.h>
...
...
@@ -39,12 +46,6 @@
#include <asm/arch/serial.h>
#include <asm/mach-types.h>
#if defined(CONFIG_SERIAL_IMX_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/serial_core.h>
/* We've been assigned a range on the "Low-density serial ports" major */
#define SERIAL_IMX_MAJOR 204
#define MINOR_START 41
...
...
@@ -237,9 +238,7 @@ static irqreturn_t imx_rxint(int irq, void *dev_id, struct pt_regs *regs)
goto
handle_error
;
error_return:
*
tty
->
flip
.
flag_buf_ptr
++
=
flg
;
*
tty
->
flip
.
char_buf_ptr
++
=
(
unsigned
char
)
rx
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
rx
,
flg
);
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
goto
out
;
...
...
This diff is collapsed.
Click to expand it.
drivers/serial/pxa.c
View file @
2d202ddc
...
...
@@ -25,8 +25,12 @@
*/
#include <linux/config.h>
#if defined(CONFIG_SERIAL_PXA_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/module.h>
#include <linux/tty.h>
#include <linux/ioport.h>
#include <linux/init.h>
#include <linux/console.h>
...
...
@@ -36,18 +40,15 @@
#include <linux/delay.h>
#include <linux/interrupt.h>
#include <linux/device.h>
#include <linux/tty.h>
#include <linux/tty_flip.h>
#include <linux/serial_core.h>
#include <asm/io.h>
#include <asm/hardware.h>
#include <asm/irq.h>
#include <asm/arch/pxa-regs.h>
#if defined(CONFIG_SERIAL_PXA_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/serial_core.h>
struct
uart_pxa_port
{
struct
uart_port
port
;
...
...
@@ -102,25 +103,20 @@ static inline void
receive_chars
(
struct
uart_pxa_port
*
up
,
int
*
status
,
struct
pt_regs
*
regs
)
{
struct
tty_struct
*
tty
=
up
->
port
.
info
->
tty
;
unsigned
char
ch
;
unsigned
int
ch
,
flag
;
int
max_count
=
256
;
do
{
if
(
unlikely
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
))
{
if
(
tty
->
low_latency
)
tty_flip_buffer_push
(
tty
);
/*
* FIXME: Deadlock can happen here if we're a
* low-latency port. We're holding the per-port
* spinlock, and we call flush_to_ldisc->
* n_tty_receive_buf->n_tty_receive_char->
* opost->uart_put_char.
* If this failed then we will throw away the
* bytes but must do so to clear interrupts
*/
tty
->
flip
.
work
.
func
((
void
*
)
tty
);
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
return
;
// if TTY_DONT_FLIP is set
}
ch
=
serial_in
(
up
,
UART_RX
);
*
tty
->
flip
.
char_buf_ptr
=
ch
;
*
tty
->
flip
.
flag_buf_ptr
=
TTY_NORMAL
;
flag
=
TTY_NORMAL
;
up
->
port
.
icount
.
rx
++
;
if
(
unlikely
(
*
status
&
(
UART_LSR_BI
|
UART_LSR_PE
|
...
...
@@ -159,18 +155,16 @@ receive_chars(struct uart_pxa_port *up, int *status, struct pt_regs *regs)
}
#endif
if
(
*
status
&
UART_LSR_BI
)
{
*
tty
->
flip
.
flag_buf_ptr
=
TTY_BREAK
;
flag
=
TTY_BREAK
;
}
else
if
(
*
status
&
UART_LSR_PE
)
*
tty
->
flip
.
flag_buf_ptr
=
TTY_PARITY
;
flag
=
TTY_PARITY
;
else
if
(
*
status
&
UART_LSR_FE
)
*
tty
->
flip
.
flag_buf_ptr
=
TTY_FRAME
;
flag
=
TTY_FRAME
;
}
if
(
uart_handle_sysrq_char
(
&
up
->
port
,
ch
,
regs
))
goto
ignore_char
;
if
((
*
status
&
up
->
port
.
ignore_status_mask
)
==
0
)
{
tty
->
flip
.
flag_buf_ptr
++
;
tty
->
flip
.
char_buf_ptr
++
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
ch
,
flag
);
}
if
((
*
status
&
UART_LSR_OE
)
&&
tty
->
flip
.
count
<
TTY_FLIPBUF_SIZE
)
{
...
...
@@ -179,10 +173,7 @@ receive_chars(struct uart_pxa_port *up, int *status, struct pt_regs *regs)
* immediately, and doesn't affect the current
* character.
*/
*
tty
->
flip
.
flag_buf_ptr
=
TTY_OVERRUN
;
tty
->
flip
.
flag_buf_ptr
++
;
tty
->
flip
.
char_buf_ptr
++
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
0
,
TTY_OVERRUN
);
}
ignore_char:
*
status
=
serial_in
(
up
,
UART_LSR
);
...
...
This diff is collapsed.
Click to expand it.
drivers/serial/s3c2410.c
View file @
2d202ddc
...
...
@@ -12,11 +12,12 @@
*/
#include <linux/config.h>
#include <linux/module.h>
#include <linux/tty.h>
#include <linux/ioport.h>
#include <linux/device.h>
#include <linux/init.h>
#include <linux/console.h>
#include <linux/tty.h>
#include <linux/tty_flip.h>
#include <linux/serial_core.h>
#include <linux/serial.h>
...
...
@@ -111,7 +112,7 @@ serial_s3c2410_rx_chars(int irq, void *dev_id, struct pt_regs *regs)
{
struct
uart_port
*
port
=
dev_id
;
struct
tty_struct
*
tty
=
port
->
info
->
tty
;
unsigned
int
ufcon
,
ch
,
rxs
,
ufstat
;
unsigned
int
ufcon
,
ch
,
flag
,
rxs
,
ufstat
;
int
max_count
=
256
;
while
(
max_count
--
>
0
)
{
...
...
@@ -122,17 +123,16 @@ serial_s3c2410_rx_chars(int irq, void *dev_id, struct pt_regs *regs)
break
;
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
{
tty
->
flip
.
work
.
func
((
void
*
)
tty
);
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
{
printk
(
KERN_WARNING
"TTY_DONT_FLIP set
\n
"
);
goto
out
;
}
if
(
tty
->
low_latency
)
tty_flip_buffer_push
(
tty
);
/*
* If this failed then we will throw away the
* bytes but must do so to clear interrupts
*/
}
ch
=
rd_regb
(
port
,
S3C2410_URXH
);
*
tty
->
flip
.
char_buf_ptr
=
ch
;
*
tty
->
flip
.
flag_buf_ptr
=
TTY_NORMAL
;
flag
=
TTY_NORMAL
;
port
->
icount
.
rx
++
;
rxs
=
rd_regb
(
port
,
S3C2410_UERSTAT
)
|
RXSTAT_DUMMY_READ
;
...
...
@@ -146,15 +146,13 @@ serial_s3c2410_rx_chars(int irq, void *dev_id, struct pt_regs *regs)
rxs
&=
port
->
read_status_mask
;
if
(
rxs
&
S3C2410_UERSTAT_PARITY
)
*
tty
->
flip
.
flag_buf_ptr
=
TTY_PARITY
;
flag
=
TTY_PARITY
;
else
if
(
rxs
&
(
S3C2410_UERSTAT_FRAME
|
S3C2410_UERSTAT_OVERRUN
))
*
tty
->
flip
.
flag_buf_ptr
=
TTY_FRAME
;
flag
=
TTY_FRAME
;
}
if
((
rxs
&
port
->
ignore_status_mask
)
==
0
)
{
tty
->
flip
.
flag_buf_ptr
++
;
tty
->
flip
.
char_buf_ptr
++
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
ch
,
flag
);
}
if
((
rxs
&
S3C2410_UERSTAT_OVERRUN
)
&&
...
...
@@ -164,9 +162,7 @@ serial_s3c2410_rx_chars(int irq, void *dev_id, struct pt_regs *regs)
* immediately, and doesn't affect the current
* character.
*/
*
tty
->
flip
.
char_buf_ptr
++
=
0
;
*
tty
->
flip
.
flag_buf_ptr
++
=
TTY_OVERRUN
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
0
,
TTY_OVERRUN
);
}
}
tty_flip_buffer_push
(
tty
);
...
...
This diff is collapsed.
Click to expand it.
drivers/serial/sa1100.c
View file @
2d202ddc
...
...
@@ -25,26 +25,27 @@
*
*/
#include <linux/config.h>
#if defined(CONFIG_SERIAL_SA1100_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/module.h>
#include <linux/tty.h>
#include <linux/ioport.h>
#include <linux/init.h>
#include <linux/serial.h>
#include <linux/console.h>
#include <linux/sysrq.h>
#include <linux/device.h>
#include <linux/tty.h>
#include <linux/tty_flip.h>
#include <linux/serial_core.h>
#include <linux/serial.h>
#include <asm/io.h>
#include <asm/irq.h>
#include <asm/hardware.h>
#include <asm/mach/serial_sa1100.h>
#if defined(CONFIG_SERIAL_SA1100_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/serial_core.h>
/* We've been assigned a range on the "Low-density serial ports" major */
#define SERIAL_SA1100_MAJOR 204
#define MINOR_START 5
...
...
@@ -220,9 +221,7 @@ sa1100_rx_chars(struct sa1100_port *sport, struct pt_regs *regs)
goto
ignore_char
;
error_return:
*
tty
->
flip
.
flag_buf_ptr
++
=
flg
;
*
tty
->
flip
.
char_buf_ptr
++
=
ch
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
ch
,
flg
);
ignore_char:
status
=
UTSR1_TO_SM
(
UART_GET_UTSR1
(
sport
))
|
UTSR0_TO_SM
(
UART_GET_UTSR0
(
sport
));
...
...
@@ -257,11 +256,7 @@ sa1100_rx_chars(struct sa1100_port *sport, struct pt_regs *regs)
* overrun does *not* affect the character
* we read from the FIFO
*/
*
tty
->
flip
.
flag_buf_ptr
++
=
flg
;
*
tty
->
flip
.
char_buf_ptr
++
=
ch
;
tty
->
flip
.
count
++
;
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
goto
ignore_char
;
tty_insert_flip_char
(
tty
,
ch
,
flg
);
ch
=
0
;
flg
=
TTY_OVERRUN
;
}
...
...
This diff is collapsed.
Click to expand it.
drivers/serial/serial_lh7a40x.c
View file @
2d202ddc
...
...
@@ -28,23 +28,24 @@
*/
#include <linux/config.h>
#if defined(CONFIG_SERIAL_LH7A40X_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/module.h>
#include <linux/tty.h>
#include <linux/ioport.h>
#include <linux/init.h>
#include <linux/serial.h>
#include <linux/console.h>
#include <linux/sysrq.h>
#include <linux/tty.h>
#include <linux/tty_flip.h>
#include <linux/serial_core.h>
#include <linux/serial.h>
#include <asm/io.h>
#include <asm/irq.h>
#if defined(CONFIG_SERIAL_LH7A40X_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/serial_core.h>
#define DEV_MAJOR 204
#define DEV_MINOR 16
#define DEV_NR 3
...
...
@@ -145,21 +146,20 @@ lh7a40xuart_rx_chars (struct uart_port* port)
{
struct
tty_struct
*
tty
=
port
->
info
->
tty
;
int
cbRxMax
=
256
;
/* (Gross) limit on receive */
unsigned
int
data
;
/* Received data and status */
unsigned
int
data
,
flag
;
/* Received data and status */
while
(
!
(
UR
(
port
,
UART_R_STATUS
)
&
nRxRdy
)
&&
--
cbRxMax
)
{
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
{
tty
->
flip
.
work
.
func
((
void
*
)
tty
);
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
{
printk
(
KERN_WARNING
"TTY_DONT_FLIP set
\n
"
);
return
;
}
if
(
tty
->
low_latency
)
tty_flip_buffer_push
(
tty
);
/*
* If this failed then we will throw away the
* bytes but must do so to clear interrupts
*/
}
data
=
UR
(
port
,
UART_R_DATA
);
*
tty
->
flip
.
char_buf_ptr
=
(
unsigned
char
)
data
;
*
tty
->
flip
.
flag_buf_ptr
=
TTY_NORMAL
;
flag
=
TTY_NORMAL
;
++
port
->
icount
.
rx
;
if
(
data
&
RxError
)
{
/* Quick check, short-circuit */
...
...
@@ -180,20 +180,18 @@ lh7a40xuart_rx_chars (struct uart_port* port)
data
&=
port
->
read_status_mask
|
0xff
;
if
(
data
&
RxBreak
)
*
tty
->
flip
.
flag_buf_ptr
=
TTY_BREAK
;
flag
=
TTY_BREAK
;
else
if
(
data
&
RxParityError
)
*
tty
->
flip
.
flag_buf_ptr
=
TTY_PARITY
;
flag
=
TTY_PARITY
;
else
if
(
data
&
RxFramingError
)
*
tty
->
flip
.
flag_buf_ptr
=
TTY_FRAME
;
flag
=
TTY_FRAME
;
}
if
(
uart_handle_sysrq_char
(
port
,
(
unsigned
char
)
data
,
regs
))
continue
;
if
((
data
&
port
->
ignore_status_mask
)
==
0
)
{
++
tty
->
flip
.
flag_buf_ptr
;
++
tty
->
flip
.
char_buf_ptr
;
++
tty
->
flip
.
count
;
tty_insert_flip_char
(
tty
,
data
,
flag
);
}
if
((
data
&
RxOverrunError
)
&&
tty
->
flip
.
count
<
TTY_FLIPBUF_SIZE
)
{
...
...
@@ -202,9 +200,7 @@ lh7a40xuart_rx_chars (struct uart_port* port)
* immediately, and doesn't affect the current
* character
*/
*
tty
->
flip
.
char_buf_ptr
++
=
0
;
*
tty
->
flip
.
flag_buf_ptr
++
=
TTY_OVERRUN
;
++
tty
->
flip
.
count
;
tty_insert_flip_char
(
tty
,
0
,
TTY_OVERRUN
);
}
}
tty_flip_buffer_push
(
tty
);
...
...
This diff is collapsed.
Click to expand it.
drivers/serial/uart00.c
View file @
2d202ddc
...
...
@@ -27,23 +27,25 @@
*
*/
#include <linux/config.h>
#if defined(CONFIG_SERIAL_UART00_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/module.h>
#include <linux/tty.h>
#include <linux/ioport.h>
#include <linux/init.h>
#include <linux/serial.h>
#include <linux/console.h>
#include <linux/sysrq.h>
#include <linux/tty.h>
#include <linux/tty_flip.h>
#include <linux/serial_core.h>
#include <linux/serial.h>
#include <asm/io.h>
#include <asm/irq.h>
#include <asm/sizes.h>
#if defined(CONFIG_SERIAL_UART00_CONSOLE) && defined(CONFIG_MAGIC_SYSRQ)
#define SUPPORT_SYSRQ
#endif
#include <linux/serial_core.h>
#include <asm/arch/excalibur.h>
#define UART00_TYPE (volatile unsigned int*)
#include <asm/arch/uart00.h>
...
...
@@ -132,9 +134,8 @@ uart00_rx_chars(struct uart_port *port, struct pt_regs *regs)
goto
ignore_char
;
error_return:
*
tty
->
flip
.
flag_buf_ptr
++
=
flg
;
*
tty
->
flip
.
char_buf_ptr
++
=
ch
;
tty
->
flip
.
count
++
;
tty_insert_flip_char
(
tty
,
ch
,
flg
);
ignore_char:
status
=
UART_GET_RSR
(
port
);
}
...
...
@@ -174,11 +175,7 @@ uart00_rx_chars(struct uart_port *port, struct pt_regs *regs)
* CHECK: does overrun affect the current character?
* ASSUMPTION: it does not.
*/
*
tty
->
flip
.
flag_buf_ptr
++
=
flg
;
*
tty
->
flip
.
char_buf_ptr
++
=
ch
;
tty
->
flip
.
count
++
;
if
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)
goto
ignore_char
;
tty_insert_flip_char
(
tty
,
ch
,
flg
);
ch
=
0
;
flg
=
TTY_OVERRUN
;
}
...
...
This diff is collapsed.
Click to expand it.
include/linux/serial_core.h
View file @
2d202ddc
...
...
@@ -94,6 +94,9 @@
/*IBM icom*/
#define PORT_ICOM 60
/* Samsung S3C2440 SoC */
#define PORT_S3C2440 61
#ifdef __KERNEL__
#include <linux/config.h>
...
...
@@ -171,7 +174,7 @@ struct uart_icount {
struct
uart_port
{
spinlock_t
lock
;
/* port lock */
unsigned
int
iobase
;
/* in/out[bwl] */
char
*
membase
;
/* read/write[bwl] */
unsigned
char
__iomem
*
membase
;
/* read/write[bwl] */
unsigned
int
irq
;
/* irq number */
unsigned
int
uartclk
;
/* base uart clock */
unsigned
char
fifosize
;
/* tx fifo size */
...
...
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment