aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/serial/8250_pci.c33
1 files changed, 18 insertions, 15 deletions
diff --git a/drivers/serial/8250_pci.c b/drivers/serial/8250_pci.c
index 356f5556759a..84c8f8f592ca 100644
--- a/drivers/serial/8250_pci.c
+++ b/drivers/serial/8250_pci.c
@@ -54,7 +54,7 @@
54/* Use the Base address register size to cap number of ports */ 54/* Use the Base address register size to cap number of ports */
55#define FL_REGION_SZ_CAP 0x0100 55#define FL_REGION_SZ_CAP 0x0100
56 56
57struct pci_board { 57struct pciserial_board {
58 unsigned int flags; 58 unsigned int flags;
59 unsigned int num_ports; 59 unsigned int num_ports;
60 unsigned int base_baud; 60 unsigned int base_baud;
@@ -75,7 +75,7 @@ struct pci_serial_quirk {
75 u32 subvendor; 75 u32 subvendor;
76 u32 subdevice; 76 u32 subdevice;
77 int (*init)(struct pci_dev *dev); 77 int (*init)(struct pci_dev *dev);
78 int (*setup)(struct pci_dev *dev, struct pci_board *board, 78 int (*setup)(struct pci_dev *dev, struct pciserial_board *,
79 struct uart_port *port, int idx); 79 struct uart_port *port, int idx);
80 void (*exit)(struct pci_dev *dev); 80 void (*exit)(struct pci_dev *dev);
81}; 81};
@@ -136,7 +136,7 @@ setup_port(struct pci_dev *dev, struct uart_port *port,
136 * Not that ugly ;) -- HW 136 * Not that ugly ;) -- HW
137 */ 137 */
138static int 138static int
139afavlab_setup(struct pci_dev *dev, struct pci_board *board, 139afavlab_setup(struct pci_dev *dev, struct pciserial_board *board,
140 struct uart_port *port, int idx) 140 struct uart_port *port, int idx)
141{ 141{
142 unsigned int bar, offset = board->first_offset; 142 unsigned int bar, offset = board->first_offset;
@@ -189,7 +189,7 @@ static int __devinit pci_hp_diva_init(struct pci_dev *dev)
189 * some serial ports are supposed to be hidden on certain models. 189 * some serial ports are supposed to be hidden on certain models.
190 */ 190 */
191static int 191static int
192pci_hp_diva_setup(struct pci_dev *dev, struct pci_board *board, 192pci_hp_diva_setup(struct pci_dev *dev, struct pciserial_board *board,
193 struct uart_port *port, int idx) 193 struct uart_port *port, int idx)
194{ 194{
195 unsigned int offset = board->first_offset; 195 unsigned int offset = board->first_offset;
@@ -307,7 +307,7 @@ static void __devexit pci_plx9050_exit(struct pci_dev *dev)
307 307
308/* SBS Technologies Inc. PMC-OCTPRO and P-OCTAL cards */ 308/* SBS Technologies Inc. PMC-OCTPRO and P-OCTAL cards */
309static int 309static int
310sbs_setup(struct pci_dev *dev, struct pci_board *board, 310sbs_setup(struct pci_dev *dev, struct pciserial_board *board,
311 struct uart_port *port, int idx) 311 struct uart_port *port, int idx)
312{ 312{
313 unsigned int bar, offset = board->first_offset; 313 unsigned int bar, offset = board->first_offset;
@@ -523,7 +523,7 @@ static int __devinit pci_timedia_init(struct pci_dev *dev)
523 * Ugh, this is ugly as all hell --- TYT 523 * Ugh, this is ugly as all hell --- TYT
524 */ 524 */
525static int 525static int
526pci_timedia_setup(struct pci_dev *dev, struct pci_board *board, 526pci_timedia_setup(struct pci_dev *dev, struct pciserial_board *board,
527 struct uart_port *port, int idx) 527 struct uart_port *port, int idx)
528{ 528{
529 unsigned int bar = 0, offset = board->first_offset; 529 unsigned int bar = 0, offset = board->first_offset;
@@ -556,7 +556,8 @@ pci_timedia_setup(struct pci_dev *dev, struct pci_board *board,
556 * Some Titan cards are also a little weird 556 * Some Titan cards are also a little weird
557 */ 557 */
558static int 558static int
559titan_400l_800l_setup(struct pci_dev *dev, struct pci_board *board, 559titan_400l_800l_setup(struct pci_dev *dev,
560 struct pciserial_board *board,
560 struct uart_port *port, int idx) 561 struct uart_port *port, int idx)
561{ 562{
562 unsigned int bar, offset = board->first_offset; 563 unsigned int bar, offset = board->first_offset;
@@ -593,7 +594,7 @@ static int __devinit pci_netmos_init(struct pci_dev *dev)
593} 594}
594 595
595static int 596static int
596pci_default_setup(struct pci_dev *dev, struct pci_board *board, 597pci_default_setup(struct pci_dev *dev, struct pciserial_board *board,
597 struct uart_port *port, int idx) 598 struct uart_port *port, int idx)
598{ 599{
599 unsigned int bar, offset = board->first_offset, maxnr; 600 unsigned int bar, offset = board->first_offset, maxnr;
@@ -990,7 +991,7 @@ static struct pci_serial_quirk *find_quirk(struct pci_dev *dev)
990} 991}
991 992
992static _INLINE_ int 993static _INLINE_ int
993get_pci_irq(struct pci_dev *dev, struct pci_board *board, int idx) 994get_pci_irq(struct pci_dev *dev, struct pciserial_board *board, int idx)
994{ 995{
995 if (board->flags & FL_NOIRQ) 996 if (board->flags & FL_NOIRQ)
996 return 0; 997 return 0;
@@ -1113,7 +1114,7 @@ enum pci_board_num_t {
1113 * see first lines of serial_in() and serial_out() in 8250.c 1114 * see first lines of serial_in() and serial_out() in 8250.c
1114*/ 1115*/
1115 1116
1116static struct pci_board pci_boards[] __devinitdata = { 1117static struct pciserial_board pci_boards[] __devinitdata = {
1117 [pbn_default] = { 1118 [pbn_default] = {
1118 .flags = FL_BASE0, 1119 .flags = FL_BASE0,
1119 .num_ports = 1, 1120 .num_ports = 1,
@@ -1565,7 +1566,7 @@ static struct pci_board pci_boards[] __devinitdata = {
1565 * serial specs. Returns 0 on success, 1 on failure. 1566 * serial specs. Returns 0 on success, 1 on failure.
1566 */ 1567 */
1567static int __devinit 1568static int __devinit
1568serial_pci_guess_board(struct pci_dev *dev, struct pci_board *board) 1569serial_pci_guess_board(struct pci_dev *dev, struct pciserial_board *board)
1569{ 1570{
1570 int num_iomem, num_port, first_port = -1, i; 1571 int num_iomem, num_port, first_port = -1, i;
1571 1572
@@ -1630,7 +1631,8 @@ serial_pci_guess_board(struct pci_dev *dev, struct pci_board *board)
1630} 1631}
1631 1632
1632static inline int 1633static inline int
1633serial_pci_matches(struct pci_board *board, struct pci_board *guessed) 1634serial_pci_matches(struct pciserial_board *board,
1635 struct pciserial_board *guessed)
1634{ 1636{
1635 return 1637 return
1636 board->num_ports == guessed->num_ports && 1638 board->num_ports == guessed->num_ports &&
@@ -1648,7 +1650,7 @@ static int __devinit
1648pciserial_init_one(struct pci_dev *dev, const struct pci_device_id *ent) 1650pciserial_init_one(struct pci_dev *dev, const struct pci_device_id *ent)
1649{ 1651{
1650 struct serial_private *priv; 1652 struct serial_private *priv;
1651 struct pci_board *board, tmp; 1653 struct pciserial_board *board, tmp;
1652 struct pci_serial_quirk *quirk; 1654 struct pci_serial_quirk *quirk;
1653 int rc, nr_ports, i; 1655 int rc, nr_ports, i;
1654 1656
@@ -1669,7 +1671,7 @@ pciserial_init_one(struct pci_dev *dev, const struct pci_device_id *ent)
1669 * Use a copy of the pci_board entry for this; 1671 * Use a copy of the pci_board entry for this;
1670 * avoid changing entries in the table. 1672 * avoid changing entries in the table.
1671 */ 1673 */
1672 memcpy(&tmp, board, sizeof(struct pci_board)); 1674 memcpy(&tmp, board, sizeof(struct pciserial_board));
1673 board = &tmp; 1675 board = &tmp;
1674 1676
1675 /* 1677 /*
@@ -1685,7 +1687,8 @@ pciserial_init_one(struct pci_dev *dev, const struct pci_device_id *ent)
1685 * detect this boards settings with our heuristic, 1687 * detect this boards settings with our heuristic,
1686 * then we no longer need this entry. 1688 * then we no longer need this entry.
1687 */ 1689 */
1688 memcpy(&tmp, &pci_boards[pbn_default], sizeof(struct pci_board)); 1690 memcpy(&tmp, &pci_boards[pbn_default],
1691 sizeof(struct pciserial_board));
1689 rc = serial_pci_guess_board(dev, &tmp); 1692 rc = serial_pci_guess_board(dev, &tmp);
1690 if (rc == 0 && serial_pci_matches(board, &tmp)) 1693 if (rc == 0 && serial_pci_matches(board, &tmp))
1691 moan_device("Redundant entry in serial pci_table.", 1694 moan_device("Redundant entry in serial pci_table.",