LCOV - code coverage report
Current view: top level - drivers/tty/serial/8250 - 8250_pci.c (source / functions) Hit Total Coverage
Test: combined.info Lines: 32 886 3.6 %
Date: 2022-04-01 14:35:51 Functions: 3 76 3.9 %
Branches: 11 367 3.0 %

           Branch data     Line data    Source code
       1                 :            : // SPDX-License-Identifier: GPL-2.0
       2                 :            : /*
       3                 :            :  *  Probe module for 8250/16550-type PCI serial ports.
       4                 :            :  *
       5                 :            :  *  Based on drivers/char/serial.c, by Linus Torvalds, Theodore Ts'o.
       6                 :            :  *
       7                 :            :  *  Copyright (C) 2001 Russell King, All Rights Reserved.
       8                 :            :  */
       9                 :            : #undef DEBUG
      10                 :            : #include <linux/module.h>
      11                 :            : #include <linux/pci.h>
      12                 :            : #include <linux/string.h>
      13                 :            : #include <linux/kernel.h>
      14                 :            : #include <linux/slab.h>
      15                 :            : #include <linux/delay.h>
      16                 :            : #include <linux/tty.h>
      17                 :            : #include <linux/serial_reg.h>
      18                 :            : #include <linux/serial_core.h>
      19                 :            : #include <linux/8250_pci.h>
      20                 :            : #include <linux/bitops.h>
      21                 :            : 
      22                 :            : #include <asm/byteorder.h>
      23                 :            : #include <asm/io.h>
      24                 :            : 
      25                 :            : #include "8250.h"
      26                 :            : 
      27                 :            : /*
      28                 :            :  * init function returns:
      29                 :            :  *  > 0 - number of ports
      30                 :            :  *  = 0 - use board->num_ports
      31                 :            :  *  < 0 - error
      32                 :            :  */
      33                 :            : struct pci_serial_quirk {
      34                 :            :         u32     vendor;
      35                 :            :         u32     device;
      36                 :            :         u32     subvendor;
      37                 :            :         u32     subdevice;
      38                 :            :         int     (*probe)(struct pci_dev *dev);
      39                 :            :         int     (*init)(struct pci_dev *dev);
      40                 :            :         int     (*setup)(struct serial_private *,
      41                 :            :                          const struct pciserial_board *,
      42                 :            :                          struct uart_8250_port *, int);
      43                 :            :         void    (*exit)(struct pci_dev *dev);
      44                 :            : };
      45                 :            : 
      46                 :            : struct f815xxa_data {
      47                 :            :         spinlock_t lock;
      48                 :            :         int idx;
      49                 :            : };
      50                 :            : 
      51                 :            : struct serial_private {
      52                 :            :         struct pci_dev          *dev;
      53                 :            :         unsigned int            nr;
      54                 :            :         struct pci_serial_quirk *quirk;
      55                 :            :         const struct pciserial_board *board;
      56                 :            :         int                     line[0];
      57                 :            : };
      58                 :            : 
      59                 :            : static const struct pci_device_id pci_use_msi[] = {
      60                 :            :         { PCI_DEVICE_SUB(PCI_VENDOR_ID_NETMOS, PCI_DEVICE_ID_NETMOS_9900,
      61                 :            :                          0xA000, 0x1000) },
      62                 :            :         { PCI_DEVICE_SUB(PCI_VENDOR_ID_NETMOS, PCI_DEVICE_ID_NETMOS_9912,
      63                 :            :                          0xA000, 0x1000) },
      64                 :            :         { PCI_DEVICE_SUB(PCI_VENDOR_ID_NETMOS, PCI_DEVICE_ID_NETMOS_9922,
      65                 :            :                          0xA000, 0x1000) },
      66                 :            :         { }
      67                 :            : };
      68                 :            : 
      69                 :            : static int pci_default_setup(struct serial_private*,
      70                 :            :           const struct pciserial_board*, struct uart_8250_port *, int);
      71                 :            : 
      72                 :          0 : static void moan_device(const char *str, struct pci_dev *dev)
      73                 :            : {
      74         [ #  # ]:          0 :         dev_err(&dev->dev,
      75                 :            :                "%s: %s\n"
      76                 :            :                "Please send the output of lspci -vv, this\n"
      77                 :            :                "message (0x%04x,0x%04x,0x%04x,0x%04x), the\n"
      78                 :            :                "manufacturer and name of serial board or\n"
      79                 :            :                "modem board to <linux-serial@vger.kernel.org>.\n",
      80                 :            :                pci_name(dev), str, dev->vendor, dev->device,
      81                 :            :                dev->subsystem_vendor, dev->subsystem_device);
      82                 :          0 : }
      83                 :            : 
      84                 :            : static int
      85                 :            : setup_port(struct serial_private *priv, struct uart_8250_port *port,
      86                 :            :            int bar, int offset, int regshift)
      87                 :            : {
      88                 :            :         struct pci_dev *dev = priv->dev;
      89                 :            : 
      90                 :            :         if (bar >= PCI_STD_NUM_BARS)
      91                 :            :                 return -EINVAL;
      92                 :            : 
      93                 :            :         if (pci_resource_flags(dev, bar) & IORESOURCE_MEM) {
      94                 :            :                 if (!pcim_iomap(dev, bar, 0) && !pcim_iomap_table(dev))
      95                 :            :                         return -ENOMEM;
      96                 :            : 
      97                 :            :                 port->port.iotype = UPIO_MEM;
      98                 :            :                 port->port.iobase = 0;
      99                 :            :                 port->port.mapbase = pci_resource_start(dev, bar) + offset;
     100                 :            :                 port->port.membase = pcim_iomap_table(dev)[bar] + offset;
     101                 :            :                 port->port.regshift = regshift;
     102                 :            :         } else {
     103                 :            :                 port->port.iotype = UPIO_PORT;
     104                 :            :                 port->port.iobase = pci_resource_start(dev, bar) + offset;
     105                 :            :                 port->port.mapbase = 0;
     106                 :            :                 port->port.membase = NULL;
     107                 :            :                 port->port.regshift = 0;
     108                 :            :         }
     109                 :            :         return 0;
     110                 :            : }
     111                 :            : 
     112                 :            : /*
     113                 :            :  * ADDI-DATA GmbH communication cards <info@addi-data.com>
     114                 :            :  */
     115                 :          0 : static int addidata_apci7800_setup(struct serial_private *priv,
     116                 :            :                                 const struct pciserial_board *board,
     117                 :            :                                 struct uart_8250_port *port, int idx)
     118                 :            : {
     119                 :          0 :         unsigned int bar = 0, offset = board->first_offset;
     120                 :          0 :         bar = FL_GET_BASE(board->flags);
     121                 :            : 
     122         [ #  # ]:          0 :         if (idx < 2) {
     123                 :          0 :                 offset += idx * board->uart_offset;
     124         [ #  # ]:          0 :         } else if ((idx >= 2) && (idx < 4)) {
     125                 :          0 :                 bar += 1;
     126                 :          0 :                 offset += ((idx - 2) * board->uart_offset);
     127         [ #  # ]:          0 :         } else if ((idx >= 4) && (idx < 6)) {
     128                 :          0 :                 bar += 2;
     129                 :          0 :                 offset += ((idx - 4) * board->uart_offset);
     130                 :          0 :         } else if (idx >= 6) {
     131                 :          0 :                 bar += 3;
     132                 :          0 :                 offset += ((idx - 6) * board->uart_offset);
     133                 :            :         }
     134                 :            : 
     135                 :          0 :         return setup_port(priv, port, bar, offset, board->reg_shift);
     136                 :            : }
     137                 :            : 
     138                 :            : /*
     139                 :            :  * AFAVLAB uses a different mixture of BARs and offsets
     140                 :            :  * Not that ugly ;) -- HW
     141                 :            :  */
     142                 :            : static int
     143                 :          0 : afavlab_setup(struct serial_private *priv, const struct pciserial_board *board,
     144                 :            :               struct uart_8250_port *port, int idx)
     145                 :            : {
     146                 :          0 :         unsigned int bar, offset = board->first_offset;
     147                 :            : 
     148                 :          0 :         bar = FL_GET_BASE(board->flags);
     149         [ #  # ]:          0 :         if (idx < 4)
     150                 :          0 :                 bar += idx;
     151                 :            :         else {
     152                 :          0 :                 bar = 4;
     153                 :          0 :                 offset += (idx - 4) * board->uart_offset;
     154                 :            :         }
     155                 :            : 
     156                 :          0 :         return setup_port(priv, port, bar, offset, board->reg_shift);
     157                 :            : }
     158                 :            : 
     159                 :            : /*
     160                 :            :  * HP's Remote Management Console.  The Diva chip came in several
     161                 :            :  * different versions.  N-class, L2000 and A500 have two Diva chips, each
     162                 :            :  * with 3 UARTs (the third UART on the second chip is unused).  Superdome
     163                 :            :  * and Keystone have one Diva chip with 3 UARTs.  Some later machines have
     164                 :            :  * one Diva chip, but it has been expanded to 5 UARTs.
     165                 :            :  */
     166                 :          0 : static int pci_hp_diva_init(struct pci_dev *dev)
     167                 :            : {
     168                 :          0 :         int rc = 0;
     169                 :            : 
     170   [ #  #  #  #  :          0 :         switch (dev->subsystem_device) {
                      # ]
     171                 :          0 :         case PCI_DEVICE_ID_HP_DIVA_TOSCA1:
     172                 :            :         case PCI_DEVICE_ID_HP_DIVA_HALFDOME:
     173                 :            :         case PCI_DEVICE_ID_HP_DIVA_KEYSTONE:
     174                 :            :         case PCI_DEVICE_ID_HP_DIVA_EVEREST:
     175                 :          0 :                 rc = 3;
     176                 :          0 :                 break;
     177                 :          0 :         case PCI_DEVICE_ID_HP_DIVA_TOSCA2:
     178                 :          0 :                 rc = 2;
     179                 :          0 :                 break;
     180                 :          0 :         case PCI_DEVICE_ID_HP_DIVA_MAESTRO:
     181                 :          0 :                 rc = 4;
     182                 :          0 :                 break;
     183                 :          0 :         case PCI_DEVICE_ID_HP_DIVA_POWERBAR:
     184                 :            :         case PCI_DEVICE_ID_HP_DIVA_HURRICANE:
     185                 :          0 :                 rc = 1;
     186                 :          0 :                 break;
     187                 :            :         }
     188                 :            : 
     189                 :          0 :         return rc;
     190                 :            : }
     191                 :            : 
     192                 :            : /*
     193                 :            :  * HP's Diva chip puts the 4th/5th serial port further out, and
     194                 :            :  * some serial ports are supposed to be hidden on certain models.
     195                 :            :  */
     196                 :            : static int
     197                 :          0 : pci_hp_diva_setup(struct serial_private *priv,
     198                 :            :                 const struct pciserial_board *board,
     199                 :            :                 struct uart_8250_port *port, int idx)
     200                 :            : {
     201                 :          0 :         unsigned int offset = board->first_offset;
     202                 :          0 :         unsigned int bar = FL_GET_BASE(board->flags);
     203                 :            : 
     204      [ #  #  # ]:          0 :         switch (priv->dev->subsystem_device) {
     205                 :          0 :         case PCI_DEVICE_ID_HP_DIVA_MAESTRO:
     206         [ #  # ]:          0 :                 if (idx == 3)
     207                 :          0 :                         idx++;
     208                 :            :                 break;
     209                 :          0 :         case PCI_DEVICE_ID_HP_DIVA_EVEREST:
     210         [ #  # ]:          0 :                 if (idx > 0)
     211                 :          0 :                         idx++;
     212         [ #  # ]:          0 :                 if (idx > 2)
     213                 :          0 :                         idx++;
     214                 :            :                 break;
     215                 :            :         }
     216         [ #  # ]:          0 :         if (idx > 2)
     217                 :          0 :                 offset = 0x18;
     218                 :            : 
     219                 :          0 :         offset += idx * board->uart_offset;
     220                 :            : 
     221                 :          0 :         return setup_port(priv, port, bar, offset, board->reg_shift);
     222                 :            : }
     223                 :            : 
     224                 :            : /*
     225                 :            :  * Added for EKF Intel i960 serial boards
     226                 :            :  */
     227                 :          0 : static int pci_inteli960ni_init(struct pci_dev *dev)
     228                 :            : {
     229                 :          0 :         u32 oldval;
     230                 :            : 
     231         [ #  # ]:          0 :         if (!(dev->subsystem_device & 0x1000))
     232                 :            :                 return -ENODEV;
     233                 :            : 
     234                 :            :         /* is firmware started? */
     235                 :          0 :         pci_read_config_dword(dev, 0x44, &oldval);
     236         [ #  # ]:          0 :         if (oldval == 0x00001000L) { /* RESET value */
     237                 :          0 :                 dev_dbg(&dev->dev, "Local i960 firmware missing\n");
     238                 :          0 :                 return -ENODEV;
     239                 :            :         }
     240                 :            :         return 0;
     241                 :            : }
     242                 :            : 
     243                 :            : /*
     244                 :            :  * Some PCI serial cards using the PLX 9050 PCI interface chip require
     245                 :            :  * that the card interrupt be explicitly enabled or disabled.  This
     246                 :            :  * seems to be mainly needed on card using the PLX which also use I/O
     247                 :            :  * mapped memory.
     248                 :            :  */
     249                 :          0 : static int pci_plx9050_init(struct pci_dev *dev)
     250                 :            : {
     251                 :          0 :         u8 irq_config;
     252                 :          0 :         void __iomem *p;
     253                 :            : 
     254         [ #  # ]:          0 :         if ((pci_resource_flags(dev, 0) & IORESOURCE_MEM) == 0) {
     255                 :          0 :                 moan_device("no memory in bar 0", dev);
     256                 :          0 :                 return 0;
     257                 :            :         }
     258                 :            : 
     259                 :          0 :         irq_config = 0x41;
     260         [ #  # ]:          0 :         if (dev->vendor == PCI_VENDOR_ID_PANACOM ||
     261         [ #  # ]:          0 :             dev->subsystem_vendor == PCI_SUBVENDOR_ID_EXSYS)
     262                 :          0 :                 irq_config = 0x43;
     263                 :            : 
     264         [ #  # ]:          0 :         if ((dev->vendor == PCI_VENDOR_ID_PLX) &&
     265                 :            :             (dev->device == PCI_DEVICE_ID_PLX_ROMULUS))
     266                 :            :                 /*
     267                 :            :                  * As the megawolf cards have the int pins active
     268                 :            :                  * high, and have 2 UART chips, both ints must be
     269                 :            :                  * enabled on the 9050. Also, the UARTS are set in
     270                 :            :                  * 16450 mode by default, so we have to enable the
     271                 :            :                  * 16C950 'enhanced' mode so that we can use the
     272                 :            :                  * deep FIFOs
     273                 :            :                  */
     274                 :          0 :                 irq_config = 0x5b;
     275                 :            :         /*
     276                 :            :          * enable/disable interrupts
     277                 :            :          */
     278                 :          0 :         p = ioremap(pci_resource_start(dev, 0), 0x80);
     279         [ #  # ]:          0 :         if (p == NULL)
     280                 :            :                 return -ENOMEM;
     281                 :          0 :         writel(irq_config, p + 0x4c);
     282                 :            : 
     283                 :            :         /*
     284                 :            :          * Read the register back to ensure that it took effect.
     285                 :            :          */
     286                 :          0 :         readl(p + 0x4c);
     287                 :          0 :         iounmap(p);
     288                 :            : 
     289                 :          0 :         return 0;
     290                 :            : }
     291                 :            : 
     292                 :          0 : static void pci_plx9050_exit(struct pci_dev *dev)
     293                 :            : {
     294                 :          0 :         u8 __iomem *p;
     295                 :            : 
     296         [ #  # ]:          0 :         if ((pci_resource_flags(dev, 0) & IORESOURCE_MEM) == 0)
     297                 :            :                 return;
     298                 :            : 
     299                 :            :         /*
     300                 :            :          * disable interrupts
     301                 :            :          */
     302                 :          0 :         p = ioremap(pci_resource_start(dev, 0), 0x80);
     303         [ #  # ]:          0 :         if (p != NULL) {
     304                 :          0 :                 writel(0, p + 0x4c);
     305                 :            : 
     306                 :            :                 /*
     307                 :            :                  * Read the register back to ensure that it took effect.
     308                 :            :                  */
     309                 :          0 :                 readl(p + 0x4c);
     310                 :          0 :                 iounmap(p);
     311                 :            :         }
     312                 :            : }
     313                 :            : 
     314                 :            : #define NI8420_INT_ENABLE_REG   0x38
     315                 :            : #define NI8420_INT_ENABLE_BIT   0x2000
     316                 :            : 
     317                 :          0 : static void pci_ni8420_exit(struct pci_dev *dev)
     318                 :            : {
     319                 :          0 :         void __iomem *p;
     320                 :          0 :         unsigned int bar = 0;
     321                 :            : 
     322         [ #  # ]:          0 :         if ((pci_resource_flags(dev, bar) & IORESOURCE_MEM) == 0) {
     323                 :          0 :                 moan_device("no memory in bar", dev);
     324                 :          0 :                 return;
     325                 :            :         }
     326                 :            : 
     327                 :          0 :         p = pci_ioremap_bar(dev, bar);
     328         [ #  # ]:          0 :         if (p == NULL)
     329                 :            :                 return;
     330                 :            : 
     331                 :            :         /* Disable the CPU Interrupt */
     332                 :          0 :         writel(readl(p + NI8420_INT_ENABLE_REG) & ~(NI8420_INT_ENABLE_BIT),
     333                 :          0 :                p + NI8420_INT_ENABLE_REG);
     334                 :          0 :         iounmap(p);
     335                 :            : }
     336                 :            : 
     337                 :            : 
     338                 :            : /* MITE registers */
     339                 :            : #define MITE_IOWBSR1    0xc4
     340                 :            : #define MITE_IOWCR1     0xf4
     341                 :            : #define MITE_LCIMR1     0x08
     342                 :            : #define MITE_LCIMR2     0x10
     343                 :            : 
     344                 :            : #define MITE_LCIMR2_CLR_CPU_IE  (1 << 30)
     345                 :            : 
     346                 :          0 : static void pci_ni8430_exit(struct pci_dev *dev)
     347                 :            : {
     348                 :          0 :         void __iomem *p;
     349                 :          0 :         unsigned int bar = 0;
     350                 :            : 
     351         [ #  # ]:          0 :         if ((pci_resource_flags(dev, bar) & IORESOURCE_MEM) == 0) {
     352                 :          0 :                 moan_device("no memory in bar", dev);
     353                 :          0 :                 return;
     354                 :            :         }
     355                 :            : 
     356                 :          0 :         p = pci_ioremap_bar(dev, bar);
     357         [ #  # ]:          0 :         if (p == NULL)
     358                 :            :                 return;
     359                 :            : 
     360                 :            :         /* Disable the CPU Interrupt */
     361                 :          0 :         writel(MITE_LCIMR2_CLR_CPU_IE, p + MITE_LCIMR2);
     362                 :          0 :         iounmap(p);
     363                 :            : }
     364                 :            : 
     365                 :            : /* SBS Technologies Inc. PMC-OCTPRO and P-OCTAL cards */
     366                 :            : static int
     367                 :          0 : sbs_setup(struct serial_private *priv, const struct pciserial_board *board,
     368                 :            :                 struct uart_8250_port *port, int idx)
     369                 :            : {
     370                 :          0 :         unsigned int bar, offset = board->first_offset;
     371                 :            : 
     372                 :          0 :         bar = 0;
     373                 :            : 
     374         [ #  # ]:          0 :         if (idx < 4) {
     375                 :            :                 /* first four channels map to 0, 0x100, 0x200, 0x300 */
     376                 :          0 :                 offset += idx * board->uart_offset;
     377         [ #  # ]:          0 :         } else if (idx < 8) {
     378                 :            :                 /* last four channels map to 0x1000, 0x1100, 0x1200, 0x1300 */
     379                 :          0 :                 offset += idx * board->uart_offset + 0xC00;
     380                 :            :         } else /* we have only 8 ports on PMC-OCTALPRO */
     381                 :            :                 return 1;
     382                 :            : 
     383                 :          0 :         return setup_port(priv, port, bar, offset, board->reg_shift);
     384                 :            : }
     385                 :            : 
     386                 :            : /*
     387                 :            : * This does initialization for PMC OCTALPRO cards:
     388                 :            : * maps the device memory, resets the UARTs (needed, bc
     389                 :            : * if the module is removed and inserted again, the card
     390                 :            : * is in the sleep mode) and enables global interrupt.
     391                 :            : */
     392                 :            : 
     393                 :            : /* global control register offset for SBS PMC-OctalPro */
     394                 :            : #define OCT_REG_CR_OFF          0x500
     395                 :            : 
     396                 :          0 : static int sbs_init(struct pci_dev *dev)
     397                 :            : {
     398                 :          0 :         u8 __iomem *p;
     399                 :            : 
     400                 :          0 :         p = pci_ioremap_bar(dev, 0);
     401                 :            : 
     402         [ #  # ]:          0 :         if (p == NULL)
     403                 :            :                 return -ENOMEM;
     404                 :            :         /* Set bit-4 Control Register (UART RESET) in to reset the uarts */
     405                 :          0 :         writeb(0x10, p + OCT_REG_CR_OFF);
     406                 :          0 :         udelay(50);
     407                 :          0 :         writeb(0x0, p + OCT_REG_CR_OFF);
     408                 :            : 
     409                 :            :         /* Set bit-2 (INTENABLE) of Control Register */
     410                 :          0 :         writeb(0x4, p + OCT_REG_CR_OFF);
     411                 :          0 :         iounmap(p);
     412                 :            : 
     413                 :          0 :         return 0;
     414                 :            : }
     415                 :            : 
     416                 :            : /*
     417                 :            :  * Disables the global interrupt of PMC-OctalPro
     418                 :            :  */
     419                 :            : 
     420                 :          0 : static void sbs_exit(struct pci_dev *dev)
     421                 :            : {
     422                 :          0 :         u8 __iomem *p;
     423                 :            : 
     424                 :          0 :         p = pci_ioremap_bar(dev, 0);
     425                 :            :         /* FIXME: What if resource_len < OCT_REG_CR_OFF */
     426         [ #  # ]:          0 :         if (p != NULL)
     427                 :          0 :                 writeb(0, p + OCT_REG_CR_OFF);
     428                 :          0 :         iounmap(p);
     429                 :          0 : }
     430                 :            : 
     431                 :            : /*
     432                 :            :  * SIIG serial cards have an PCI interface chip which also controls
     433                 :            :  * the UART clocking frequency. Each UART can be clocked independently
     434                 :            :  * (except cards equipped with 4 UARTs) and initial clocking settings
     435                 :            :  * are stored in the EEPROM chip. It can cause problems because this
     436                 :            :  * version of serial driver doesn't support differently clocked UART's
     437                 :            :  * on single PCI card. To prevent this, initialization functions set
     438                 :            :  * high frequency clocking for all UART's on given card. It is safe (I
     439                 :            :  * hope) because it doesn't touch EEPROM settings to prevent conflicts
     440                 :            :  * with other OSes (like M$ DOS).
     441                 :            :  *
     442                 :            :  *  SIIG support added by Andrey Panin <pazke@donpac.ru>, 10/1999
     443                 :            :  *
     444                 :            :  * There is two family of SIIG serial cards with different PCI
     445                 :            :  * interface chip and different configuration methods:
     446                 :            :  *     - 10x cards have control registers in IO and/or memory space;
     447                 :            :  *     - 20x cards have control registers in standard PCI configuration space.
     448                 :            :  *
     449                 :            :  * Note: all 10x cards have PCI device ids 0x10..
     450                 :            :  *       all 20x cards have PCI device ids 0x20..
     451                 :            :  *
     452                 :            :  * There are also Quartet Serial cards which use Oxford Semiconductor
     453                 :            :  * 16954 quad UART PCI chip clocked by 18.432 MHz quartz.
     454                 :            :  *
     455                 :            :  * Note: some SIIG cards are probed by the parport_serial object.
     456                 :            :  */
     457                 :            : 
     458                 :            : #define PCI_DEVICE_ID_SIIG_1S_10x (PCI_DEVICE_ID_SIIG_1S_10x_550 & 0xfffc)
     459                 :            : #define PCI_DEVICE_ID_SIIG_2S_10x (PCI_DEVICE_ID_SIIG_2S_10x_550 & 0xfff8)
     460                 :            : 
     461                 :            : static int pci_siig10x_init(struct pci_dev *dev)
     462                 :            : {
     463                 :            :         u16 data;
     464                 :            :         void __iomem *p;
     465                 :            : 
     466                 :            :         switch (dev->device & 0xfff8) {
     467                 :            :         case PCI_DEVICE_ID_SIIG_1S_10x: /* 1S */
     468                 :            :                 data = 0xffdf;
     469                 :            :                 break;
     470                 :            :         case PCI_DEVICE_ID_SIIG_2S_10x: /* 2S, 2S1P */
     471                 :            :                 data = 0xf7ff;
     472                 :            :                 break;
     473                 :            :         default:                        /* 1S1P, 4S */
     474                 :            :                 data = 0xfffb;
     475                 :            :                 break;
     476                 :            :         }
     477                 :            : 
     478                 :            :         p = ioremap(pci_resource_start(dev, 0), 0x80);
     479                 :            :         if (p == NULL)
     480                 :            :                 return -ENOMEM;
     481                 :            : 
     482                 :            :         writew(readw(p + 0x28) & data, p + 0x28);
     483                 :            :         readw(p + 0x28);
     484                 :            :         iounmap(p);
     485                 :            :         return 0;
     486                 :            : }
     487                 :            : 
     488                 :            : #define PCI_DEVICE_ID_SIIG_2S_20x (PCI_DEVICE_ID_SIIG_2S_20x_550 & 0xfffc)
     489                 :            : #define PCI_DEVICE_ID_SIIG_2S1P_20x (PCI_DEVICE_ID_SIIG_2S1P_20x_550 & 0xfffc)
     490                 :            : 
     491                 :          0 : static int pci_siig20x_init(struct pci_dev *dev)
     492                 :            : {
     493                 :          0 :         u8 data;
     494                 :            : 
     495                 :            :         /* Change clock frequency for the first UART. */
     496                 :          0 :         pci_read_config_byte(dev, 0x6f, &data);
     497                 :          0 :         pci_write_config_byte(dev, 0x6f, data & 0xef);
     498                 :            : 
     499                 :            :         /* If this card has 2 UART, we have to do the same with second UART. */
     500         [ #  # ]:          0 :         if (((dev->device & 0xfffc) == PCI_DEVICE_ID_SIIG_2S_20x) ||
     501                 :            :             ((dev->device & 0xfffc) == PCI_DEVICE_ID_SIIG_2S1P_20x)) {
     502                 :          0 :                 pci_read_config_byte(dev, 0x73, &data);
     503                 :          0 :                 pci_write_config_byte(dev, 0x73, data & 0xef);
     504                 :            :         }
     505                 :          0 :         return 0;
     506                 :            : }
     507                 :            : 
     508                 :          0 : static int pci_siig_init(struct pci_dev *dev)
     509                 :            : {
     510                 :          0 :         unsigned int type = dev->device & 0xff00;
     511                 :            : 
     512         [ #  # ]:          0 :         if (type == 0x1000)
     513                 :          0 :                 return pci_siig10x_init(dev);
     514         [ #  # ]:          0 :         else if (type == 0x2000)
     515                 :          0 :                 return pci_siig20x_init(dev);
     516                 :            : 
     517                 :          0 :         moan_device("Unknown SIIG card", dev);
     518                 :          0 :         return -ENODEV;
     519                 :            : }
     520                 :            : 
     521                 :          0 : static int pci_siig_setup(struct serial_private *priv,
     522                 :            :                           const struct pciserial_board *board,
     523                 :            :                           struct uart_8250_port *port, int idx)
     524                 :            : {
     525                 :          0 :         unsigned int bar = FL_GET_BASE(board->flags) + idx, offset = 0;
     526                 :            : 
     527         [ #  # ]:          0 :         if (idx > 3) {
     528                 :          0 :                 bar = 4;
     529                 :          0 :                 offset = (idx - 4) * 8;
     530                 :            :         }
     531                 :            : 
     532                 :          0 :         return setup_port(priv, port, bar, offset, 0);
     533                 :            : }
     534                 :            : 
     535                 :            : /*
     536                 :            :  * Timedia has an explosion of boards, and to avoid the PCI table from
     537                 :            :  * growing *huge*, we use this function to collapse some 70 entries
     538                 :            :  * in the PCI table into one, for sanity's and compactness's sake.
     539                 :            :  */
     540                 :            : static const unsigned short timedia_single_port[] = {
     541                 :            :         0x4025, 0x4027, 0x4028, 0x5025, 0x5027, 0
     542                 :            : };
     543                 :            : 
     544                 :            : static const unsigned short timedia_dual_port[] = {
     545                 :            :         0x0002, 0x4036, 0x4037, 0x4038, 0x4078, 0x4079, 0x4085,
     546                 :            :         0x4088, 0x4089, 0x5037, 0x5078, 0x5079, 0x5085, 0x6079,
     547                 :            :         0x7079, 0x8079, 0x8137, 0x8138, 0x8237, 0x8238, 0x9079,
     548                 :            :         0x9137, 0x9138, 0x9237, 0x9238, 0xA079, 0xB079, 0xC079,
     549                 :            :         0xD079, 0
     550                 :            : };
     551                 :            : 
     552                 :            : static const unsigned short timedia_quad_port[] = {
     553                 :            :         0x4055, 0x4056, 0x4095, 0x4096, 0x5056, 0x8156, 0x8157,
     554                 :            :         0x8256, 0x8257, 0x9056, 0x9156, 0x9157, 0x9158, 0x9159,
     555                 :            :         0x9256, 0x9257, 0xA056, 0xA157, 0xA158, 0xA159, 0xB056,
     556                 :            :         0xB157, 0
     557                 :            : };
     558                 :            : 
     559                 :            : static const unsigned short timedia_eight_port[] = {
     560                 :            :         0x4065, 0x4066, 0x5065, 0x5066, 0x8166, 0x9066, 0x9166,
     561                 :            :         0x9167, 0x9168, 0xA066, 0xA167, 0xA168, 0
     562                 :            : };
     563                 :            : 
     564                 :            : static const struct timedia_struct {
     565                 :            :         int num;
     566                 :            :         const unsigned short *ids;
     567                 :            : } timedia_data[] = {
     568                 :            :         { 1, timedia_single_port },
     569                 :            :         { 2, timedia_dual_port },
     570                 :            :         { 4, timedia_quad_port },
     571                 :            :         { 8, timedia_eight_port }
     572                 :            : };
     573                 :            : 
     574                 :            : /*
     575                 :            :  * There are nearly 70 different Timedia/SUNIX PCI serial devices.  Instead of
     576                 :            :  * listing them individually, this driver merely grabs them all with
     577                 :            :  * PCI_ANY_ID.  Some of these devices, however, also feature a parallel port,
     578                 :            :  * and should be left free to be claimed by parport_serial instead.
     579                 :            :  */
     580                 :          0 : static int pci_timedia_probe(struct pci_dev *dev)
     581                 :            : {
     582                 :            :         /*
     583                 :            :          * Check the third digit of the subdevice ID
     584                 :            :          * (0,2,3,5,6: serial only -- 7,8,9: serial + parallel)
     585                 :            :          */
     586         [ #  # ]:          0 :         if ((dev->subsystem_device & 0x00f0) >= 0x70) {
     587                 :          0 :                 dev_info(&dev->dev,
     588                 :            :                         "ignoring Timedia subdevice %04x for parport_serial\n",
     589                 :            :                         dev->subsystem_device);
     590                 :          0 :                 return -ENODEV;
     591                 :            :         }
     592                 :            : 
     593                 :            :         return 0;
     594                 :            : }
     595                 :            : 
     596                 :          0 : static int pci_timedia_init(struct pci_dev *dev)
     597                 :            : {
     598                 :          0 :         const unsigned short *ids;
     599                 :          0 :         int i, j;
     600                 :            : 
     601         [ #  # ]:          0 :         for (i = 0; i < ARRAY_SIZE(timedia_data); i++) {
     602                 :          0 :                 ids = timedia_data[i].ids;
     603         [ #  # ]:          0 :                 for (j = 0; ids[j]; j++)
     604         [ #  # ]:          0 :                         if (dev->subsystem_device == ids[j])
     605                 :          0 :                                 return timedia_data[i].num;
     606                 :            :         }
     607                 :            :         return 0;
     608                 :            : }
     609                 :            : 
     610                 :            : /*
     611                 :            :  * Timedia/SUNIX uses a mixture of BARs and offsets
     612                 :            :  * Ugh, this is ugly as all hell --- TYT
     613                 :            :  */
     614                 :            : static int
     615                 :          0 : pci_timedia_setup(struct serial_private *priv,
     616                 :            :                   const struct pciserial_board *board,
     617                 :            :                   struct uart_8250_port *port, int idx)
     618                 :            : {
     619                 :          0 :         unsigned int bar = 0, offset = board->first_offset;
     620                 :            : 
     621   [ #  #  #  #  :          0 :         switch (idx) {
                      # ]
     622                 :            :         case 0:
     623                 :            :                 bar = 0;
     624                 :            :                 break;
     625                 :          0 :         case 1:
     626                 :          0 :                 offset = board->uart_offset;
     627                 :          0 :                 bar = 0;
     628                 :          0 :                 break;
     629                 :          0 :         case 2:
     630                 :          0 :                 bar = 1;
     631                 :          0 :                 break;
     632                 :          0 :         case 3:
     633                 :          0 :                 offset = board->uart_offset;
     634                 :            :                 /* FALLTHROUGH */
     635                 :          0 :         case 4: /* BAR 2 */
     636                 :            :         case 5: /* BAR 3 */
     637                 :            :         case 6: /* BAR 4 */
     638                 :            :         case 7: /* BAR 5 */
     639                 :          0 :                 bar = idx - 2;
     640                 :            :         }
     641                 :            : 
     642                 :          0 :         return setup_port(priv, port, bar, offset, board->reg_shift);
     643                 :            : }
     644                 :            : 
     645                 :            : /*
     646                 :            :  * Some Titan cards are also a little weird
     647                 :            :  */
     648                 :            : static int
     649                 :          0 : titan_400l_800l_setup(struct serial_private *priv,
     650                 :            :                       const struct pciserial_board *board,
     651                 :            :                       struct uart_8250_port *port, int idx)
     652                 :            : {
     653                 :          0 :         unsigned int bar, offset = board->first_offset;
     654                 :            : 
     655      [ #  #  # ]:          0 :         switch (idx) {
     656                 :            :         case 0:
     657                 :            :                 bar = 1;
     658                 :            :                 break;
     659                 :          0 :         case 1:
     660                 :          0 :                 bar = 2;
     661                 :          0 :                 break;
     662                 :          0 :         default:
     663                 :          0 :                 bar = 4;
     664                 :          0 :                 offset = (idx - 2) * board->uart_offset;
     665                 :            :         }
     666                 :            : 
     667                 :          0 :         return setup_port(priv, port, bar, offset, board->reg_shift);
     668                 :            : }
     669                 :            : 
     670                 :          0 : static int pci_xircom_init(struct pci_dev *dev)
     671                 :            : {
     672                 :          0 :         msleep(100);
     673                 :          0 :         return 0;
     674                 :            : }
     675                 :            : 
     676                 :          0 : static int pci_ni8420_init(struct pci_dev *dev)
     677                 :            : {
     678                 :          0 :         void __iomem *p;
     679                 :          0 :         unsigned int bar = 0;
     680                 :            : 
     681         [ #  # ]:          0 :         if ((pci_resource_flags(dev, bar) & IORESOURCE_MEM) == 0) {
     682                 :          0 :                 moan_device("no memory in bar", dev);
     683                 :          0 :                 return 0;
     684                 :            :         }
     685                 :            : 
     686                 :          0 :         p = pci_ioremap_bar(dev, bar);
     687         [ #  # ]:          0 :         if (p == NULL)
     688                 :            :                 return -ENOMEM;
     689                 :            : 
     690                 :            :         /* Enable CPU Interrupt */
     691                 :          0 :         writel(readl(p + NI8420_INT_ENABLE_REG) | NI8420_INT_ENABLE_BIT,
     692                 :          0 :                p + NI8420_INT_ENABLE_REG);
     693                 :            : 
     694                 :          0 :         iounmap(p);
     695                 :          0 :         return 0;
     696                 :            : }
     697                 :            : 
     698                 :            : #define MITE_IOWBSR1_WSIZE      0xa
     699                 :            : #define MITE_IOWBSR1_WIN_OFFSET 0x800
     700                 :            : #define MITE_IOWBSR1_WENAB      (1 << 7)
     701                 :            : #define MITE_LCIMR1_IO_IE_0     (1 << 24)
     702                 :            : #define MITE_LCIMR2_SET_CPU_IE  (1 << 31)
     703                 :            : #define MITE_IOWCR1_RAMSEL_MASK 0xfffffffe
     704                 :            : 
     705                 :          0 : static int pci_ni8430_init(struct pci_dev *dev)
     706                 :            : {
     707                 :          0 :         void __iomem *p;
     708                 :          0 :         struct pci_bus_region region;
     709                 :          0 :         u32 device_window;
     710                 :          0 :         unsigned int bar = 0;
     711                 :            : 
     712         [ #  # ]:          0 :         if ((pci_resource_flags(dev, bar) & IORESOURCE_MEM) == 0) {
     713                 :          0 :                 moan_device("no memory in bar", dev);
     714                 :          0 :                 return 0;
     715                 :            :         }
     716                 :            : 
     717                 :          0 :         p = pci_ioremap_bar(dev, bar);
     718         [ #  # ]:          0 :         if (p == NULL)
     719                 :            :                 return -ENOMEM;
     720                 :            : 
     721                 :            :         /*
     722                 :            :          * Set device window address and size in BAR0, while acknowledging that
     723                 :            :          * the resource structure may contain a translated address that differs
     724                 :            :          * from the address the device responds to.
     725                 :            :          */
     726                 :          0 :         pcibios_resource_to_bus(dev->bus, &region, &dev->resource[bar]);
     727                 :          0 :         device_window = ((region.start + MITE_IOWBSR1_WIN_OFFSET) & 0xffffff00)
     728                 :            :                         | MITE_IOWBSR1_WENAB | MITE_IOWBSR1_WSIZE;
     729                 :          0 :         writel(device_window, p + MITE_IOWBSR1);
     730                 :            : 
     731                 :            :         /* Set window access to go to RAMSEL IO address space */
     732                 :          0 :         writel((readl(p + MITE_IOWCR1) & MITE_IOWCR1_RAMSEL_MASK),
     733                 :          0 :                p + MITE_IOWCR1);
     734                 :            : 
     735                 :            :         /* Enable IO Bus Interrupt 0 */
     736                 :          0 :         writel(MITE_LCIMR1_IO_IE_0, p + MITE_LCIMR1);
     737                 :            : 
     738                 :            :         /* Enable CPU Interrupt */
     739                 :          0 :         writel(MITE_LCIMR2_SET_CPU_IE, p + MITE_LCIMR2);
     740                 :            : 
     741                 :          0 :         iounmap(p);
     742                 :          0 :         return 0;
     743                 :            : }
     744                 :            : 
     745                 :            : /* UART Port Control Register */
     746                 :            : #define NI8430_PORTCON  0x0f
     747                 :            : #define NI8430_PORTCON_TXVR_ENABLE      (1 << 3)
     748                 :            : 
     749                 :            : static int
     750                 :          0 : pci_ni8430_setup(struct serial_private *priv,
     751                 :            :                  const struct pciserial_board *board,
     752                 :            :                  struct uart_8250_port *port, int idx)
     753                 :            : {
     754                 :          0 :         struct pci_dev *dev = priv->dev;
     755                 :          0 :         void __iomem *p;
     756                 :          0 :         unsigned int bar, offset = board->first_offset;
     757                 :            : 
     758         [ #  # ]:          0 :         if (idx >= board->num_ports)
     759                 :            :                 return 1;
     760                 :            : 
     761                 :          0 :         bar = FL_GET_BASE(board->flags);
     762                 :          0 :         offset += idx * board->uart_offset;
     763                 :            : 
     764                 :          0 :         p = pci_ioremap_bar(dev, bar);
     765         [ #  # ]:          0 :         if (!p)
     766                 :            :                 return -ENOMEM;
     767                 :            : 
     768                 :            :         /* enable the transceiver */
     769                 :          0 :         writeb(readb(p + offset + NI8430_PORTCON) | NI8430_PORTCON_TXVR_ENABLE,
     770                 :          0 :                p + offset + NI8430_PORTCON);
     771                 :            : 
     772                 :          0 :         iounmap(p);
     773                 :            : 
     774                 :          0 :         return setup_port(priv, port, bar, offset, board->reg_shift);
     775                 :            : }
     776                 :            : 
     777                 :          0 : static int pci_netmos_9900_setup(struct serial_private *priv,
     778                 :            :                                 const struct pciserial_board *board,
     779                 :            :                                 struct uart_8250_port *port, int idx)
     780                 :            : {
     781                 :          0 :         unsigned int bar;
     782                 :            : 
     783         [ #  # ]:          0 :         if ((priv->dev->device != PCI_DEVICE_ID_NETMOS_9865) &&
     784         [ #  # ]:          0 :             (priv->dev->subsystem_device & 0xff00) == 0x3000) {
     785                 :            :                 /* netmos apparently orders BARs by datasheet layout, so serial
     786                 :            :                  * ports get BARs 0 and 3 (or 1 and 4 for memmapped)
     787                 :            :                  */
     788                 :          0 :                 bar = 3 * idx;
     789                 :            : 
     790                 :          0 :                 return setup_port(priv, port, bar, 0, board->reg_shift);
     791                 :            :         } else {
     792                 :          0 :                 return pci_default_setup(priv, board, port, idx);
     793                 :            :         }
     794                 :            : }
     795                 :            : 
     796                 :            : /* the 99xx series comes with a range of device IDs and a variety
     797                 :            :  * of capabilities:
     798                 :            :  *
     799                 :            :  * 9900 has varying capabilities and can cascade to sub-controllers
     800                 :            :  *   (cascading should be purely internal)
     801                 :            :  * 9904 is hardwired with 4 serial ports
     802                 :            :  * 9912 and 9922 are hardwired with 2 serial ports
     803                 :            :  */
     804                 :          0 : static int pci_netmos_9900_numports(struct pci_dev *dev)
     805                 :            : {
     806                 :          0 :         unsigned int c = dev->class;
     807                 :          0 :         unsigned int pi;
     808                 :          0 :         unsigned short sub_serports;
     809                 :            : 
     810                 :          0 :         pi = c & 0xff;
     811                 :            : 
     812         [ #  # ]:          0 :         if (pi == 2)
     813                 :            :                 return 1;
     814                 :            : 
     815   [ #  #  #  # ]:          0 :         if ((pi == 0) && (dev->device == PCI_DEVICE_ID_NETMOS_9900)) {
     816                 :            :                 /* two possibilities: 0x30ps encodes number of parallel and
     817                 :            :                  * serial ports, or 0x1000 indicates *something*. This is not
     818                 :            :                  * immediately obvious, since the 2s1p+4s configuration seems
     819                 :            :                  * to offer all functionality on functions 0..2, while still
     820                 :            :                  * advertising the same function 3 as the 4s+2s1p config.
     821                 :            :                  */
     822                 :          0 :                 sub_serports = dev->subsystem_device & 0xf;
     823         [ #  # ]:          0 :                 if (sub_serports > 0)
     824                 :          0 :                         return sub_serports;
     825                 :            : 
     826                 :          0 :                 dev_err(&dev->dev,
     827                 :            :                         "NetMos/Mostech serial driver ignoring port on ambiguous config.\n");
     828                 :          0 :                 return 0;
     829                 :            :         }
     830                 :            : 
     831                 :          0 :         moan_device("unknown NetMos/Mostech program interface", dev);
     832                 :          0 :         return 0;
     833                 :            : }
     834                 :            : 
     835                 :          0 : static int pci_netmos_init(struct pci_dev *dev)
     836                 :            : {
     837                 :            :         /* subdevice 0x00PS means <P> parallel, <S> serial */
     838                 :          0 :         unsigned int num_serial = dev->subsystem_device & 0xf;
     839                 :            : 
     840         [ #  # ]:          0 :         if ((dev->device == PCI_DEVICE_ID_NETMOS_9901) ||
     841                 :            :                 (dev->device == PCI_DEVICE_ID_NETMOS_9865))
     842                 :            :                 return 0;
     843                 :            : 
     844         [ #  # ]:          0 :         if (dev->subsystem_vendor == PCI_VENDOR_ID_IBM &&
     845                 :            :                         dev->subsystem_device == 0x0299)
     846                 :            :                 return 0;
     847                 :            : 
     848         [ #  # ]:          0 :         switch (dev->device) { /* FALLTHROUGH on all */
     849                 :          0 :         case PCI_DEVICE_ID_NETMOS_9904:
     850                 :            :         case PCI_DEVICE_ID_NETMOS_9912:
     851                 :            :         case PCI_DEVICE_ID_NETMOS_9922:
     852                 :            :         case PCI_DEVICE_ID_NETMOS_9900:
     853                 :          0 :                 num_serial = pci_netmos_9900_numports(dev);
     854                 :          0 :                 break;
     855                 :            : 
     856                 :            :         default:
     857                 :            :                 break;
     858                 :            :         }
     859                 :            : 
     860         [ #  # ]:          0 :         if (num_serial == 0) {
     861                 :          0 :                 moan_device("unknown NetMos/Mostech device", dev);
     862                 :          0 :                 return -ENODEV;
     863                 :            :         }
     864                 :            : 
     865                 :          0 :         return num_serial;
     866                 :            : }
     867                 :            : 
     868                 :            : /*
     869                 :            :  * These chips are available with optionally one parallel port and up to
     870                 :            :  * two serial ports. Unfortunately they all have the same product id.
     871                 :            :  *
     872                 :            :  * Basic configuration is done over a region of 32 I/O ports. The base
     873                 :            :  * ioport is called INTA or INTC, depending on docs/other drivers.
     874                 :            :  *
     875                 :            :  * The region of the 32 I/O ports is configured in POSIO0R...
     876                 :            :  */
     877                 :            : 
     878                 :            : /* registers */
     879                 :            : #define ITE_887x_MISCR          0x9c
     880                 :            : #define ITE_887x_INTCBAR        0x78
     881                 :            : #define ITE_887x_UARTBAR        0x7c
     882                 :            : #define ITE_887x_PS0BAR         0x10
     883                 :            : #define ITE_887x_POSIO0         0x60
     884                 :            : 
     885                 :            : /* I/O space size */
     886                 :            : #define ITE_887x_IOSIZE         32
     887                 :            : /* I/O space size (bits 26-24; 8 bytes = 011b) */
     888                 :            : #define ITE_887x_POSIO_IOSIZE_8         (3 << 24)
     889                 :            : /* I/O space size (bits 26-24; 32 bytes = 101b) */
     890                 :            : #define ITE_887x_POSIO_IOSIZE_32        (5 << 24)
     891                 :            : /* Decoding speed (1 = slow, 2 = medium, 3 = fast) */
     892                 :            : #define ITE_887x_POSIO_SPEED            (3 << 29)
     893                 :            : /* enable IO_Space bit */
     894                 :            : #define ITE_887x_POSIO_ENABLE           (1 << 31)
     895                 :            : 
     896                 :          0 : static int pci_ite887x_init(struct pci_dev *dev)
     897                 :            : {
     898                 :            :         /* inta_addr are the configuration addresses of the ITE */
     899                 :          0 :         static const short inta_addr[] = { 0x2a0, 0x2c0, 0x220, 0x240, 0x1e0,
     900                 :            :                                                         0x200, 0x280, 0 };
     901                 :          0 :         int ret, i, type;
     902                 :          0 :         struct resource *iobase = NULL;
     903                 :          0 :         u32 miscr, uartbar, ioport;
     904                 :            : 
     905                 :            :         /* search for the base-ioport */
     906                 :          0 :         i = 0;
     907   [ #  #  #  # ]:          0 :         while (inta_addr[i] && iobase == NULL) {
     908                 :          0 :                 iobase = request_region(inta_addr[i], ITE_887x_IOSIZE,
     909                 :            :                                                                 "ite887x");
     910         [ #  # ]:          0 :                 if (iobase != NULL) {
     911                 :            :                         /* write POSIO0R - speed | size | ioport */
     912                 :          0 :                         pci_write_config_dword(dev, ITE_887x_POSIO0,
     913                 :            :                                 ITE_887x_POSIO_ENABLE | ITE_887x_POSIO_SPEED |
     914                 :          0 :                                 ITE_887x_POSIO_IOSIZE_32 | inta_addr[i]);
     915                 :            :                         /* write INTCBAR - ioport */
     916                 :          0 :                         pci_write_config_dword(dev, ITE_887x_INTCBAR,
     917                 :            :                                                                 inta_addr[i]);
     918                 :          0 :                         ret = inb(inta_addr[i]);
     919         [ #  # ]:          0 :                         if (ret != 0xff) {
     920                 :            :                                 /* ioport connected */
     921                 :            :                                 break;
     922                 :            :                         }
     923                 :          0 :                         release_region(iobase->start, ITE_887x_IOSIZE);
     924                 :          0 :                         iobase = NULL;
     925                 :            :                 }
     926                 :          0 :                 i++;
     927                 :            :         }
     928                 :            : 
     929         [ #  # ]:          0 :         if (!inta_addr[i]) {
     930                 :          0 :                 dev_err(&dev->dev, "ite887x: could not find iobase\n");
     931                 :          0 :                 return -ENODEV;
     932                 :            :         }
     933                 :            : 
     934                 :            :         /* start of undocumented type checking (see parport_pc.c) */
     935                 :          0 :         type = inb(iobase->start + 0x18) & 0x0f;
     936                 :            : 
     937   [ #  #  #  #  :          0 :         switch (type) {
                      # ]
     938                 :            :         case 0x2:       /* ITE8871 (1P) */
     939                 :            :         case 0xa:       /* ITE8875 (1P) */
     940                 :            :                 ret = 0;
     941                 :            :                 break;
     942                 :          0 :         case 0xe:       /* ITE8872 (2S1P) */
     943                 :          0 :                 ret = 2;
     944                 :          0 :                 break;
     945                 :          0 :         case 0x6:       /* ITE8873 (1S) */
     946                 :          0 :                 ret = 1;
     947                 :          0 :                 break;
     948                 :          0 :         case 0x8:       /* ITE8874 (2S) */
     949                 :          0 :                 ret = 2;
     950                 :          0 :                 break;
     951                 :          0 :         default:
     952                 :          0 :                 moan_device("Unknown ITE887x", dev);
     953                 :          0 :                 ret = -ENODEV;
     954                 :            :         }
     955                 :            : 
     956                 :            :         /* configure all serial ports */
     957         [ #  # ]:          0 :         for (i = 0; i < ret; i++) {
     958                 :            :                 /* read the I/O port from the device */
     959                 :          0 :                 pci_read_config_dword(dev, ITE_887x_PS0BAR + (0x4 * (i + 1)),
     960                 :            :                                                                 &ioport);
     961                 :          0 :                 ioport &= 0x0000FF00;       /* the actual base address */
     962                 :          0 :                 pci_write_config_dword(dev, ITE_887x_POSIO0 + (0x4 * (i + 1)),
     963                 :            :                         ITE_887x_POSIO_ENABLE | ITE_887x_POSIO_SPEED |
     964                 :            :                         ITE_887x_POSIO_IOSIZE_8 | ioport);
     965                 :            : 
     966                 :            :                 /* write the ioport to the UARTBAR */
     967                 :          0 :                 pci_read_config_dword(dev, ITE_887x_UARTBAR, &uartbar);
     968                 :          0 :                 uartbar &= ~(0xffff << (16 * i));     /* clear half the reg */
     969                 :          0 :                 uartbar |= (ioport << (16 * i));  /* set the ioport */
     970                 :          0 :                 pci_write_config_dword(dev, ITE_887x_UARTBAR, uartbar);
     971                 :            : 
     972                 :            :                 /* get current config */
     973                 :          0 :                 pci_read_config_dword(dev, ITE_887x_MISCR, &miscr);
     974                 :            :                 /* disable interrupts (UARTx_Routing[3:0]) */
     975                 :          0 :                 miscr &= ~(0xf << (12 - 4 * i));
     976                 :            :                 /* activate the UART (UARTx_En) */
     977                 :          0 :                 miscr |= 1 << (23 - i);
     978                 :            :                 /* write new config with activated UART */
     979                 :          0 :                 pci_write_config_dword(dev, ITE_887x_MISCR, miscr);
     980                 :            :         }
     981                 :            : 
     982         [ #  # ]:          0 :         if (ret <= 0) {
     983                 :            :                 /* the device has no UARTs if we get here */
     984                 :          0 :                 release_region(iobase->start, ITE_887x_IOSIZE);
     985                 :            :         }
     986                 :            : 
     987                 :            :         return ret;
     988                 :            : }
     989                 :            : 
     990                 :          0 : static void pci_ite887x_exit(struct pci_dev *dev)
     991                 :            : {
     992                 :          0 :         u32 ioport;
     993                 :            :         /* the ioport is bit 0-15 in POSIO0R */
     994                 :          0 :         pci_read_config_dword(dev, ITE_887x_POSIO0, &ioport);
     995                 :          0 :         ioport &= 0xffff;
     996                 :          0 :         release_region(ioport, ITE_887x_IOSIZE);
     997                 :          0 : }
     998                 :            : 
     999                 :            : /*
    1000                 :            :  * EndRun Technologies.
    1001                 :            :  * Determine the number of ports available on the device.
    1002                 :            :  */
    1003                 :            : #define PCI_VENDOR_ID_ENDRUN                    0x7401
    1004                 :            : #define PCI_DEVICE_ID_ENDRUN_1588       0xe100
    1005                 :            : 
    1006                 :          0 : static int pci_endrun_init(struct pci_dev *dev)
    1007                 :            : {
    1008                 :          0 :         u8 __iomem *p;
    1009                 :          0 :         unsigned long deviceID;
    1010                 :          0 :         unsigned int  number_uarts = 0;
    1011                 :            : 
    1012                 :            :         /* EndRun device is all 0xexxx */
    1013         [ #  # ]:          0 :         if (dev->vendor == PCI_VENDOR_ID_ENDRUN &&
    1014         [ #  # ]:          0 :                 (dev->device & 0xf000) != 0xe000)
    1015                 :            :                 return 0;
    1016                 :            : 
    1017                 :          0 :         p = pci_iomap(dev, 0, 5);
    1018         [ #  # ]:          0 :         if (p == NULL)
    1019                 :            :                 return -ENOMEM;
    1020                 :            : 
    1021                 :          0 :         deviceID = ioread32(p);
    1022                 :            :         /* EndRun device */
    1023         [ #  # ]:          0 :         if (deviceID == 0x07000200) {
    1024                 :          0 :                 number_uarts = ioread8(p + 4);
    1025                 :          0 :                 dev_dbg(&dev->dev,
    1026                 :            :                         "%d ports detected on EndRun PCI Express device\n",
    1027                 :            :                         number_uarts);
    1028                 :            :         }
    1029                 :          0 :         pci_iounmap(dev, p);
    1030                 :          0 :         return number_uarts;
    1031                 :            : }
    1032                 :            : 
    1033                 :            : /*
    1034                 :            :  * Oxford Semiconductor Inc.
    1035                 :            :  * Check that device is part of the Tornado range of devices, then determine
    1036                 :            :  * the number of ports available on the device.
    1037                 :            :  */
    1038                 :          0 : static int pci_oxsemi_tornado_init(struct pci_dev *dev)
    1039                 :            : {
    1040                 :          0 :         u8 __iomem *p;
    1041                 :          0 :         unsigned long deviceID;
    1042                 :          0 :         unsigned int  number_uarts = 0;
    1043                 :            : 
    1044                 :            :         /* OxSemi Tornado devices are all 0xCxxx */
    1045         [ #  # ]:          0 :         if (dev->vendor == PCI_VENDOR_ID_OXSEMI &&
    1046         [ #  # ]:          0 :             (dev->device & 0xF000) != 0xC000)
    1047                 :            :                 return 0;
    1048                 :            : 
    1049                 :          0 :         p = pci_iomap(dev, 0, 5);
    1050         [ #  # ]:          0 :         if (p == NULL)
    1051                 :            :                 return -ENOMEM;
    1052                 :            : 
    1053                 :          0 :         deviceID = ioread32(p);
    1054                 :            :         /* Tornado device */
    1055         [ #  # ]:          0 :         if (deviceID == 0x07000200) {
    1056                 :          0 :                 number_uarts = ioread8(p + 4);
    1057                 :          0 :                 dev_dbg(&dev->dev,
    1058                 :            :                         "%d ports detected on Oxford PCI Express device\n",
    1059                 :            :                         number_uarts);
    1060                 :            :         }
    1061                 :          0 :         pci_iounmap(dev, p);
    1062                 :          0 :         return number_uarts;
    1063                 :            : }
    1064                 :            : 
    1065                 :          0 : static int pci_asix_setup(struct serial_private *priv,
    1066                 :            :                   const struct pciserial_board *board,
    1067                 :            :                   struct uart_8250_port *port, int idx)
    1068                 :            : {
    1069                 :          0 :         port->bugs |= UART_BUG_PARITY;
    1070                 :          0 :         return pci_default_setup(priv, board, port, idx);
    1071                 :            : }
    1072                 :            : 
    1073                 :            : /* Quatech devices have their own extra interface features */
    1074                 :            : 
    1075                 :            : struct quatech_feature {
    1076                 :            :         u16 devid;
    1077                 :            :         bool amcc;
    1078                 :            : };
    1079                 :            : 
    1080                 :            : #define QPCR_TEST_FOR1          0x3F
    1081                 :            : #define QPCR_TEST_GET1          0x00
    1082                 :            : #define QPCR_TEST_FOR2          0x40
    1083                 :            : #define QPCR_TEST_GET2          0x40
    1084                 :            : #define QPCR_TEST_FOR3          0x80
    1085                 :            : #define QPCR_TEST_GET3          0x40
    1086                 :            : #define QPCR_TEST_FOR4          0xC0
    1087                 :            : #define QPCR_TEST_GET4          0x80
    1088                 :            : 
    1089                 :            : #define QOPR_CLOCK_X1           0x0000
    1090                 :            : #define QOPR_CLOCK_X2           0x0001
    1091                 :            : #define QOPR_CLOCK_X4           0x0002
    1092                 :            : #define QOPR_CLOCK_X8           0x0003
    1093                 :            : #define QOPR_CLOCK_RATE_MASK    0x0003
    1094                 :            : 
    1095                 :            : 
    1096                 :            : static struct quatech_feature quatech_cards[] = {
    1097                 :            :         { PCI_DEVICE_ID_QUATECH_QSC100,   1 },
    1098                 :            :         { PCI_DEVICE_ID_QUATECH_DSC100,   1 },
    1099                 :            :         { PCI_DEVICE_ID_QUATECH_DSC100E,  0 },
    1100                 :            :         { PCI_DEVICE_ID_QUATECH_DSC200,   1 },
    1101                 :            :         { PCI_DEVICE_ID_QUATECH_DSC200E,  0 },
    1102                 :            :         { PCI_DEVICE_ID_QUATECH_ESC100D,  1 },
    1103                 :            :         { PCI_DEVICE_ID_QUATECH_ESC100M,  1 },
    1104                 :            :         { PCI_DEVICE_ID_QUATECH_QSCP100,  1 },
    1105                 :            :         { PCI_DEVICE_ID_QUATECH_DSCP100,  1 },
    1106                 :            :         { PCI_DEVICE_ID_QUATECH_QSCP200,  1 },
    1107                 :            :         { PCI_DEVICE_ID_QUATECH_DSCP200,  1 },
    1108                 :            :         { PCI_DEVICE_ID_QUATECH_ESCLP100, 0 },
    1109                 :            :         { PCI_DEVICE_ID_QUATECH_QSCLP100, 0 },
    1110                 :            :         { PCI_DEVICE_ID_QUATECH_DSCLP100, 0 },
    1111                 :            :         { PCI_DEVICE_ID_QUATECH_SSCLP100, 0 },
    1112                 :            :         { PCI_DEVICE_ID_QUATECH_QSCLP200, 0 },
    1113                 :            :         { PCI_DEVICE_ID_QUATECH_DSCLP200, 0 },
    1114                 :            :         { PCI_DEVICE_ID_QUATECH_SSCLP200, 0 },
    1115                 :            :         { PCI_DEVICE_ID_QUATECH_SPPXP_100, 0 },
    1116                 :            :         { 0, }
    1117                 :            : };
    1118                 :            : 
    1119                 :          0 : static int pci_quatech_amcc(u16 devid)
    1120                 :            : {
    1121                 :          0 :         struct quatech_feature *qf = &quatech_cards[0];
    1122         [ #  # ]:          0 :         while (qf->devid) {
    1123         [ #  # ]:          0 :                 if (qf->devid == devid)
    1124                 :          0 :                         return qf->amcc;
    1125                 :          0 :                 qf++;
    1126                 :            :         }
    1127                 :          0 :         pr_err("quatech: unknown port type '0x%04X'.\n", devid);
    1128                 :          0 :         return 0;
    1129                 :            : };
    1130                 :            : 
    1131                 :          0 : static int pci_quatech_rqopr(struct uart_8250_port *port)
    1132                 :            : {
    1133                 :          0 :         unsigned long base = port->port.iobase;
    1134                 :          0 :         u8 LCR, val;
    1135                 :            : 
    1136                 :          0 :         LCR = inb(base + UART_LCR);
    1137                 :          0 :         outb(0xBF, base + UART_LCR);
    1138                 :          0 :         val = inb(base + UART_SCR);
    1139                 :          0 :         outb(LCR, base + UART_LCR);
    1140                 :          0 :         return val;
    1141                 :            : }
    1142                 :            : 
    1143                 :          0 : static void pci_quatech_wqopr(struct uart_8250_port *port, u8 qopr)
    1144                 :            : {
    1145                 :          0 :         unsigned long base = port->port.iobase;
    1146                 :          0 :         u8 LCR;
    1147                 :            : 
    1148                 :          0 :         LCR = inb(base + UART_LCR);
    1149                 :          0 :         outb(0xBF, base + UART_LCR);
    1150                 :          0 :         inb(base + UART_SCR);
    1151                 :          0 :         outb(qopr, base + UART_SCR);
    1152                 :          0 :         outb(LCR, base + UART_LCR);
    1153                 :            : }
    1154                 :            : 
    1155                 :          0 : static int pci_quatech_rqmcr(struct uart_8250_port *port)
    1156                 :            : {
    1157                 :          0 :         unsigned long base = port->port.iobase;
    1158                 :          0 :         u8 LCR, val, qmcr;
    1159                 :            : 
    1160                 :          0 :         LCR = inb(base + UART_LCR);
    1161                 :          0 :         outb(0xBF, base + UART_LCR);
    1162                 :          0 :         val = inb(base + UART_SCR);
    1163                 :          0 :         outb(val | 0x10, base + UART_SCR);
    1164                 :          0 :         qmcr = inb(base + UART_MCR);
    1165                 :          0 :         outb(val, base + UART_SCR);
    1166                 :          0 :         outb(LCR, base + UART_LCR);
    1167                 :            : 
    1168                 :          0 :         return qmcr;
    1169                 :            : }
    1170                 :            : 
    1171                 :          0 : static void pci_quatech_wqmcr(struct uart_8250_port *port, u8 qmcr)
    1172                 :            : {
    1173                 :          0 :         unsigned long base = port->port.iobase;
    1174                 :          0 :         u8 LCR, val;
    1175                 :            : 
    1176                 :          0 :         LCR = inb(base + UART_LCR);
    1177                 :          0 :         outb(0xBF, base + UART_LCR);
    1178                 :          0 :         val = inb(base + UART_SCR);
    1179                 :          0 :         outb(val | 0x10, base + UART_SCR);
    1180                 :          0 :         outb(qmcr, base + UART_MCR);
    1181                 :          0 :         outb(val, base + UART_SCR);
    1182                 :          0 :         outb(LCR, base + UART_LCR);
    1183                 :            : }
    1184                 :            : 
    1185                 :          0 : static int pci_quatech_has_qmcr(struct uart_8250_port *port)
    1186                 :            : {
    1187                 :          0 :         unsigned long base = port->port.iobase;
    1188                 :          0 :         u8 LCR, val;
    1189                 :            : 
    1190                 :          0 :         LCR = inb(base + UART_LCR);
    1191                 :          0 :         outb(0xBF, base + UART_LCR);
    1192                 :          0 :         val = inb(base + UART_SCR);
    1193         [ #  # ]:          0 :         if (val & 0x20) {
    1194                 :          0 :                 outb(0x80, UART_LCR);
    1195         [ #  # ]:          0 :                 if (!(inb(UART_SCR) & 0x20)) {
    1196                 :          0 :                         outb(LCR, base + UART_LCR);
    1197                 :          0 :                         return 1;
    1198                 :            :                 }
    1199                 :            :         }
    1200                 :            :         return 0;
    1201                 :            : }
    1202                 :            : 
    1203                 :          0 : static int pci_quatech_test(struct uart_8250_port *port)
    1204                 :            : {
    1205                 :          0 :         u8 reg, qopr;
    1206                 :            : 
    1207                 :          0 :         qopr = pci_quatech_rqopr(port);
    1208                 :          0 :         pci_quatech_wqopr(port, qopr & QPCR_TEST_FOR1);
    1209                 :          0 :         reg = pci_quatech_rqopr(port) & 0xC0;
    1210         [ #  # ]:          0 :         if (reg != QPCR_TEST_GET1)
    1211                 :            :                 return -EINVAL;
    1212                 :          0 :         pci_quatech_wqopr(port, (qopr & QPCR_TEST_FOR1)|QPCR_TEST_FOR2);
    1213                 :          0 :         reg = pci_quatech_rqopr(port) & 0xC0;
    1214         [ #  # ]:          0 :         if (reg != QPCR_TEST_GET2)
    1215                 :            :                 return -EINVAL;
    1216                 :          0 :         pci_quatech_wqopr(port, (qopr & QPCR_TEST_FOR1)|QPCR_TEST_FOR3);
    1217                 :          0 :         reg = pci_quatech_rqopr(port) & 0xC0;
    1218         [ #  # ]:          0 :         if (reg != QPCR_TEST_GET3)
    1219                 :            :                 return -EINVAL;
    1220                 :          0 :         pci_quatech_wqopr(port, (qopr & QPCR_TEST_FOR1)|QPCR_TEST_FOR4);
    1221                 :          0 :         reg = pci_quatech_rqopr(port) & 0xC0;
    1222         [ #  # ]:          0 :         if (reg != QPCR_TEST_GET4)
    1223                 :            :                 return -EINVAL;
    1224                 :            : 
    1225                 :          0 :         pci_quatech_wqopr(port, qopr);
    1226                 :          0 :         return 0;
    1227                 :            : }
    1228                 :            : 
    1229                 :          0 : static int pci_quatech_clock(struct uart_8250_port *port)
    1230                 :            : {
    1231                 :          0 :         u8 qopr, reg, set;
    1232                 :          0 :         unsigned long clock;
    1233                 :            : 
    1234         [ #  # ]:          0 :         if (pci_quatech_test(port) < 0)
    1235                 :            :                 return 1843200;
    1236                 :            : 
    1237                 :          0 :         qopr = pci_quatech_rqopr(port);
    1238                 :            : 
    1239                 :          0 :         pci_quatech_wqopr(port, qopr & ~QOPR_CLOCK_X8);
    1240                 :          0 :         reg = pci_quatech_rqopr(port);
    1241         [ #  # ]:          0 :         if (reg & QOPR_CLOCK_X8) {
    1242                 :          0 :                 clock = 1843200;
    1243                 :          0 :                 goto out;
    1244                 :            :         }
    1245                 :          0 :         pci_quatech_wqopr(port, qopr | QOPR_CLOCK_X8);
    1246                 :          0 :         reg = pci_quatech_rqopr(port);
    1247         [ #  # ]:          0 :         if (!(reg & QOPR_CLOCK_X8)) {
    1248                 :          0 :                 clock = 1843200;
    1249                 :          0 :                 goto out;
    1250                 :            :         }
    1251                 :          0 :         reg &= QOPR_CLOCK_X8;
    1252         [ #  # ]:          0 :         if (reg == QOPR_CLOCK_X2) {
    1253                 :            :                 clock =  3685400;
    1254                 :            :                 set = QOPR_CLOCK_X2;
    1255         [ #  # ]:          0 :         } else if (reg == QOPR_CLOCK_X4) {
    1256                 :            :                 clock = 7372800;
    1257                 :            :                 set = QOPR_CLOCK_X4;
    1258                 :          0 :         } else if (reg == QOPR_CLOCK_X8) {
    1259                 :            :                 clock = 14745600;
    1260                 :            :                 set = QOPR_CLOCK_X8;
    1261                 :            :         } else {
    1262                 :            :                 clock = 1843200;
    1263                 :            :                 set = QOPR_CLOCK_X1;
    1264                 :            :         }
    1265                 :          0 :         qopr &= ~QOPR_CLOCK_RATE_MASK;
    1266                 :          0 :         qopr |= set;
    1267                 :            : 
    1268                 :          0 : out:
    1269                 :          0 :         pci_quatech_wqopr(port, qopr);
    1270                 :          0 :         return clock;
    1271                 :            : }
    1272                 :            : 
    1273                 :          0 : static int pci_quatech_rs422(struct uart_8250_port *port)
    1274                 :            : {
    1275                 :          0 :         u8 qmcr;
    1276                 :          0 :         int rs422 = 0;
    1277                 :            : 
    1278                 :          0 :         if (!pci_quatech_has_qmcr(port))
    1279                 :            :                 return 0;
    1280                 :          0 :         qmcr = pci_quatech_rqmcr(port);
    1281                 :          0 :         pci_quatech_wqmcr(port, 0xFF);
    1282         [ #  # ]:          0 :         if (pci_quatech_rqmcr(port))
    1283                 :          0 :                 rs422 = 1;
    1284                 :          0 :         pci_quatech_wqmcr(port, qmcr);
    1285                 :          0 :         return rs422;
    1286                 :            : }
    1287                 :            : 
    1288                 :          0 : static int pci_quatech_init(struct pci_dev *dev)
    1289                 :            : {
    1290         [ #  # ]:          0 :         if (pci_quatech_amcc(dev->device)) {
    1291                 :          0 :                 unsigned long base = pci_resource_start(dev, 0);
    1292         [ #  # ]:          0 :                 if (base) {
    1293                 :          0 :                         u32 tmp;
    1294                 :            : 
    1295                 :          0 :                         outl(inl(base + 0x38) | 0x00002000, base + 0x38);
    1296                 :          0 :                         tmp = inl(base + 0x3c);
    1297                 :          0 :                         outl(tmp | 0x01000000, base + 0x3c);
    1298                 :          0 :                         outl(tmp &= ~0x01000000, base + 0x3c);
    1299                 :            :                 }
    1300                 :            :         }
    1301                 :          0 :         return 0;
    1302                 :            : }
    1303                 :            : 
    1304                 :          0 : static int pci_quatech_setup(struct serial_private *priv,
    1305                 :            :                   const struct pciserial_board *board,
    1306                 :            :                   struct uart_8250_port *port, int idx)
    1307                 :            : {
    1308                 :            :         /* Needed by pci_quatech calls below */
    1309                 :          0 :         port->port.iobase = pci_resource_start(priv->dev, FL_GET_BASE(board->flags));
    1310                 :            :         /* Set up the clocking */
    1311                 :          0 :         port->port.uartclk = pci_quatech_clock(port);
    1312                 :            :         /* For now just warn about RS422 */
    1313         [ #  # ]:          0 :         if (pci_quatech_rs422(port))
    1314                 :          0 :                 pr_warn("quatech: software control of RS422 features not currently supported.\n");
    1315                 :          0 :         return pci_default_setup(priv, board, port, idx);
    1316                 :            : }
    1317                 :            : 
    1318                 :          0 : static void pci_quatech_exit(struct pci_dev *dev)
    1319                 :            : {
    1320                 :          0 : }
    1321                 :            : 
    1322                 :          0 : static int pci_default_setup(struct serial_private *priv,
    1323                 :            :                   const struct pciserial_board *board,
    1324                 :            :                   struct uart_8250_port *port, int idx)
    1325                 :            : {
    1326                 :          0 :         unsigned int bar, offset = board->first_offset, maxnr;
    1327                 :            : 
    1328                 :          0 :         bar = FL_GET_BASE(board->flags);
    1329         [ #  # ]:          0 :         if (board->flags & FL_BASE_BARS)
    1330                 :          0 :                 bar += idx;
    1331                 :            :         else
    1332                 :          0 :                 offset += idx * board->uart_offset;
    1333                 :            : 
    1334   [ #  #  #  # ]:          0 :         maxnr = (pci_resource_len(priv->dev, bar) - board->first_offset) >>
    1335                 :          0 :                 (board->reg_shift + 3);
    1336                 :            : 
    1337   [ #  #  #  # ]:          0 :         if (board->flags & FL_REGION_SZ_CAP && idx >= maxnr)
    1338                 :            :                 return 1;
    1339                 :            : 
    1340                 :          0 :         return setup_port(priv, port, bar, offset, board->reg_shift);
    1341                 :            : }
    1342                 :            : static void
    1343                 :          0 : pericom_do_set_divisor(struct uart_port *port, unsigned int baud,
    1344                 :            :                                unsigned int quot, unsigned int quot_frac)
    1345                 :            : {
    1346                 :          0 :         int scr;
    1347                 :          0 :         int lcr;
    1348                 :          0 :         int actual_baud;
    1349                 :          0 :         int tolerance;
    1350                 :            : 
    1351         [ #  # ]:          0 :         for (scr = 5 ; scr <= 15 ; scr++) {
    1352                 :          0 :                 actual_baud = 921600 * 16 / scr;
    1353                 :          0 :                 tolerance = actual_baud / 50;
    1354                 :            : 
    1355         [ #  # ]:          0 :                 if ((baud < actual_baud + tolerance) &&
    1356         [ #  # ]:          0 :                         (baud > actual_baud - tolerance)) {
    1357                 :            : 
    1358                 :          0 :                         lcr = serial_port_in(port, UART_LCR);
    1359                 :          0 :                         serial_port_out(port, UART_LCR, lcr | 0x80);
    1360                 :            : 
    1361                 :          0 :                         serial_port_out(port, UART_DLL, 1);
    1362                 :          0 :                         serial_port_out(port, UART_DLM, 0);
    1363                 :          0 :                         serial_port_out(port, 2, 16 - scr);
    1364                 :          0 :                         serial_port_out(port, UART_LCR, lcr);
    1365                 :          0 :                         return;
    1366         [ #  # ]:          0 :                 } else if (baud > actual_baud) {
    1367                 :            :                         break;
    1368                 :            :                 }
    1369                 :            :         }
    1370                 :          0 :         serial8250_do_set_divisor(port, baud, quot, quot_frac);
    1371                 :            : }
    1372                 :          0 : static int pci_pericom_setup(struct serial_private *priv,
    1373                 :            :                   const struct pciserial_board *board,
    1374                 :            :                   struct uart_8250_port *port, int idx)
    1375                 :            : {
    1376                 :          0 :         unsigned int bar, offset = board->first_offset, maxnr;
    1377                 :            : 
    1378                 :          0 :         bar = FL_GET_BASE(board->flags);
    1379         [ #  # ]:          0 :         if (board->flags & FL_BASE_BARS)
    1380                 :          0 :                 bar += idx;
    1381                 :            :         else
    1382                 :          0 :                 offset += idx * board->uart_offset;
    1383                 :            : 
    1384                 :            : 
    1385   [ #  #  #  # ]:          0 :         maxnr = (pci_resource_len(priv->dev, bar) - board->first_offset) >>
    1386                 :          0 :                 (board->reg_shift + 3);
    1387                 :            : 
    1388   [ #  #  #  # ]:          0 :         if (board->flags & FL_REGION_SZ_CAP && idx >= maxnr)
    1389                 :            :                 return 1;
    1390                 :            : 
    1391                 :          0 :         port->port.set_divisor = pericom_do_set_divisor;
    1392                 :            : 
    1393                 :          0 :         return setup_port(priv, port, bar, offset, board->reg_shift);
    1394                 :            : }
    1395                 :            : 
    1396                 :          0 : static int pci_pericom_setup_four_at_eight(struct serial_private *priv,
    1397                 :            :                   const struct pciserial_board *board,
    1398                 :            :                   struct uart_8250_port *port, int idx)
    1399                 :            : {
    1400                 :          0 :         unsigned int bar, offset = board->first_offset, maxnr;
    1401                 :            : 
    1402                 :          0 :         bar = FL_GET_BASE(board->flags);
    1403         [ #  # ]:          0 :         if (board->flags & FL_BASE_BARS)
    1404                 :          0 :                 bar += idx;
    1405                 :            :         else
    1406                 :          0 :                 offset += idx * board->uart_offset;
    1407                 :            : 
    1408         [ #  # ]:          0 :         if (idx==3)
    1409                 :          0 :                 offset = 0x38;
    1410                 :            : 
    1411   [ #  #  #  # ]:          0 :         maxnr = (pci_resource_len(priv->dev, bar) - board->first_offset) >>
    1412                 :          0 :                 (board->reg_shift + 3);
    1413                 :            : 
    1414   [ #  #  #  # ]:          0 :         if (board->flags & FL_REGION_SZ_CAP && idx >= maxnr)
    1415                 :            :                 return 1;
    1416                 :            : 
    1417                 :          0 :         port->port.set_divisor = pericom_do_set_divisor;
    1418                 :            : 
    1419                 :          0 :         return setup_port(priv, port, bar, offset, board->reg_shift);
    1420                 :            : }
    1421                 :            : 
    1422                 :            : static int
    1423                 :          0 : ce4100_serial_setup(struct serial_private *priv,
    1424                 :            :                   const struct pciserial_board *board,
    1425                 :            :                   struct uart_8250_port *port, int idx)
    1426                 :            : {
    1427                 :          0 :         int ret;
    1428                 :            : 
    1429                 :          0 :         ret = setup_port(priv, port, idx, 0, board->reg_shift);
    1430                 :          0 :         port->port.iotype = UPIO_MEM32;
    1431                 :          0 :         port->port.type = PORT_XSCALE;
    1432                 :          0 :         port->port.flags = (port->port.flags | UPF_FIXED_PORT | UPF_FIXED_TYPE);
    1433                 :          0 :         port->port.regshift = 2;
    1434                 :            : 
    1435                 :          0 :         return ret;
    1436                 :            : }
    1437                 :            : 
    1438                 :            : static int
    1439                 :          0 : pci_omegapci_setup(struct serial_private *priv,
    1440                 :            :                       const struct pciserial_board *board,
    1441                 :            :                       struct uart_8250_port *port, int idx)
    1442                 :            : {
    1443                 :          0 :         return setup_port(priv, port, 2, idx * 8, 0);
    1444                 :            : }
    1445                 :            : 
    1446                 :            : static int
    1447                 :          0 : pci_brcm_trumanage_setup(struct serial_private *priv,
    1448                 :            :                          const struct pciserial_board *board,
    1449                 :            :                          struct uart_8250_port *port, int idx)
    1450                 :            : {
    1451                 :          0 :         int ret = pci_default_setup(priv, board, port, idx);
    1452                 :            : 
    1453                 :          0 :         port->port.type = PORT_BRCM_TRUMANAGE;
    1454                 :          0 :         port->port.flags = (port->port.flags | UPF_FIXED_PORT | UPF_FIXED_TYPE);
    1455                 :          0 :         return ret;
    1456                 :            : }
    1457                 :            : 
    1458                 :            : /* RTS will control by MCR if this bit is 0 */
    1459                 :            : #define FINTEK_RTS_CONTROL_BY_HW        BIT(4)
    1460                 :            : /* only worked with FINTEK_RTS_CONTROL_BY_HW on */
    1461                 :            : #define FINTEK_RTS_INVERT               BIT(5)
    1462                 :            : 
    1463                 :            : /* We should do proper H/W transceiver setting before change to RS485 mode */
    1464                 :          0 : static int pci_fintek_rs485_config(struct uart_port *port,
    1465                 :            :                                struct serial_rs485 *rs485)
    1466                 :            : {
    1467                 :          0 :         struct pci_dev *pci_dev = to_pci_dev(port->dev);
    1468                 :          0 :         u8 setting;
    1469                 :          0 :         u8 *index = (u8 *) port->private_data;
    1470                 :            : 
    1471                 :          0 :         pci_read_config_byte(pci_dev, 0x40 + 8 * *index + 7, &setting);
    1472                 :            : 
    1473         [ #  # ]:          0 :         if (!rs485)
    1474                 :          0 :                 rs485 = &port->rs485;
    1475         [ #  # ]:          0 :         else if (rs485->flags & SER_RS485_ENABLED)
    1476                 :          0 :                 memset(rs485->padding, 0, sizeof(rs485->padding));
    1477                 :            :         else
    1478                 :          0 :                 memset(rs485, 0, sizeof(*rs485));
    1479                 :            : 
    1480                 :            :         /* F81504/508/512 not support RTS delay before or after send */
    1481                 :          0 :         rs485->flags &= SER_RS485_ENABLED | SER_RS485_RTS_ON_SEND;
    1482                 :            : 
    1483         [ #  # ]:          0 :         if (rs485->flags & SER_RS485_ENABLED) {
    1484                 :            :                 /* Enable RTS H/W control mode */
    1485                 :          0 :                 setting |= FINTEK_RTS_CONTROL_BY_HW;
    1486                 :            : 
    1487         [ #  # ]:          0 :                 if (rs485->flags & SER_RS485_RTS_ON_SEND) {
    1488                 :            :                         /* RTS driving high on TX */
    1489                 :          0 :                         setting &= ~FINTEK_RTS_INVERT;
    1490                 :            :                 } else {
    1491                 :            :                         /* RTS driving low on TX */
    1492                 :          0 :                         setting |= FINTEK_RTS_INVERT;
    1493                 :            :                 }
    1494                 :            : 
    1495                 :          0 :                 rs485->delay_rts_after_send = 0;
    1496                 :          0 :                 rs485->delay_rts_before_send = 0;
    1497                 :            :         } else {
    1498                 :            :                 /* Disable RTS H/W control mode */
    1499                 :          0 :                 setting &= ~(FINTEK_RTS_CONTROL_BY_HW | FINTEK_RTS_INVERT);
    1500                 :            :         }
    1501                 :            : 
    1502                 :          0 :         pci_write_config_byte(pci_dev, 0x40 + 8 * *index + 7, setting);
    1503                 :            : 
    1504         [ #  # ]:          0 :         if (rs485 != &port->rs485)
    1505                 :          0 :                 port->rs485 = *rs485;
    1506                 :            : 
    1507                 :          0 :         return 0;
    1508                 :            : }
    1509                 :            : 
    1510                 :          0 : static int pci_fintek_setup(struct serial_private *priv,
    1511                 :            :                             const struct pciserial_board *board,
    1512                 :            :                             struct uart_8250_port *port, int idx)
    1513                 :            : {
    1514                 :          0 :         struct pci_dev *pdev = priv->dev;
    1515                 :          0 :         u8 *data;
    1516                 :          0 :         u8 config_base;
    1517                 :          0 :         u16 iobase;
    1518                 :            : 
    1519                 :          0 :         config_base = 0x40 + 0x08 * idx;
    1520                 :            : 
    1521                 :            :         /* Get the io address from configuration space */
    1522                 :          0 :         pci_read_config_word(pdev, config_base + 4, &iobase);
    1523                 :            : 
    1524                 :          0 :         dev_dbg(&pdev->dev, "%s: idx=%d iobase=0x%x", __func__, idx, iobase);
    1525                 :            : 
    1526                 :          0 :         port->port.iotype = UPIO_PORT;
    1527                 :          0 :         port->port.iobase = iobase;
    1528                 :          0 :         port->port.rs485_config = pci_fintek_rs485_config;
    1529                 :            : 
    1530                 :          0 :         data = devm_kzalloc(&pdev->dev, sizeof(u8), GFP_KERNEL);
    1531         [ #  # ]:          0 :         if (!data)
    1532                 :            :                 return -ENOMEM;
    1533                 :            : 
    1534                 :            :         /* preserve index in PCI configuration space */
    1535                 :          0 :         *data = idx;
    1536                 :          0 :         port->port.private_data = data;
    1537                 :            : 
    1538                 :          0 :         return 0;
    1539                 :            : }
    1540                 :            : 
    1541                 :          0 : static int pci_fintek_init(struct pci_dev *dev)
    1542                 :            : {
    1543                 :          0 :         unsigned long iobase;
    1544                 :          0 :         u32 max_port, i;
    1545                 :          0 :         resource_size_t bar_data[3];
    1546                 :          0 :         u8 config_base;
    1547         [ #  # ]:          0 :         struct serial_private *priv = pci_get_drvdata(dev);
    1548                 :          0 :         struct uart_8250_port *port;
    1549                 :            : 
    1550         [ #  # ]:          0 :         if (!(pci_resource_flags(dev, 5) & IORESOURCE_IO) ||
    1551         [ #  # ]:          0 :                         !(pci_resource_flags(dev, 4) & IORESOURCE_IO) ||
    1552         [ #  # ]:          0 :                         !(pci_resource_flags(dev, 3) & IORESOURCE_IO))
    1553                 :            :                 return -ENODEV;
    1554                 :            : 
    1555      [ #  #  # ]:          0 :         switch (dev->device) {
    1556                 :          0 :         case 0x1104: /* 4 ports */
    1557                 :            :         case 0x1108: /* 8 ports */
    1558                 :          0 :                 max_port = dev->device & 0xff;
    1559                 :          0 :                 break;
    1560                 :            :         case 0x1112: /* 12 ports */
    1561                 :            :                 max_port = 12;
    1562                 :            :                 break;
    1563                 :            :         default:
    1564                 :            :                 return -EINVAL;
    1565                 :            :         }
    1566                 :            : 
    1567                 :            :         /* Get the io address dispatch from the BIOS */
    1568                 :          0 :         bar_data[0] = pci_resource_start(dev, 5);
    1569                 :          0 :         bar_data[1] = pci_resource_start(dev, 4);
    1570                 :          0 :         bar_data[2] = pci_resource_start(dev, 3);
    1571                 :            : 
    1572         [ #  # ]:          0 :         for (i = 0; i < max_port; ++i) {
    1573                 :            :                 /* UART0 configuration offset start from 0x40 */
    1574                 :          0 :                 config_base = 0x40 + 0x08 * i;
    1575                 :            : 
    1576                 :            :                 /* Calculate Real IO Port */
    1577                 :          0 :                 iobase = (bar_data[i / 4] & 0xffffffe0) + (i % 4) * 8;
    1578                 :            : 
    1579                 :            :                 /* Enable UART I/O port */
    1580                 :          0 :                 pci_write_config_byte(dev, config_base + 0x00, 0x01);
    1581                 :            : 
    1582                 :            :                 /* Select 128-byte FIFO and 8x FIFO threshold */
    1583                 :          0 :                 pci_write_config_byte(dev, config_base + 0x01, 0x33);
    1584                 :            : 
    1585                 :            :                 /* LSB UART */
    1586                 :          0 :                 pci_write_config_byte(dev, config_base + 0x04,
    1587                 :          0 :                                 (u8)(iobase & 0xff));
    1588                 :            : 
    1589                 :            :                 /* MSB UART */
    1590                 :          0 :                 pci_write_config_byte(dev, config_base + 0x05,
    1591                 :          0 :                                 (u8)((iobase & 0xff00) >> 8));
    1592                 :            : 
    1593                 :          0 :                 pci_write_config_byte(dev, config_base + 0x06, dev->irq);
    1594                 :            : 
    1595         [ #  # ]:          0 :                 if (priv) {
    1596                 :            :                         /* re-apply RS232/485 mode when
    1597                 :            :                          * pciserial_resume_ports()
    1598                 :            :                          */
    1599                 :          0 :                         port = serial8250_get_port(priv->line[i]);
    1600                 :          0 :                         pci_fintek_rs485_config(&port->port, NULL);
    1601                 :            :                 } else {
    1602                 :            :                         /* First init without port data
    1603                 :            :                          * force init to RS232 Mode
    1604                 :            :                          */
    1605                 :          0 :                         pci_write_config_byte(dev, config_base + 0x07, 0x01);
    1606                 :            :                 }
    1607                 :            :         }
    1608                 :            : 
    1609                 :          0 :         return max_port;
    1610                 :            : }
    1611                 :            : 
    1612                 :          0 : static void f815xxa_mem_serial_out(struct uart_port *p, int offset, int value)
    1613                 :            : {
    1614                 :          0 :         struct f815xxa_data *data = p->private_data;
    1615                 :          0 :         unsigned long flags;
    1616                 :            : 
    1617                 :          0 :         spin_lock_irqsave(&data->lock, flags);
    1618                 :          0 :         writeb(value, p->membase + offset);
    1619                 :          0 :         readb(p->membase + UART_SCR); /* Dummy read for flush pcie tx queue */
    1620                 :          0 :         spin_unlock_irqrestore(&data->lock, flags);
    1621                 :          0 : }
    1622                 :            : 
    1623                 :          0 : static int pci_fintek_f815xxa_setup(struct serial_private *priv,
    1624                 :            :                             const struct pciserial_board *board,
    1625                 :            :                             struct uart_8250_port *port, int idx)
    1626                 :            : {
    1627                 :          0 :         struct pci_dev *pdev = priv->dev;
    1628                 :          0 :         struct f815xxa_data *data;
    1629                 :            : 
    1630                 :          0 :         data = devm_kzalloc(&pdev->dev, sizeof(*data), GFP_KERNEL);
    1631         [ #  # ]:          0 :         if (!data)
    1632                 :            :                 return -ENOMEM;
    1633                 :            : 
    1634                 :          0 :         data->idx = idx;
    1635                 :          0 :         spin_lock_init(&data->lock);
    1636                 :            : 
    1637                 :          0 :         port->port.private_data = data;
    1638                 :          0 :         port->port.iotype = UPIO_MEM;
    1639                 :          0 :         port->port.flags |= UPF_IOREMAP;
    1640                 :          0 :         port->port.mapbase = pci_resource_start(pdev, 0) + 8 * idx;
    1641                 :          0 :         port->port.serial_out = f815xxa_mem_serial_out;
    1642                 :            : 
    1643                 :          0 :         return 0;
    1644                 :            : }
    1645                 :            : 
    1646                 :          0 : static int pci_fintek_f815xxa_init(struct pci_dev *dev)
    1647                 :            : {
    1648                 :          0 :         u32 max_port, i;
    1649                 :          0 :         int config_base;
    1650                 :            : 
    1651         [ #  # ]:          0 :         if (!(pci_resource_flags(dev, 0) & IORESOURCE_MEM))
    1652                 :            :                 return -ENODEV;
    1653                 :            : 
    1654      [ #  #  # ]:          0 :         switch (dev->device) {
    1655                 :          0 :         case 0x1204: /* 4 ports */
    1656                 :            :         case 0x1208: /* 8 ports */
    1657                 :          0 :                 max_port = dev->device & 0xff;
    1658                 :          0 :                 break;
    1659                 :            :         case 0x1212: /* 12 ports */
    1660                 :            :                 max_port = 12;
    1661                 :            :                 break;
    1662                 :            :         default:
    1663                 :            :                 return -EINVAL;
    1664                 :            :         }
    1665                 :            : 
    1666                 :            :         /* Set to mmio decode */
    1667                 :          0 :         pci_write_config_byte(dev, 0x209, 0x40);
    1668                 :            : 
    1669         [ #  # ]:          0 :         for (i = 0; i < max_port; ++i) {
    1670                 :            :                 /* UART0 configuration offset start from 0x2A0 */
    1671                 :          0 :                 config_base = 0x2A0 + 0x08 * i;
    1672                 :            : 
    1673                 :            :                 /* Select 128-byte FIFO and 8x FIFO threshold */
    1674                 :          0 :                 pci_write_config_byte(dev, config_base + 0x01, 0x33);
    1675                 :            : 
    1676                 :            :                 /* Enable UART I/O port */
    1677                 :          0 :                 pci_write_config_byte(dev, config_base + 0, 0x01);
    1678                 :            :         }
    1679                 :            : 
    1680                 :          0 :         return max_port;
    1681                 :            : }
    1682                 :            : 
    1683                 :          0 : static int skip_tx_en_setup(struct serial_private *priv,
    1684                 :            :                         const struct pciserial_board *board,
    1685                 :            :                         struct uart_8250_port *port, int idx)
    1686                 :            : {
    1687                 :          0 :         port->port.quirks |= UPQ_NO_TXEN_TEST;
    1688                 :          0 :         dev_dbg(&priv->dev->dev,
    1689                 :            :                 "serial8250: skipping TxEn test for device [%04x:%04x] subsystem [%04x:%04x]\n",
    1690                 :            :                 priv->dev->vendor, priv->dev->device,
    1691                 :            :                 priv->dev->subsystem_vendor, priv->dev->subsystem_device);
    1692                 :            : 
    1693                 :          0 :         return pci_default_setup(priv, board, port, idx);
    1694                 :            : }
    1695                 :            : 
    1696                 :          0 : static void kt_handle_break(struct uart_port *p)
    1697                 :            : {
    1698                 :          0 :         struct uart_8250_port *up = up_to_u8250p(p);
    1699                 :            :         /*
    1700                 :            :          * On receipt of a BI, serial device in Intel ME (Intel
    1701                 :            :          * management engine) needs to have its fifos cleared for sane
    1702                 :            :          * SOL (Serial Over Lan) output.
    1703                 :            :          */
    1704                 :          0 :         serial8250_clear_and_reinit_fifos(up);
    1705                 :          0 : }
    1706                 :            : 
    1707                 :          0 : static unsigned int kt_serial_in(struct uart_port *p, int offset)
    1708                 :            : {
    1709                 :          0 :         struct uart_8250_port *up = up_to_u8250p(p);
    1710                 :          0 :         unsigned int val;
    1711                 :            : 
    1712                 :            :         /*
    1713                 :            :          * When the Intel ME (management engine) gets reset its serial
    1714                 :            :          * port registers could return 0 momentarily.  Functions like
    1715                 :            :          * serial8250_console_write, read and save the IER, perform
    1716                 :            :          * some operation and then restore it.  In order to avoid
    1717                 :            :          * setting IER register inadvertently to 0, if the value read
    1718                 :            :          * is 0, double check with ier value in uart_8250_port and use
    1719                 :            :          * that instead.  up->ier should be the same value as what is
    1720                 :            :          * currently configured.
    1721                 :            :          */
    1722                 :          0 :         val = inb(p->iobase + offset);
    1723         [ #  # ]:          0 :         if (offset == UART_IER) {
    1724         [ #  # ]:          0 :                 if (val == 0)
    1725                 :          0 :                         val = up->ier;
    1726                 :            :         }
    1727                 :          0 :         return val;
    1728                 :            : }
    1729                 :            : 
    1730                 :          0 : static int kt_serial_setup(struct serial_private *priv,
    1731                 :            :                            const struct pciserial_board *board,
    1732                 :            :                            struct uart_8250_port *port, int idx)
    1733                 :            : {
    1734                 :          0 :         port->port.flags |= UPF_BUG_THRE;
    1735                 :          0 :         port->port.serial_in = kt_serial_in;
    1736                 :          0 :         port->port.handle_break = kt_handle_break;
    1737                 :          0 :         return skip_tx_en_setup(priv, board, port, idx);
    1738                 :            : }
    1739                 :            : 
    1740                 :          0 : static int pci_eg20t_init(struct pci_dev *dev)
    1741                 :            : {
    1742                 :            : #if defined(CONFIG_SERIAL_PCH_UART) || defined(CONFIG_SERIAL_PCH_UART_MODULE)
    1743                 :            :         return -ENODEV;
    1744                 :            : #else
    1745                 :          0 :         return 0;
    1746                 :            : #endif
    1747                 :            : }
    1748                 :            : 
    1749                 :            : static int
    1750                 :          0 : pci_wch_ch353_setup(struct serial_private *priv,
    1751                 :            :                     const struct pciserial_board *board,
    1752                 :            :                     struct uart_8250_port *port, int idx)
    1753                 :            : {
    1754                 :          0 :         port->port.flags |= UPF_FIXED_TYPE;
    1755                 :          0 :         port->port.type = PORT_16550A;
    1756                 :          0 :         return pci_default_setup(priv, board, port, idx);
    1757                 :            : }
    1758                 :            : 
    1759                 :            : static int
    1760                 :          0 : pci_wch_ch355_setup(struct serial_private *priv,
    1761                 :            :                 const struct pciserial_board *board,
    1762                 :            :                 struct uart_8250_port *port, int idx)
    1763                 :            : {
    1764                 :          0 :         port->port.flags |= UPF_FIXED_TYPE;
    1765                 :          0 :         port->port.type = PORT_16550A;
    1766                 :          0 :         return pci_default_setup(priv, board, port, idx);
    1767                 :            : }
    1768                 :            : 
    1769                 :            : static int
    1770                 :          0 : pci_wch_ch38x_setup(struct serial_private *priv,
    1771                 :            :                     const struct pciserial_board *board,
    1772                 :            :                     struct uart_8250_port *port, int idx)
    1773                 :            : {
    1774                 :          0 :         port->port.flags |= UPF_FIXED_TYPE;
    1775                 :          0 :         port->port.type = PORT_16850;
    1776                 :          0 :         return pci_default_setup(priv, board, port, idx);
    1777                 :            : }
    1778                 :            : 
    1779                 :            : static int
    1780                 :          0 : pci_sunix_setup(struct serial_private *priv,
    1781                 :            :                 const struct pciserial_board *board,
    1782                 :            :                 struct uart_8250_port *port, int idx)
    1783                 :            : {
    1784                 :          0 :         int bar;
    1785                 :          0 :         int offset;
    1786                 :            : 
    1787                 :          0 :         port->port.flags |= UPF_FIXED_TYPE;
    1788                 :          0 :         port->port.type = PORT_SUNIX;
    1789                 :            : 
    1790         [ #  # ]:          0 :         if (idx < 4) {
    1791                 :          0 :                 bar = 0;
    1792                 :          0 :                 offset = idx * board->uart_offset;
    1793                 :            :         } else {
    1794                 :          0 :                 bar = 1;
    1795                 :          0 :                 idx -= 4;
    1796                 :          0 :                 idx = div_s64_rem(idx, 4, &offset);
    1797                 :          0 :                 offset = idx * 64 + offset * board->uart_offset;
    1798                 :            :         }
    1799                 :            : 
    1800                 :          0 :         return setup_port(priv, port, bar, offset, 0);
    1801                 :            : }
    1802                 :            : 
    1803                 :            : static int
    1804                 :          0 : pci_moxa_setup(struct serial_private *priv,
    1805                 :            :                 const struct pciserial_board *board,
    1806                 :            :                 struct uart_8250_port *port, int idx)
    1807                 :            : {
    1808                 :          0 :         unsigned int bar = FL_GET_BASE(board->flags);
    1809                 :          0 :         int offset;
    1810                 :            : 
    1811   [ #  #  #  # ]:          0 :         if (board->num_ports == 4 && idx == 3)
    1812                 :          0 :                 offset = 7 * board->uart_offset;
    1813                 :            :         else
    1814                 :          0 :                 offset = idx * board->uart_offset;
    1815                 :            : 
    1816                 :          0 :         return setup_port(priv, port, bar, offset, 0);
    1817                 :            : }
    1818                 :            : 
    1819                 :            : #define PCI_VENDOR_ID_SBSMODULARIO      0x124B
    1820                 :            : #define PCI_SUBVENDOR_ID_SBSMODULARIO   0x124B
    1821                 :            : #define PCI_DEVICE_ID_OCTPRO            0x0001
    1822                 :            : #define PCI_SUBDEVICE_ID_OCTPRO232      0x0108
    1823                 :            : #define PCI_SUBDEVICE_ID_OCTPRO422      0x0208
    1824                 :            : #define PCI_SUBDEVICE_ID_POCTAL232      0x0308
    1825                 :            : #define PCI_SUBDEVICE_ID_POCTAL422      0x0408
    1826                 :            : #define PCI_SUBDEVICE_ID_SIIG_DUAL_00   0x2500
    1827                 :            : #define PCI_SUBDEVICE_ID_SIIG_DUAL_30   0x2530
    1828                 :            : #define PCI_VENDOR_ID_ADVANTECH         0x13fe
    1829                 :            : #define PCI_DEVICE_ID_INTEL_CE4100_UART 0x2e66
    1830                 :            : #define PCI_DEVICE_ID_ADVANTECH_PCI3620 0x3620
    1831                 :            : #define PCI_DEVICE_ID_ADVANTECH_PCI3618 0x3618
    1832                 :            : #define PCI_DEVICE_ID_ADVANTECH_PCIf618 0xf618
    1833                 :            : #define PCI_DEVICE_ID_TITAN_200I        0x8028
    1834                 :            : #define PCI_DEVICE_ID_TITAN_400I        0x8048
    1835                 :            : #define PCI_DEVICE_ID_TITAN_800I        0x8088
    1836                 :            : #define PCI_DEVICE_ID_TITAN_800EH       0xA007
    1837                 :            : #define PCI_DEVICE_ID_TITAN_800EHB      0xA008
    1838                 :            : #define PCI_DEVICE_ID_TITAN_400EH       0xA009
    1839                 :            : #define PCI_DEVICE_ID_TITAN_100E        0xA010
    1840                 :            : #define PCI_DEVICE_ID_TITAN_200E        0xA012
    1841                 :            : #define PCI_DEVICE_ID_TITAN_400E        0xA013
    1842                 :            : #define PCI_DEVICE_ID_TITAN_800E        0xA014
    1843                 :            : #define PCI_DEVICE_ID_TITAN_200EI       0xA016
    1844                 :            : #define PCI_DEVICE_ID_TITAN_200EISI     0xA017
    1845                 :            : #define PCI_DEVICE_ID_TITAN_200V3       0xA306
    1846                 :            : #define PCI_DEVICE_ID_TITAN_400V3       0xA310
    1847                 :            : #define PCI_DEVICE_ID_TITAN_410V3       0xA312
    1848                 :            : #define PCI_DEVICE_ID_TITAN_800V3       0xA314
    1849                 :            : #define PCI_DEVICE_ID_TITAN_800V3B      0xA315
    1850                 :            : #define PCI_DEVICE_ID_OXSEMI_16PCI958   0x9538
    1851                 :            : #define PCIE_DEVICE_ID_NEO_2_OX_IBM     0x00F6
    1852                 :            : #define PCI_DEVICE_ID_PLX_CRONYX_OMEGA  0xc001
    1853                 :            : #define PCI_DEVICE_ID_INTEL_PATSBURG_KT 0x1d3d
    1854                 :            : #define PCI_VENDOR_ID_WCH               0x4348
    1855                 :            : #define PCI_DEVICE_ID_WCH_CH352_2S      0x3253
    1856                 :            : #define PCI_DEVICE_ID_WCH_CH353_4S      0x3453
    1857                 :            : #define PCI_DEVICE_ID_WCH_CH353_2S1PF   0x5046
    1858                 :            : #define PCI_DEVICE_ID_WCH_CH353_1S1P    0x5053
    1859                 :            : #define PCI_DEVICE_ID_WCH_CH353_2S1P    0x7053
    1860                 :            : #define PCI_DEVICE_ID_WCH_CH355_4S      0x7173
    1861                 :            : #define PCI_VENDOR_ID_AGESTAR           0x5372
    1862                 :            : #define PCI_DEVICE_ID_AGESTAR_9375      0x6872
    1863                 :            : #define PCI_VENDOR_ID_ASIX              0x9710
    1864                 :            : #define PCI_DEVICE_ID_BROADCOM_TRUMANAGE 0x160a
    1865                 :            : #define PCI_DEVICE_ID_AMCC_ADDIDATA_APCI7800 0x818e
    1866                 :            : 
    1867                 :            : #define PCIE_VENDOR_ID_WCH              0x1c00
    1868                 :            : #define PCIE_DEVICE_ID_WCH_CH382_2S1P   0x3250
    1869                 :            : #define PCIE_DEVICE_ID_WCH_CH384_4S     0x3470
    1870                 :            : #define PCIE_DEVICE_ID_WCH_CH382_2S     0x3253
    1871                 :            : 
    1872                 :            : #define PCI_VENDOR_ID_PERICOM                   0x12D8
    1873                 :            : #define PCI_DEVICE_ID_PERICOM_PI7C9X7951        0x7951
    1874                 :            : #define PCI_DEVICE_ID_PERICOM_PI7C9X7952        0x7952
    1875                 :            : #define PCI_DEVICE_ID_PERICOM_PI7C9X7954        0x7954
    1876                 :            : #define PCI_DEVICE_ID_PERICOM_PI7C9X7958        0x7958
    1877                 :            : 
    1878                 :            : #define PCI_VENDOR_ID_ACCESIO                   0x494f
    1879                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_COM_2SDB     0x1051
    1880                 :            : #define PCI_DEVICE_ID_ACCESIO_MPCIE_COM_2S      0x1053
    1881                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_COM_4SDB     0x105C
    1882                 :            : #define PCI_DEVICE_ID_ACCESIO_MPCIE_COM_4S      0x105E
    1883                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_COM232_2DB   0x1091
    1884                 :            : #define PCI_DEVICE_ID_ACCESIO_MPCIE_COM232_2    0x1093
    1885                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_COM232_4DB   0x1099
    1886                 :            : #define PCI_DEVICE_ID_ACCESIO_MPCIE_COM232_4    0x109B
    1887                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_COM_2SMDB    0x10D1
    1888                 :            : #define PCI_DEVICE_ID_ACCESIO_MPCIE_COM_2SM     0x10D3
    1889                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_COM_4SMDB    0x10DA
    1890                 :            : #define PCI_DEVICE_ID_ACCESIO_MPCIE_COM_4SM     0x10DC
    1891                 :            : #define PCI_DEVICE_ID_ACCESIO_MPCIE_ICM485_1    0x1108
    1892                 :            : #define PCI_DEVICE_ID_ACCESIO_MPCIE_ICM422_2    0x1110
    1893                 :            : #define PCI_DEVICE_ID_ACCESIO_MPCIE_ICM485_2    0x1111
    1894                 :            : #define PCI_DEVICE_ID_ACCESIO_MPCIE_ICM422_4    0x1118
    1895                 :            : #define PCI_DEVICE_ID_ACCESIO_MPCIE_ICM485_4    0x1119
    1896                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_ICM_2S       0x1152
    1897                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_ICM_4S       0x115A
    1898                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_ICM232_2     0x1190
    1899                 :            : #define PCI_DEVICE_ID_ACCESIO_MPCIE_ICM232_2    0x1191
    1900                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_ICM232_4     0x1198
    1901                 :            : #define PCI_DEVICE_ID_ACCESIO_MPCIE_ICM232_4    0x1199
    1902                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_ICM_2SM      0x11D0
    1903                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_COM422_4     0x105A
    1904                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_COM485_4     0x105B
    1905                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_COM422_8     0x106A
    1906                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_COM485_8     0x106B
    1907                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_COM232_4     0x1098
    1908                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_COM232_8     0x10A9
    1909                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_COM_4SM      0x10D9
    1910                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_COM_8SM      0x10E9
    1911                 :            : #define PCI_DEVICE_ID_ACCESIO_PCIE_ICM_4SM      0x11D8
    1912                 :            : 
    1913                 :            : 
    1914                 :            : #define PCI_DEVICE_ID_MOXA_CP102E       0x1024
    1915                 :            : #define PCI_DEVICE_ID_MOXA_CP102EL      0x1025
    1916                 :            : #define PCI_DEVICE_ID_MOXA_CP104EL_A    0x1045
    1917                 :            : #define PCI_DEVICE_ID_MOXA_CP114EL      0x1144
    1918                 :            : #define PCI_DEVICE_ID_MOXA_CP116E_A_A   0x1160
    1919                 :            : #define PCI_DEVICE_ID_MOXA_CP116E_A_B   0x1161
    1920                 :            : #define PCI_DEVICE_ID_MOXA_CP118EL_A    0x1182
    1921                 :            : #define PCI_DEVICE_ID_MOXA_CP118E_A_I   0x1183
    1922                 :            : #define PCI_DEVICE_ID_MOXA_CP132EL      0x1322
    1923                 :            : #define PCI_DEVICE_ID_MOXA_CP134EL_A    0x1342
    1924                 :            : #define PCI_DEVICE_ID_MOXA_CP138E_A     0x1381
    1925                 :            : #define PCI_DEVICE_ID_MOXA_CP168EL_A    0x1683
    1926                 :            : 
    1927                 :            : /* Unknown vendors/cards - this should not be in linux/pci_ids.h */
    1928                 :            : #define PCI_SUBDEVICE_ID_UNKNOWN_0x1584 0x1584
    1929                 :            : #define PCI_SUBDEVICE_ID_UNKNOWN_0x1588 0x1588
    1930                 :            : 
    1931                 :            : /*
    1932                 :            :  * Master list of serial port init/setup/exit quirks.
    1933                 :            :  * This does not describe the general nature of the port.
    1934                 :            :  * (ie, baud base, number and location of ports, etc)
    1935                 :            :  *
    1936                 :            :  * This list is ordered alphabetically by vendor then device.
    1937                 :            :  * Specific entries must come before more generic entries.
    1938                 :            :  */
    1939                 :            : static struct pci_serial_quirk pci_serial_quirks[] __refdata = {
    1940                 :            :         /*
    1941                 :            :         * ADDI-DATA GmbH communication cards <info@addi-data.com>
    1942                 :            :         */
    1943                 :            :         {
    1944                 :            :                 .vendor         = PCI_VENDOR_ID_AMCC,
    1945                 :            :                 .device         = PCI_DEVICE_ID_AMCC_ADDIDATA_APCI7800,
    1946                 :            :                 .subvendor      = PCI_ANY_ID,
    1947                 :            :                 .subdevice      = PCI_ANY_ID,
    1948                 :            :                 .setup          = addidata_apci7800_setup,
    1949                 :            :         },
    1950                 :            :         /*
    1951                 :            :          * AFAVLAB cards - these may be called via parport_serial
    1952                 :            :          *  It is not clear whether this applies to all products.
    1953                 :            :          */
    1954                 :            :         {
    1955                 :            :                 .vendor         = PCI_VENDOR_ID_AFAVLAB,
    1956                 :            :                 .device         = PCI_ANY_ID,
    1957                 :            :                 .subvendor      = PCI_ANY_ID,
    1958                 :            :                 .subdevice      = PCI_ANY_ID,
    1959                 :            :                 .setup          = afavlab_setup,
    1960                 :            :         },
    1961                 :            :         /*
    1962                 :            :          * HP Diva
    1963                 :            :          */
    1964                 :            :         {
    1965                 :            :                 .vendor         = PCI_VENDOR_ID_HP,
    1966                 :            :                 .device         = PCI_DEVICE_ID_HP_DIVA,
    1967                 :            :                 .subvendor      = PCI_ANY_ID,
    1968                 :            :                 .subdevice      = PCI_ANY_ID,
    1969                 :            :                 .init           = pci_hp_diva_init,
    1970                 :            :                 .setup          = pci_hp_diva_setup,
    1971                 :            :         },
    1972                 :            :         /*
    1973                 :            :          * Intel
    1974                 :            :          */
    1975                 :            :         {
    1976                 :            :                 .vendor         = PCI_VENDOR_ID_INTEL,
    1977                 :            :                 .device         = PCI_DEVICE_ID_INTEL_80960_RP,
    1978                 :            :                 .subvendor      = 0xe4bf,
    1979                 :            :                 .subdevice      = PCI_ANY_ID,
    1980                 :            :                 .init           = pci_inteli960ni_init,
    1981                 :            :                 .setup          = pci_default_setup,
    1982                 :            :         },
    1983                 :            :         {
    1984                 :            :                 .vendor         = PCI_VENDOR_ID_INTEL,
    1985                 :            :                 .device         = PCI_DEVICE_ID_INTEL_8257X_SOL,
    1986                 :            :                 .subvendor      = PCI_ANY_ID,
    1987                 :            :                 .subdevice      = PCI_ANY_ID,
    1988                 :            :                 .setup          = skip_tx_en_setup,
    1989                 :            :         },
    1990                 :            :         {
    1991                 :            :                 .vendor         = PCI_VENDOR_ID_INTEL,
    1992                 :            :                 .device         = PCI_DEVICE_ID_INTEL_82573L_SOL,
    1993                 :            :                 .subvendor      = PCI_ANY_ID,
    1994                 :            :                 .subdevice      = PCI_ANY_ID,
    1995                 :            :                 .setup          = skip_tx_en_setup,
    1996                 :            :         },
    1997                 :            :         {
    1998                 :            :                 .vendor         = PCI_VENDOR_ID_INTEL,
    1999                 :            :                 .device         = PCI_DEVICE_ID_INTEL_82573E_SOL,
    2000                 :            :                 .subvendor      = PCI_ANY_ID,
    2001                 :            :                 .subdevice      = PCI_ANY_ID,
    2002                 :            :                 .setup          = skip_tx_en_setup,
    2003                 :            :         },
    2004                 :            :         {
    2005                 :            :                 .vendor         = PCI_VENDOR_ID_INTEL,
    2006                 :            :                 .device         = PCI_DEVICE_ID_INTEL_CE4100_UART,
    2007                 :            :                 .subvendor      = PCI_ANY_ID,
    2008                 :            :                 .subdevice      = PCI_ANY_ID,
    2009                 :            :                 .setup          = ce4100_serial_setup,
    2010                 :            :         },
    2011                 :            :         {
    2012                 :            :                 .vendor         = PCI_VENDOR_ID_INTEL,
    2013                 :            :                 .device         = PCI_DEVICE_ID_INTEL_PATSBURG_KT,
    2014                 :            :                 .subvendor      = PCI_ANY_ID,
    2015                 :            :                 .subdevice      = PCI_ANY_ID,
    2016                 :            :                 .setup          = kt_serial_setup,
    2017                 :            :         },
    2018                 :            :         /*
    2019                 :            :          * ITE
    2020                 :            :          */
    2021                 :            :         {
    2022                 :            :                 .vendor         = PCI_VENDOR_ID_ITE,
    2023                 :            :                 .device         = PCI_DEVICE_ID_ITE_8872,
    2024                 :            :                 .subvendor      = PCI_ANY_ID,
    2025                 :            :                 .subdevice      = PCI_ANY_ID,
    2026                 :            :                 .init           = pci_ite887x_init,
    2027                 :            :                 .setup          = pci_default_setup,
    2028                 :            :                 .exit           = pci_ite887x_exit,
    2029                 :            :         },
    2030                 :            :         /*
    2031                 :            :          * National Instruments
    2032                 :            :          */
    2033                 :            :         {
    2034                 :            :                 .vendor         = PCI_VENDOR_ID_NI,
    2035                 :            :                 .device         = PCI_DEVICE_ID_NI_PCI23216,
    2036                 :            :                 .subvendor      = PCI_ANY_ID,
    2037                 :            :                 .subdevice      = PCI_ANY_ID,
    2038                 :            :                 .init           = pci_ni8420_init,
    2039                 :            :                 .setup          = pci_default_setup,
    2040                 :            :                 .exit           = pci_ni8420_exit,
    2041                 :            :         },
    2042                 :            :         {
    2043                 :            :                 .vendor         = PCI_VENDOR_ID_NI,
    2044                 :            :                 .device         = PCI_DEVICE_ID_NI_PCI2328,
    2045                 :            :                 .subvendor      = PCI_ANY_ID,
    2046                 :            :                 .subdevice      = PCI_ANY_ID,
    2047                 :            :                 .init           = pci_ni8420_init,
    2048                 :            :                 .setup          = pci_default_setup,
    2049                 :            :                 .exit           = pci_ni8420_exit,
    2050                 :            :         },
    2051                 :            :         {
    2052                 :            :                 .vendor         = PCI_VENDOR_ID_NI,
    2053                 :            :                 .device         = PCI_DEVICE_ID_NI_PCI2324,
    2054                 :            :                 .subvendor      = PCI_ANY_ID,
    2055                 :            :                 .subdevice      = PCI_ANY_ID,
    2056                 :            :                 .init           = pci_ni8420_init,
    2057                 :            :                 .setup          = pci_default_setup,
    2058                 :            :                 .exit           = pci_ni8420_exit,
    2059                 :            :         },
    2060                 :            :         {
    2061                 :            :                 .vendor         = PCI_VENDOR_ID_NI,
    2062                 :            :                 .device         = PCI_DEVICE_ID_NI_PCI2322,
    2063                 :            :                 .subvendor      = PCI_ANY_ID,
    2064                 :            :                 .subdevice      = PCI_ANY_ID,
    2065                 :            :                 .init           = pci_ni8420_init,
    2066                 :            :                 .setup          = pci_default_setup,
    2067                 :            :                 .exit           = pci_ni8420_exit,
    2068                 :            :         },
    2069                 :            :         {
    2070                 :            :                 .vendor         = PCI_VENDOR_ID_NI,
    2071                 :            :                 .device         = PCI_DEVICE_ID_NI_PCI2324I,
    2072                 :            :                 .subvendor      = PCI_ANY_ID,
    2073                 :            :                 .subdevice      = PCI_ANY_ID,
    2074                 :            :                 .init           = pci_ni8420_init,
    2075                 :            :                 .setup          = pci_default_setup,
    2076                 :            :                 .exit           = pci_ni8420_exit,
    2077                 :            :         },
    2078                 :            :         {
    2079                 :            :                 .vendor         = PCI_VENDOR_ID_NI,
    2080                 :            :                 .device         = PCI_DEVICE_ID_NI_PCI2322I,
    2081                 :            :                 .subvendor      = PCI_ANY_ID,
    2082                 :            :                 .subdevice      = PCI_ANY_ID,
    2083                 :            :                 .init           = pci_ni8420_init,
    2084                 :            :                 .setup          = pci_default_setup,
    2085                 :            :                 .exit           = pci_ni8420_exit,
    2086                 :            :         },
    2087                 :            :         {
    2088                 :            :                 .vendor         = PCI_VENDOR_ID_NI,
    2089                 :            :                 .device         = PCI_DEVICE_ID_NI_PXI8420_23216,
    2090                 :            :                 .subvendor      = PCI_ANY_ID,
    2091                 :            :                 .subdevice      = PCI_ANY_ID,
    2092                 :            :                 .init           = pci_ni8420_init,
    2093                 :            :                 .setup          = pci_default_setup,
    2094                 :            :                 .exit           = pci_ni8420_exit,
    2095                 :            :         },
    2096                 :            :         {
    2097                 :            :                 .vendor         = PCI_VENDOR_ID_NI,
    2098                 :            :                 .device         = PCI_DEVICE_ID_NI_PXI8420_2328,
    2099                 :            :                 .subvendor      = PCI_ANY_ID,
    2100                 :            :                 .subdevice      = PCI_ANY_ID,
    2101                 :            :                 .init           = pci_ni8420_init,
    2102                 :            :                 .setup          = pci_default_setup,
    2103                 :            :                 .exit           = pci_ni8420_exit,
    2104                 :            :         },
    2105                 :            :         {
    2106                 :            :                 .vendor         = PCI_VENDOR_ID_NI,
    2107                 :            :                 .device         = PCI_DEVICE_ID_NI_PXI8420_2324,
    2108                 :            :                 .subvendor      = PCI_ANY_ID,
    2109                 :            :                 .subdevice      = PCI_ANY_ID,
    2110                 :            :                 .init           = pci_ni8420_init,
    2111                 :            :                 .setup          = pci_default_setup,
    2112                 :            :                 .exit           = pci_ni8420_exit,
    2113                 :            :         },
    2114                 :            :         {
    2115                 :            :                 .vendor         = PCI_VENDOR_ID_NI,
    2116                 :            :                 .device         = PCI_DEVICE_ID_NI_PXI8420_2322,
    2117                 :            :                 .subvendor      = PCI_ANY_ID,
    2118                 :            :                 .subdevice      = PCI_ANY_ID,
    2119                 :            :                 .init           = pci_ni8420_init,
    2120                 :            :                 .setup          = pci_default_setup,
    2121                 :            :                 .exit           = pci_ni8420_exit,
    2122                 :            :         },
    2123                 :            :         {
    2124                 :            :                 .vendor         = PCI_VENDOR_ID_NI,
    2125                 :            :                 .device         = PCI_DEVICE_ID_NI_PXI8422_2324,
    2126                 :            :                 .subvendor      = PCI_ANY_ID,
    2127                 :            :                 .subdevice      = PCI_ANY_ID,
    2128                 :            :                 .init           = pci_ni8420_init,
    2129                 :            :                 .setup          = pci_default_setup,
    2130                 :            :                 .exit           = pci_ni8420_exit,
    2131                 :            :         },
    2132                 :            :         {
    2133                 :            :                 .vendor         = PCI_VENDOR_ID_NI,
    2134                 :            :                 .device         = PCI_DEVICE_ID_NI_PXI8422_2322,
    2135                 :            :                 .subvendor      = PCI_ANY_ID,
    2136                 :            :                 .subdevice      = PCI_ANY_ID,
    2137                 :            :                 .init           = pci_ni8420_init,
    2138                 :            :                 .setup          = pci_default_setup,
    2139                 :            :                 .exit           = pci_ni8420_exit,
    2140                 :            :         },
    2141                 :            :         {
    2142                 :            :                 .vendor         = PCI_VENDOR_ID_NI,
    2143                 :            :                 .device         = PCI_ANY_ID,
    2144                 :            :                 .subvendor      = PCI_ANY_ID,
    2145                 :            :                 .subdevice      = PCI_ANY_ID,
    2146                 :            :                 .init           = pci_ni8430_init,
    2147                 :            :                 .setup          = pci_ni8430_setup,
    2148                 :            :                 .exit           = pci_ni8430_exit,
    2149                 :            :         },
    2150                 :            :         /* Quatech */
    2151                 :            :         {
    2152                 :            :                 .vendor         = PCI_VENDOR_ID_QUATECH,
    2153                 :            :                 .device         = PCI_ANY_ID,
    2154                 :            :                 .subvendor      = PCI_ANY_ID,
    2155                 :            :                 .subdevice      = PCI_ANY_ID,
    2156                 :            :                 .init           = pci_quatech_init,
    2157                 :            :                 .setup          = pci_quatech_setup,
    2158                 :            :                 .exit           = pci_quatech_exit,
    2159                 :            :         },
    2160                 :            :         /*
    2161                 :            :          * Panacom
    2162                 :            :          */
    2163                 :            :         {
    2164                 :            :                 .vendor         = PCI_VENDOR_ID_PANACOM,
    2165                 :            :                 .device         = PCI_DEVICE_ID_PANACOM_QUADMODEM,
    2166                 :            :                 .subvendor      = PCI_ANY_ID,
    2167                 :            :                 .subdevice      = PCI_ANY_ID,
    2168                 :            :                 .init           = pci_plx9050_init,
    2169                 :            :                 .setup          = pci_default_setup,
    2170                 :            :                 .exit           = pci_plx9050_exit,
    2171                 :            :         },
    2172                 :            :         {
    2173                 :            :                 .vendor         = PCI_VENDOR_ID_PANACOM,
    2174                 :            :                 .device         = PCI_DEVICE_ID_PANACOM_DUALMODEM,
    2175                 :            :                 .subvendor      = PCI_ANY_ID,
    2176                 :            :                 .subdevice      = PCI_ANY_ID,
    2177                 :            :                 .init           = pci_plx9050_init,
    2178                 :            :                 .setup          = pci_default_setup,
    2179                 :            :                 .exit           = pci_plx9050_exit,
    2180                 :            :         },
    2181                 :            :         /*
    2182                 :            :          * Pericom (Only 7954 - It have a offset jump for port 4)
    2183                 :            :          */
    2184                 :            :         {
    2185                 :            :                 .vendor         = PCI_VENDOR_ID_PERICOM,
    2186                 :            :                 .device         = PCI_DEVICE_ID_PERICOM_PI7C9X7954,
    2187                 :            :                 .subvendor      = PCI_ANY_ID,
    2188                 :            :                 .subdevice      = PCI_ANY_ID,
    2189                 :            :                 .setup          = pci_pericom_setup_four_at_eight,
    2190                 :            :         },
    2191                 :            :         /*
    2192                 :            :          * PLX
    2193                 :            :          */
    2194                 :            :         {
    2195                 :            :                 .vendor         = PCI_VENDOR_ID_PLX,
    2196                 :            :                 .device         = PCI_DEVICE_ID_PLX_9050,
    2197                 :            :                 .subvendor      = PCI_SUBVENDOR_ID_EXSYS,
    2198                 :            :                 .subdevice      = PCI_SUBDEVICE_ID_EXSYS_4055,
    2199                 :            :                 .init           = pci_plx9050_init,
    2200                 :            :                 .setup          = pci_default_setup,
    2201                 :            :                 .exit           = pci_plx9050_exit,
    2202                 :            :         },
    2203                 :            :         {
    2204                 :            :                 .vendor         = PCI_VENDOR_ID_PLX,
    2205                 :            :                 .device         = PCI_DEVICE_ID_PLX_9050,
    2206                 :            :                 .subvendor      = PCI_SUBVENDOR_ID_KEYSPAN,
    2207                 :            :                 .subdevice      = PCI_SUBDEVICE_ID_KEYSPAN_SX2,
    2208                 :            :                 .init           = pci_plx9050_init,
    2209                 :            :                 .setup          = pci_default_setup,
    2210                 :            :                 .exit           = pci_plx9050_exit,
    2211                 :            :         },
    2212                 :            :         {
    2213                 :            :                 .vendor         = PCI_VENDOR_ID_PLX,
    2214                 :            :                 .device         = PCI_DEVICE_ID_PLX_ROMULUS,
    2215                 :            :                 .subvendor      = PCI_VENDOR_ID_PLX,
    2216                 :            :                 .subdevice      = PCI_DEVICE_ID_PLX_ROMULUS,
    2217                 :            :                 .init           = pci_plx9050_init,
    2218                 :            :                 .setup          = pci_default_setup,
    2219                 :            :                 .exit           = pci_plx9050_exit,
    2220                 :            :         },
    2221                 :            :         {
    2222                 :            :                 .vendor     = PCI_VENDOR_ID_ACCESIO,
    2223                 :            :                 .device     = PCI_DEVICE_ID_ACCESIO_PCIE_COM_4SDB,
    2224                 :            :                 .subvendor  = PCI_ANY_ID,
    2225                 :            :                 .subdevice  = PCI_ANY_ID,
    2226                 :            :                 .setup      = pci_pericom_setup_four_at_eight,
    2227                 :            :         },
    2228                 :            :         {
    2229                 :            :                 .vendor     = PCI_VENDOR_ID_ACCESIO,
    2230                 :            :                 .device     = PCI_DEVICE_ID_ACCESIO_MPCIE_COM_4S,
    2231                 :            :                 .subvendor  = PCI_ANY_ID,
    2232                 :            :                 .subdevice  = PCI_ANY_ID,
    2233                 :            :                 .setup      = pci_pericom_setup_four_at_eight,
    2234                 :            :         },
    2235                 :            :         {
    2236                 :            :                 .vendor     = PCI_VENDOR_ID_ACCESIO,
    2237                 :            :                 .device     = PCI_DEVICE_ID_ACCESIO_PCIE_COM232_4DB,
    2238                 :            :                 .subvendor  = PCI_ANY_ID,
    2239                 :            :                 .subdevice  = PCI_ANY_ID,
    2240                 :            :                 .setup      = pci_pericom_setup_four_at_eight,
    2241                 :            :         },
    2242                 :            :         {
    2243                 :            :                 .vendor     = PCI_VENDOR_ID_ACCESIO,
    2244                 :            :                 .device     = PCI_DEVICE_ID_ACCESIO_MPCIE_COM232_4,
    2245                 :            :                 .subvendor  = PCI_ANY_ID,
    2246                 :            :                 .subdevice  = PCI_ANY_ID,
    2247                 :            :                 .setup      = pci_pericom_setup_four_at_eight,
    2248                 :            :         },
    2249                 :            :         {
    2250                 :            :                 .vendor     = PCI_VENDOR_ID_ACCESIO,
    2251                 :            :                 .device     = PCI_DEVICE_ID_ACCESIO_PCIE_COM_4SMDB,
    2252                 :            :                 .subvendor  = PCI_ANY_ID,
    2253                 :            :                 .subdevice  = PCI_ANY_ID,
    2254                 :            :                 .setup      = pci_pericom_setup_four_at_eight,
    2255                 :            :         },
    2256                 :            :         {
    2257                 :            :                 .vendor     = PCI_VENDOR_ID_ACCESIO,
    2258                 :            :                 .device     = PCI_DEVICE_ID_ACCESIO_MPCIE_COM_4SM,
    2259                 :            :                 .subvendor  = PCI_ANY_ID,
    2260                 :            :                 .subdevice  = PCI_ANY_ID,
    2261                 :            :                 .setup      = pci_pericom_setup_four_at_eight,
    2262                 :            :         },
    2263                 :            :         {
    2264                 :            :                 .vendor     = PCI_VENDOR_ID_ACCESIO,
    2265                 :            :                 .device     = PCI_DEVICE_ID_ACCESIO_MPCIE_ICM422_4,
    2266                 :            :                 .subvendor  = PCI_ANY_ID,
    2267                 :            :                 .subdevice  = PCI_ANY_ID,
    2268                 :            :                 .setup      = pci_pericom_setup_four_at_eight,
    2269                 :            :         },
    2270                 :            :         {
    2271                 :            :                 .vendor     = PCI_VENDOR_ID_ACCESIO,
    2272                 :            :                 .device     = PCI_DEVICE_ID_ACCESIO_MPCIE_ICM485_4,
    2273                 :            :                 .subvendor  = PCI_ANY_ID,
    2274                 :            :                 .subdevice  = PCI_ANY_ID,
    2275                 :            :                 .setup      = pci_pericom_setup_four_at_eight,
    2276                 :            :         },
    2277                 :            :         {
    2278                 :            :                 .vendor     = PCI_DEVICE_ID_ACCESIO_PCIE_ICM_4S,
    2279                 :            :                 .device     = PCI_DEVICE_ID_ACCESIO_PCIE_ICM232_4,
    2280                 :            :                 .subvendor  = PCI_ANY_ID,
    2281                 :            :                 .subdevice  = PCI_ANY_ID,
    2282                 :            :                 .setup      = pci_pericom_setup_four_at_eight,
    2283                 :            :         },
    2284                 :            :         {
    2285                 :            :                 .vendor     = PCI_VENDOR_ID_ACCESIO,
    2286                 :            :                 .device     = PCI_DEVICE_ID_ACCESIO_MPCIE_ICM232_4,
    2287                 :            :                 .subvendor  = PCI_ANY_ID,
    2288                 :            :                 .subdevice  = PCI_ANY_ID,
    2289                 :            :                 .setup      = pci_pericom_setup_four_at_eight,
    2290                 :            :         },
    2291                 :            :         {
    2292                 :            :                 .vendor     = PCI_VENDOR_ID_ACCESIO,
    2293                 :            :                 .device     = PCI_DEVICE_ID_ACCESIO_PCIE_COM422_4,
    2294                 :            :                 .subvendor  = PCI_ANY_ID,
    2295                 :            :                 .subdevice  = PCI_ANY_ID,
    2296                 :            :                 .setup      = pci_pericom_setup_four_at_eight,
    2297                 :            :         },
    2298                 :            :         {
    2299                 :            :                 .vendor     = PCI_VENDOR_ID_ACCESIO,
    2300                 :            :                 .device     = PCI_DEVICE_ID_ACCESIO_PCIE_COM485_4,
    2301                 :            :                 .subvendor  = PCI_ANY_ID,
    2302                 :            :                 .subdevice  = PCI_ANY_ID,
    2303                 :            :                 .setup      = pci_pericom_setup_four_at_eight,
    2304                 :            :         },
    2305                 :            :         {
    2306                 :            :                 .vendor     = PCI_VENDOR_ID_ACCESIO,
    2307                 :            :                 .device     = PCI_DEVICE_ID_ACCESIO_PCIE_COM232_4,
    2308                 :            :                 .subvendor  = PCI_ANY_ID,
    2309                 :            :                 .subdevice  = PCI_ANY_ID,
    2310                 :            :                 .setup      = pci_pericom_setup_four_at_eight,
    2311                 :            :         },
    2312                 :            :         {
    2313                 :            :                 .vendor     = PCI_VENDOR_ID_ACCESIO,
    2314                 :            :                 .device     = PCI_DEVICE_ID_ACCESIO_PCIE_COM_4SM,
    2315                 :            :                 .subvendor  = PCI_ANY_ID,
    2316                 :            :                 .subdevice  = PCI_ANY_ID,
    2317                 :            :                 .setup      = pci_pericom_setup_four_at_eight,
    2318                 :            :         },
    2319                 :            :         {
    2320                 :            :                 .vendor     = PCI_VENDOR_ID_ACCESIO,
    2321                 :            :                 .device     = PCI_DEVICE_ID_ACCESIO_PCIE_ICM_4SM,
    2322                 :            :                 .subvendor  = PCI_ANY_ID,
    2323                 :            :                 .subdevice  = PCI_ANY_ID,
    2324                 :            :                 .setup      = pci_pericom_setup_four_at_eight,
    2325                 :            :         },
    2326                 :            :         {
    2327                 :            :                 .vendor     = PCI_VENDOR_ID_ACCESIO,
    2328                 :            :                 .device     = PCI_ANY_ID,
    2329                 :            :                 .subvendor  = PCI_ANY_ID,
    2330                 :            :                 .subdevice  = PCI_ANY_ID,
    2331                 :            :                 .setup      = pci_pericom_setup,
    2332                 :            :         },      /*
    2333                 :            :          * SBS Technologies, Inc., PMC-OCTALPRO 232
    2334                 :            :          */
    2335                 :            :         {
    2336                 :            :                 .vendor         = PCI_VENDOR_ID_SBSMODULARIO,
    2337                 :            :                 .device         = PCI_DEVICE_ID_OCTPRO,
    2338                 :            :                 .subvendor      = PCI_SUBVENDOR_ID_SBSMODULARIO,
    2339                 :            :                 .subdevice      = PCI_SUBDEVICE_ID_OCTPRO232,
    2340                 :            :                 .init           = sbs_init,
    2341                 :            :                 .setup          = sbs_setup,
    2342                 :            :                 .exit           = sbs_exit,
    2343                 :            :         },
    2344                 :            :         /*
    2345                 :            :          * SBS Technologies, Inc., PMC-OCTALPRO 422
    2346                 :            :          */
    2347                 :            :         {
    2348                 :            :                 .vendor         = PCI_VENDOR_ID_SBSMODULARIO,
    2349                 :            :                 .device         = PCI_DEVICE_ID_OCTPRO,
    2350                 :            :                 .subvendor      = PCI_SUBVENDOR_ID_SBSMODULARIO,
    2351                 :            :                 .subdevice      = PCI_SUBDEVICE_ID_OCTPRO422,
    2352                 :            :                 .init           = sbs_init,
    2353                 :            :                 .setup          = sbs_setup,
    2354                 :            :                 .exit           = sbs_exit,
    2355                 :            :         },
    2356                 :            :         /*
    2357                 :            :          * SBS Technologies, Inc., P-Octal 232
    2358                 :            :          */
    2359                 :            :         {
    2360                 :            :                 .vendor         = PCI_VENDOR_ID_SBSMODULARIO,
    2361                 :            :                 .device         = PCI_DEVICE_ID_OCTPRO,
    2362                 :            :                 .subvendor      = PCI_SUBVENDOR_ID_SBSMODULARIO,
    2363                 :            :                 .subdevice      = PCI_SUBDEVICE_ID_POCTAL232,
    2364                 :            :                 .init           = sbs_init,
    2365                 :            :                 .setup          = sbs_setup,
    2366                 :            :                 .exit           = sbs_exit,
    2367                 :            :         },
    2368                 :            :         /*
    2369                 :            :          * SBS Technologies, Inc., P-Octal 422
    2370                 :            :          */
    2371                 :            :         {
    2372                 :            :                 .vendor         = PCI_VENDOR_ID_SBSMODULARIO,
    2373                 :            :                 .device         = PCI_DEVICE_ID_OCTPRO,
    2374                 :            :                 .subvendor      = PCI_SUBVENDOR_ID_SBSMODULARIO,
    2375                 :            :                 .subdevice      = PCI_SUBDEVICE_ID_POCTAL422,
    2376                 :            :                 .init           = sbs_init,
    2377                 :            :                 .setup          = sbs_setup,
    2378                 :            :                 .exit           = sbs_exit,
    2379                 :            :         },
    2380                 :            :         /*
    2381                 :            :          * SIIG cards - these may be called via parport_serial
    2382                 :            :          */
    2383                 :            :         {
    2384                 :            :                 .vendor         = PCI_VENDOR_ID_SIIG,
    2385                 :            :                 .device         = PCI_ANY_ID,
    2386                 :            :                 .subvendor      = PCI_ANY_ID,
    2387                 :            :                 .subdevice      = PCI_ANY_ID,
    2388                 :            :                 .init           = pci_siig_init,
    2389                 :            :                 .setup          = pci_siig_setup,
    2390                 :            :         },
    2391                 :            :         /*
    2392                 :            :          * Titan cards
    2393                 :            :          */
    2394                 :            :         {
    2395                 :            :                 .vendor         = PCI_VENDOR_ID_TITAN,
    2396                 :            :                 .device         = PCI_DEVICE_ID_TITAN_400L,
    2397                 :            :                 .subvendor      = PCI_ANY_ID,
    2398                 :            :                 .subdevice      = PCI_ANY_ID,
    2399                 :            :                 .setup          = titan_400l_800l_setup,
    2400                 :            :         },
    2401                 :            :         {
    2402                 :            :                 .vendor         = PCI_VENDOR_ID_TITAN,
    2403                 :            :                 .device         = PCI_DEVICE_ID_TITAN_800L,
    2404                 :            :                 .subvendor      = PCI_ANY_ID,
    2405                 :            :                 .subdevice      = PCI_ANY_ID,
    2406                 :            :                 .setup          = titan_400l_800l_setup,
    2407                 :            :         },
    2408                 :            :         /*
    2409                 :            :          * Timedia cards
    2410                 :            :          */
    2411                 :            :         {
    2412                 :            :                 .vendor         = PCI_VENDOR_ID_TIMEDIA,
    2413                 :            :                 .device         = PCI_DEVICE_ID_TIMEDIA_1889,
    2414                 :            :                 .subvendor      = PCI_VENDOR_ID_TIMEDIA,
    2415                 :            :                 .subdevice      = PCI_ANY_ID,
    2416                 :            :                 .probe          = pci_timedia_probe,
    2417                 :            :                 .init           = pci_timedia_init,
    2418                 :            :                 .setup          = pci_timedia_setup,
    2419                 :            :         },
    2420                 :            :         {
    2421                 :            :                 .vendor         = PCI_VENDOR_ID_TIMEDIA,
    2422                 :            :                 .device         = PCI_ANY_ID,
    2423                 :            :                 .subvendor      = PCI_ANY_ID,
    2424                 :            :                 .subdevice      = PCI_ANY_ID,
    2425                 :            :                 .setup          = pci_timedia_setup,
    2426                 :            :         },
    2427                 :            :         /*
    2428                 :            :          * Sunix PCI serial boards
    2429                 :            :          */
    2430                 :            :         {
    2431                 :            :                 .vendor         = PCI_VENDOR_ID_SUNIX,
    2432                 :            :                 .device         = PCI_DEVICE_ID_SUNIX_1999,
    2433                 :            :                 .subvendor      = PCI_VENDOR_ID_SUNIX,
    2434                 :            :                 .subdevice      = PCI_ANY_ID,
    2435                 :            :                 .setup          = pci_sunix_setup,
    2436                 :            :         },
    2437                 :            :         /*
    2438                 :            :          * Xircom cards
    2439                 :            :          */
    2440                 :            :         {
    2441                 :            :                 .vendor         = PCI_VENDOR_ID_XIRCOM,
    2442                 :            :                 .device         = PCI_DEVICE_ID_XIRCOM_X3201_MDM,
    2443                 :            :                 .subvendor      = PCI_ANY_ID,
    2444                 :            :                 .subdevice      = PCI_ANY_ID,
    2445                 :            :                 .init           = pci_xircom_init,
    2446                 :            :                 .setup          = pci_default_setup,
    2447                 :            :         },
    2448                 :            :         /*
    2449                 :            :          * Netmos cards - these may be called via parport_serial
    2450                 :            :          */
    2451                 :            :         {
    2452                 :            :                 .vendor         = PCI_VENDOR_ID_NETMOS,
    2453                 :            :                 .device         = PCI_ANY_ID,
    2454                 :            :                 .subvendor      = PCI_ANY_ID,
    2455                 :            :                 .subdevice      = PCI_ANY_ID,
    2456                 :            :                 .init           = pci_netmos_init,
    2457                 :            :                 .setup          = pci_netmos_9900_setup,
    2458                 :            :         },
    2459                 :            :         /*
    2460                 :            :          * EndRun Technologies
    2461                 :            :         */
    2462                 :            :         {
    2463                 :            :                 .vendor         = PCI_VENDOR_ID_ENDRUN,
    2464                 :            :                 .device         = PCI_ANY_ID,
    2465                 :            :                 .subvendor      = PCI_ANY_ID,
    2466                 :            :                 .subdevice      = PCI_ANY_ID,
    2467                 :            :                 .init           = pci_endrun_init,
    2468                 :            :                 .setup          = pci_default_setup,
    2469                 :            :         },
    2470                 :            :         /*
    2471                 :            :          * For Oxford Semiconductor Tornado based devices
    2472                 :            :          */
    2473                 :            :         {
    2474                 :            :                 .vendor         = PCI_VENDOR_ID_OXSEMI,
    2475                 :            :                 .device         = PCI_ANY_ID,
    2476                 :            :                 .subvendor      = PCI_ANY_ID,
    2477                 :            :                 .subdevice      = PCI_ANY_ID,
    2478                 :            :                 .init           = pci_oxsemi_tornado_init,
    2479                 :            :                 .setup          = pci_default_setup,
    2480                 :            :         },
    2481                 :            :         {
    2482                 :            :                 .vendor         = PCI_VENDOR_ID_MAINPINE,
    2483                 :            :                 .device         = PCI_ANY_ID,
    2484                 :            :                 .subvendor      = PCI_ANY_ID,
    2485                 :            :                 .subdevice      = PCI_ANY_ID,
    2486                 :            :                 .init           = pci_oxsemi_tornado_init,
    2487                 :            :                 .setup          = pci_default_setup,
    2488                 :            :         },
    2489                 :            :         {
    2490                 :            :                 .vendor         = PCI_VENDOR_ID_DIGI,
    2491                 :            :                 .device         = PCIE_DEVICE_ID_NEO_2_OX_IBM,
    2492                 :            :                 .subvendor              = PCI_SUBVENDOR_ID_IBM,
    2493                 :            :                 .subdevice              = PCI_ANY_ID,
    2494                 :            :                 .init                   = pci_oxsemi_tornado_init,
    2495                 :            :                 .setup          = pci_default_setup,
    2496                 :            :         },
    2497                 :            :         {
    2498                 :            :                 .vendor         = PCI_VENDOR_ID_INTEL,
    2499                 :            :                 .device         = 0x8811,
    2500                 :            :                 .subvendor      = PCI_ANY_ID,
    2501                 :            :                 .subdevice      = PCI_ANY_ID,
    2502                 :            :                 .init           = pci_eg20t_init,
    2503                 :            :                 .setup          = pci_default_setup,
    2504                 :            :         },
    2505                 :            :         {
    2506                 :            :                 .vendor         = PCI_VENDOR_ID_INTEL,
    2507                 :            :                 .device         = 0x8812,
    2508                 :            :                 .subvendor      = PCI_ANY_ID,
    2509                 :            :                 .subdevice      = PCI_ANY_ID,
    2510                 :            :                 .init           = pci_eg20t_init,
    2511                 :            :                 .setup          = pci_default_setup,
    2512                 :            :         },
    2513                 :            :         {
    2514                 :            :                 .vendor         = PCI_VENDOR_ID_INTEL,
    2515                 :            :                 .device         = 0x8813,
    2516                 :            :                 .subvendor      = PCI_ANY_ID,
    2517                 :            :                 .subdevice      = PCI_ANY_ID,
    2518                 :            :                 .init           = pci_eg20t_init,
    2519                 :            :                 .setup          = pci_default_setup,
    2520                 :            :         },
    2521                 :            :         {
    2522                 :            :                 .vendor         = PCI_VENDOR_ID_INTEL,
    2523                 :            :                 .device         = 0x8814,
    2524                 :            :                 .subvendor      = PCI_ANY_ID,
    2525                 :            :                 .subdevice      = PCI_ANY_ID,
    2526                 :            :                 .init           = pci_eg20t_init,
    2527                 :            :                 .setup          = pci_default_setup,
    2528                 :            :         },
    2529                 :            :         {
    2530                 :            :                 .vendor         = 0x10DB,
    2531                 :            :                 .device         = 0x8027,
    2532                 :            :                 .subvendor      = PCI_ANY_ID,
    2533                 :            :                 .subdevice      = PCI_ANY_ID,
    2534                 :            :                 .init           = pci_eg20t_init,
    2535                 :            :                 .setup          = pci_default_setup,
    2536                 :            :         },
    2537                 :            :         {
    2538                 :            :                 .vendor         = 0x10DB,
    2539                 :            :                 .device         = 0x8028,
    2540                 :            :                 .subvendor      = PCI_ANY_ID,
    2541                 :            :                 .subdevice      = PCI_ANY_ID,
    2542                 :            :                 .init           = pci_eg20t_init,
    2543                 :            :                 .setup          = pci_default_setup,
    2544                 :            :         },
    2545                 :            :         {
    2546                 :            :                 .vendor         = 0x10DB,
    2547                 :            :                 .device         = 0x8029,
    2548                 :            :                 .subvendor      = PCI_ANY_ID,
    2549                 :            :                 .subdevice      = PCI_ANY_ID,
    2550                 :            :                 .init           = pci_eg20t_init,
    2551                 :            :                 .setup          = pci_default_setup,
    2552                 :            :         },
    2553                 :            :         {
    2554                 :            :                 .vendor         = 0x10DB,
    2555                 :            :                 .device         = 0x800C,
    2556                 :            :                 .subvendor      = PCI_ANY_ID,
    2557                 :            :                 .subdevice      = PCI_ANY_ID,
    2558                 :            :                 .init           = pci_eg20t_init,
    2559                 :            :                 .setup          = pci_default_setup,
    2560                 :            :         },
    2561                 :            :         {
    2562                 :            :                 .vendor         = 0x10DB,
    2563                 :            :                 .device         = 0x800D,
    2564                 :            :                 .subvendor      = PCI_ANY_ID,
    2565                 :            :                 .subdevice      = PCI_ANY_ID,
    2566                 :            :                 .init           = pci_eg20t_init,
    2567                 :            :                 .setup          = pci_default_setup,
    2568                 :            :         },
    2569                 :            :         /*
    2570                 :            :          * Cronyx Omega PCI (PLX-chip based)
    2571                 :            :          */
    2572                 :            :         {
    2573                 :            :                 .vendor         = PCI_VENDOR_ID_PLX,
    2574                 :            :                 .device         = PCI_DEVICE_ID_PLX_CRONYX_OMEGA,
    2575                 :            :                 .subvendor      = PCI_ANY_ID,
    2576                 :            :                 .subdevice      = PCI_ANY_ID,
    2577                 :            :                 .setup          = pci_omegapci_setup,
    2578                 :            :         },
    2579                 :            :         /* WCH CH353 1S1P card (16550 clone) */
    2580                 :            :         {
    2581                 :            :                 .vendor         = PCI_VENDOR_ID_WCH,
    2582                 :            :                 .device         = PCI_DEVICE_ID_WCH_CH353_1S1P,
    2583                 :            :                 .subvendor      = PCI_ANY_ID,
    2584                 :            :                 .subdevice      = PCI_ANY_ID,
    2585                 :            :                 .setup          = pci_wch_ch353_setup,
    2586                 :            :         },
    2587                 :            :         /* WCH CH353 2S1P card (16550 clone) */
    2588                 :            :         {
    2589                 :            :                 .vendor         = PCI_VENDOR_ID_WCH,
    2590                 :            :                 .device         = PCI_DEVICE_ID_WCH_CH353_2S1P,
    2591                 :            :                 .subvendor      = PCI_ANY_ID,
    2592                 :            :                 .subdevice      = PCI_ANY_ID,
    2593                 :            :                 .setup          = pci_wch_ch353_setup,
    2594                 :            :         },
    2595                 :            :         /* WCH CH353 4S card (16550 clone) */
    2596                 :            :         {
    2597                 :            :                 .vendor         = PCI_VENDOR_ID_WCH,
    2598                 :            :                 .device         = PCI_DEVICE_ID_WCH_CH353_4S,
    2599                 :            :                 .subvendor      = PCI_ANY_ID,
    2600                 :            :                 .subdevice      = PCI_ANY_ID,
    2601                 :            :                 .setup          = pci_wch_ch353_setup,
    2602                 :            :         },
    2603                 :            :         /* WCH CH353 2S1PF card (16550 clone) */
    2604                 :            :         {
    2605                 :            :                 .vendor         = PCI_VENDOR_ID_WCH,
    2606                 :            :                 .device         = PCI_DEVICE_ID_WCH_CH353_2S1PF,
    2607                 :            :                 .subvendor      = PCI_ANY_ID,
    2608                 :            :                 .subdevice      = PCI_ANY_ID,
    2609                 :            :                 .setup          = pci_wch_ch353_setup,
    2610                 :            :         },
    2611                 :            :         /* WCH CH352 2S card (16550 clone) */
    2612                 :            :         {
    2613                 :            :                 .vendor         = PCI_VENDOR_ID_WCH,
    2614                 :            :                 .device         = PCI_DEVICE_ID_WCH_CH352_2S,
    2615                 :            :                 .subvendor      = PCI_ANY_ID,
    2616                 :            :                 .subdevice      = PCI_ANY_ID,
    2617                 :            :                 .setup          = pci_wch_ch353_setup,
    2618                 :            :         },
    2619                 :            :         /* WCH CH355 4S card (16550 clone) */
    2620                 :            :         {
    2621                 :            :                 .vendor         = PCI_VENDOR_ID_WCH,
    2622                 :            :                 .device         = PCI_DEVICE_ID_WCH_CH355_4S,
    2623                 :            :                 .subvendor      = PCI_ANY_ID,
    2624                 :            :                 .subdevice      = PCI_ANY_ID,
    2625                 :            :                 .setup          = pci_wch_ch355_setup,
    2626                 :            :         },
    2627                 :            :         /* WCH CH382 2S card (16850 clone) */
    2628                 :            :         {
    2629                 :            :                 .vendor         = PCIE_VENDOR_ID_WCH,
    2630                 :            :                 .device         = PCIE_DEVICE_ID_WCH_CH382_2S,
    2631                 :            :                 .subvendor      = PCI_ANY_ID,
    2632                 :            :                 .subdevice      = PCI_ANY_ID,
    2633                 :            :                 .setup          = pci_wch_ch38x_setup,
    2634                 :            :         },
    2635                 :            :         /* WCH CH382 2S1P card (16850 clone) */
    2636                 :            :         {
    2637                 :            :                 .vendor         = PCIE_VENDOR_ID_WCH,
    2638                 :            :                 .device         = PCIE_DEVICE_ID_WCH_CH382_2S1P,
    2639                 :            :                 .subvendor      = PCI_ANY_ID,
    2640                 :            :                 .subdevice      = PCI_ANY_ID,
    2641                 :            :                 .setup          = pci_wch_ch38x_setup,
    2642                 :            :         },
    2643                 :            :         /* WCH CH384 4S card (16850 clone) */
    2644                 :            :         {
    2645                 :            :                 .vendor         = PCIE_VENDOR_ID_WCH,
    2646                 :            :                 .device         = PCIE_DEVICE_ID_WCH_CH384_4S,
    2647                 :            :                 .subvendor      = PCI_ANY_ID,
    2648                 :            :                 .subdevice      = PCI_ANY_ID,
    2649                 :            :                 .setup          = pci_wch_ch38x_setup,
    2650                 :            :         },
    2651                 :            :         /*
    2652                 :            :          * ASIX devices with FIFO bug
    2653                 :            :          */
    2654                 :            :         {
    2655                 :            :                 .vendor         = PCI_VENDOR_ID_ASIX,
    2656                 :            :                 .device         = PCI_ANY_ID,
    2657                 :            :                 .subvendor      = PCI_ANY_ID,
    2658                 :            :                 .subdevice      = PCI_ANY_ID,
    2659                 :            :                 .setup          = pci_asix_setup,
    2660                 :            :         },
    2661                 :            :         /*
    2662                 :            :          * Broadcom TruManage (NetXtreme)
    2663                 :            :          */
    2664                 :            :         {
    2665                 :            :                 .vendor         = PCI_VENDOR_ID_BROADCOM,
    2666                 :            :                 .device         = PCI_DEVICE_ID_BROADCOM_TRUMANAGE,
    2667                 :            :                 .subvendor      = PCI_ANY_ID,
    2668                 :            :                 .subdevice      = PCI_ANY_ID,
    2669                 :            :                 .setup          = pci_brcm_trumanage_setup,
    2670                 :            :         },
    2671                 :            :         {
    2672                 :            :                 .vendor         = 0x1c29,
    2673                 :            :                 .device         = 0x1104,
    2674                 :            :                 .subvendor      = PCI_ANY_ID,
    2675                 :            :                 .subdevice      = PCI_ANY_ID,
    2676                 :            :                 .setup          = pci_fintek_setup,
    2677                 :            :                 .init           = pci_fintek_init,
    2678                 :            :         },
    2679                 :            :         {
    2680                 :            :                 .vendor         = 0x1c29,
    2681                 :            :                 .device         = 0x1108,
    2682                 :            :                 .subvendor      = PCI_ANY_ID,
    2683                 :            :                 .subdevice      = PCI_ANY_ID,
    2684                 :            :                 .setup          = pci_fintek_setup,
    2685                 :            :                 .init           = pci_fintek_init,
    2686                 :            :         },
    2687                 :            :         {
    2688                 :            :                 .vendor         = 0x1c29,
    2689                 :            :                 .device         = 0x1112,
    2690                 :            :                 .subvendor      = PCI_ANY_ID,
    2691                 :            :                 .subdevice      = PCI_ANY_ID,
    2692                 :            :                 .setup          = pci_fintek_setup,
    2693                 :            :                 .init           = pci_fintek_init,
    2694                 :            :         },
    2695                 :            :         /*
    2696                 :            :          * MOXA
    2697                 :            :          */
    2698                 :            :         {
    2699                 :            :                 .vendor         = PCI_VENDOR_ID_MOXA,
    2700                 :            :                 .device         = PCI_ANY_ID,
    2701                 :            :                 .subvendor      = PCI_ANY_ID,
    2702                 :            :                 .subdevice      = PCI_ANY_ID,
    2703                 :            :                 .setup          = pci_moxa_setup,
    2704                 :            :         },
    2705                 :            :         {
    2706                 :            :                 .vendor         = 0x1c29,
    2707                 :            :                 .device         = 0x1204,
    2708                 :            :                 .subvendor      = PCI_ANY_ID,
    2709                 :            :                 .subdevice      = PCI_ANY_ID,
    2710                 :            :                 .setup          = pci_fintek_f815xxa_setup,
    2711                 :            :                 .init           = pci_fintek_f815xxa_init,
    2712                 :            :         },
    2713                 :            :         {
    2714                 :            :                 .vendor         = 0x1c29,
    2715                 :            :                 .device         = 0x1208,
    2716                 :            :                 .subvendor      = PCI_ANY_ID,
    2717                 :            :                 .subdevice      = PCI_ANY_ID,
    2718                 :            :                 .setup          = pci_fintek_f815xxa_setup,
    2719                 :            :                 .init           = pci_fintek_f815xxa_init,
    2720                 :            :         },
    2721                 :            :         {
    2722                 :            :                 .vendor         = 0x1c29,
    2723                 :            :                 .device         = 0x1212,
    2724                 :            :                 .subvendor      = PCI_ANY_ID,
    2725                 :            :                 .subdevice      = PCI_ANY_ID,
    2726                 :            :                 .setup          = pci_fintek_f815xxa_setup,
    2727                 :            :                 .init           = pci_fintek_f815xxa_init,
    2728                 :            :         },
    2729                 :            : 
    2730                 :            :         /*
    2731                 :            :          * Default "match everything" terminator entry
    2732                 :            :          */
    2733                 :            :         {
    2734                 :            :                 .vendor         = PCI_ANY_ID,
    2735                 :            :                 .device         = PCI_ANY_ID,
    2736                 :            :                 .subvendor      = PCI_ANY_ID,
    2737                 :            :                 .subdevice      = PCI_ANY_ID,
    2738                 :            :                 .setup          = pci_default_setup,
    2739                 :            :         }
    2740                 :            : };
    2741                 :            : 
    2742                 :       1974 : static inline int quirk_id_matches(u32 quirk_id, u32 dev_id)
    2743                 :            : {
    2744                 :       1974 :         return quirk_id == PCI_ANY_ID || quirk_id == dev_id;
    2745                 :            : }
    2746                 :            : 
    2747                 :         21 : static struct pci_serial_quirk *find_quirk(struct pci_dev *dev)
    2748                 :            : {
    2749                 :         21 :         struct pci_serial_quirk *quirk;
    2750                 :            : 
    2751                 :       1911 :         for (quirk = pci_serial_quirks; ; quirk++)
    2752         [ +  + ]:       1911 :                 if (quirk_id_matches(quirk->vendor, dev->vendor) &&
    2753         [ +  - ]:         21 :                     quirk_id_matches(quirk->device, dev->device) &&
    2754         [ +  - ]:         21 :                     quirk_id_matches(quirk->subvendor, dev->subsystem_vendor) &&
    2755         [ -  + ]:         21 :                     quirk_id_matches(quirk->subdevice, dev->subsystem_device))
    2756                 :            :                         break;
    2757                 :         21 :         return quirk;
    2758                 :            : }
    2759                 :            : 
    2760                 :            : static inline int get_pci_irq(struct pci_dev *dev,
    2761                 :            :                                 const struct pciserial_board *board)
    2762                 :            : {
    2763                 :            :         if (board->flags & FL_NOIRQ)
    2764                 :            :                 return 0;
    2765                 :            :         else
    2766                 :            :                 return dev->irq;
    2767                 :            : }
    2768                 :            : 
    2769                 :            : /*
    2770                 :            :  * This is the configuration table for all of the PCI serial boards
    2771                 :            :  * which we support.  It is directly indexed by the pci_board_num_t enum
    2772                 :            :  * value, which is encoded in the pci_device_id PCI probe table's
    2773                 :            :  * driver_data member.
    2774                 :            :  *
    2775                 :            :  * The makeup of these names are:
    2776                 :            :  *  pbn_bn{_bt}_n_baud{_offsetinhex}
    2777                 :            :  *
    2778                 :            :  *  bn          = PCI BAR number
    2779                 :            :  *  bt          = Index using PCI BARs
    2780                 :            :  *  n           = number of serial ports
    2781                 :            :  *  baud        = baud rate
    2782                 :            :  *  offsetinhex = offset for each sequential port (in hex)
    2783                 :            :  *
    2784                 :            :  * This table is sorted by (in order): bn, bt, baud, offsetindex, n.
    2785                 :            :  *
    2786                 :            :  * Please note: in theory if n = 1, _bt infix should make no difference.
    2787                 :            :  * ie, pbn_b0_1_115200 is the same as pbn_b0_bt_1_115200
    2788                 :            :  */
    2789                 :            : enum pci_board_num_t {
    2790                 :            :         pbn_default = 0,
    2791                 :            : 
    2792                 :            :         pbn_b0_1_115200,
    2793                 :            :         pbn_b0_2_115200,
    2794                 :            :         pbn_b0_4_115200,
    2795                 :            :         pbn_b0_5_115200,
    2796                 :            :         pbn_b0_8_115200,
    2797                 :            : 
    2798                 :            :         pbn_b0_1_921600,
    2799                 :            :         pbn_b0_2_921600,
    2800                 :            :         pbn_b0_4_921600,
    2801                 :            : 
    2802                 :            :         pbn_b0_2_1130000,
    2803                 :            : 
    2804                 :            :         pbn_b0_4_1152000,
    2805                 :            : 
    2806                 :            :         pbn_b0_4_1250000,
    2807                 :            : 
    2808                 :            :         pbn_b0_2_1843200,
    2809                 :            :         pbn_b0_4_1843200,
    2810                 :            : 
    2811                 :            :         pbn_b0_1_4000000,
    2812                 :            : 
    2813                 :            :         pbn_b0_bt_1_115200,
    2814                 :            :         pbn_b0_bt_2_115200,
    2815                 :            :         pbn_b0_bt_4_115200,
    2816                 :            :         pbn_b0_bt_8_115200,
    2817                 :            : 
    2818                 :            :         pbn_b0_bt_1_460800,
    2819                 :            :         pbn_b0_bt_2_460800,
    2820                 :            :         pbn_b0_bt_4_460800,
    2821                 :            : 
    2822                 :            :         pbn_b0_bt_1_921600,
    2823                 :            :         pbn_b0_bt_2_921600,
    2824                 :            :         pbn_b0_bt_4_921600,
    2825                 :            :         pbn_b0_bt_8_921600,
    2826                 :            : 
    2827                 :            :         pbn_b1_1_115200,
    2828                 :            :         pbn_b1_2_115200,
    2829                 :            :         pbn_b1_4_115200,
    2830                 :            :         pbn_b1_8_115200,
    2831                 :            :         pbn_b1_16_115200,
    2832                 :            : 
    2833                 :            :         pbn_b1_1_921600,
    2834                 :            :         pbn_b1_2_921600,
    2835                 :            :         pbn_b1_4_921600,
    2836                 :            :         pbn_b1_8_921600,
    2837                 :            : 
    2838                 :            :         pbn_b1_2_1250000,
    2839                 :            : 
    2840                 :            :         pbn_b1_bt_1_115200,
    2841                 :            :         pbn_b1_bt_2_115200,
    2842                 :            :         pbn_b1_bt_4_115200,
    2843                 :            : 
    2844                 :            :         pbn_b1_bt_2_921600,
    2845                 :            : 
    2846                 :            :         pbn_b1_1_1382400,
    2847                 :            :         pbn_b1_2_1382400,
    2848                 :            :         pbn_b1_4_1382400,
    2849                 :            :         pbn_b1_8_1382400,
    2850                 :            : 
    2851                 :            :         pbn_b2_1_115200,
    2852                 :            :         pbn_b2_2_115200,
    2853                 :            :         pbn_b2_4_115200,
    2854                 :            :         pbn_b2_8_115200,
    2855                 :            : 
    2856                 :            :         pbn_b2_1_460800,
    2857                 :            :         pbn_b2_4_460800,
    2858                 :            :         pbn_b2_8_460800,
    2859                 :            :         pbn_b2_16_460800,
    2860                 :            : 
    2861                 :            :         pbn_b2_1_921600,
    2862                 :            :         pbn_b2_4_921600,
    2863                 :            :         pbn_b2_8_921600,
    2864                 :            : 
    2865                 :            :         pbn_b2_8_1152000,
    2866                 :            : 
    2867                 :            :         pbn_b2_bt_1_115200,
    2868                 :            :         pbn_b2_bt_2_115200,
    2869                 :            :         pbn_b2_bt_4_115200,
    2870                 :            : 
    2871                 :            :         pbn_b2_bt_2_921600,
    2872                 :            :         pbn_b2_bt_4_921600,
    2873                 :            : 
    2874                 :            :         pbn_b3_2_115200,
    2875                 :            :         pbn_b3_4_115200,
    2876                 :            :         pbn_b3_8_115200,
    2877                 :            : 
    2878                 :            :         pbn_b4_bt_2_921600,
    2879                 :            :         pbn_b4_bt_4_921600,
    2880                 :            :         pbn_b4_bt_8_921600,
    2881                 :            : 
    2882                 :            :         /*
    2883                 :            :          * Board-specific versions.
    2884                 :            :          */
    2885                 :            :         pbn_panacom,
    2886                 :            :         pbn_panacom2,
    2887                 :            :         pbn_panacom4,
    2888                 :            :         pbn_plx_romulus,
    2889                 :            :         pbn_endrun_2_4000000,
    2890                 :            :         pbn_oxsemi,
    2891                 :            :         pbn_oxsemi_1_4000000,
    2892                 :            :         pbn_oxsemi_2_4000000,
    2893                 :            :         pbn_oxsemi_4_4000000,
    2894                 :            :         pbn_oxsemi_8_4000000,
    2895                 :            :         pbn_intel_i960,
    2896                 :            :         pbn_sgi_ioc3,
    2897                 :            :         pbn_computone_4,
    2898                 :            :         pbn_computone_6,
    2899                 :            :         pbn_computone_8,
    2900                 :            :         pbn_sbsxrsio,
    2901                 :            :         pbn_pasemi_1682M,
    2902                 :            :         pbn_ni8430_2,
    2903                 :            :         pbn_ni8430_4,
    2904                 :            :         pbn_ni8430_8,
    2905                 :            :         pbn_ni8430_16,
    2906                 :            :         pbn_ADDIDATA_PCIe_1_3906250,
    2907                 :            :         pbn_ADDIDATA_PCIe_2_3906250,
    2908                 :            :         pbn_ADDIDATA_PCIe_4_3906250,
    2909                 :            :         pbn_ADDIDATA_PCIe_8_3906250,
    2910                 :            :         pbn_ce4100_1_115200,
    2911                 :            :         pbn_omegapci,
    2912                 :            :         pbn_NETMOS9900_2s_115200,
    2913                 :            :         pbn_brcm_trumanage,
    2914                 :            :         pbn_fintek_4,
    2915                 :            :         pbn_fintek_8,
    2916                 :            :         pbn_fintek_12,
    2917                 :            :         pbn_fintek_F81504A,
    2918                 :            :         pbn_fintek_F81508A,
    2919                 :            :         pbn_fintek_F81512A,
    2920                 :            :         pbn_wch382_2,
    2921                 :            :         pbn_wch384_4,
    2922                 :            :         pbn_pericom_PI7C9X7951,
    2923                 :            :         pbn_pericom_PI7C9X7952,
    2924                 :            :         pbn_pericom_PI7C9X7954,
    2925                 :            :         pbn_pericom_PI7C9X7958,
    2926                 :            :         pbn_sunix_pci_1s,
    2927                 :            :         pbn_sunix_pci_2s,
    2928                 :            :         pbn_sunix_pci_4s,
    2929                 :            :         pbn_sunix_pci_8s,
    2930                 :            :         pbn_sunix_pci_16s,
    2931                 :            :         pbn_moxa8250_2p,
    2932                 :            :         pbn_moxa8250_4p,
    2933                 :            :         pbn_moxa8250_8p,
    2934                 :            : };
    2935                 :            : 
    2936                 :            : /*
    2937                 :            :  * uart_offset - the space between channels
    2938                 :            :  * reg_shift   - describes how the UART registers are mapped
    2939                 :            :  *               to PCI memory by the card.
    2940                 :            :  * For example IER register on SBS, Inc. PMC-OctPro is located at
    2941                 :            :  * offset 0x10 from the UART base, while UART_IER is defined as 1
    2942                 :            :  * in include/linux/serial_reg.h,
    2943                 :            :  * see first lines of serial_in() and serial_out() in 8250.c
    2944                 :            : */
    2945                 :            : 
    2946                 :            : static struct pciserial_board pci_boards[] = {
    2947                 :            :         [pbn_default] = {
    2948                 :            :                 .flags          = FL_BASE0,
    2949                 :            :                 .num_ports      = 1,
    2950                 :            :                 .base_baud      = 115200,
    2951                 :            :                 .uart_offset    = 8,
    2952                 :            :         },
    2953                 :            :         [pbn_b0_1_115200] = {
    2954                 :            :                 .flags          = FL_BASE0,
    2955                 :            :                 .num_ports      = 1,
    2956                 :            :                 .base_baud      = 115200,
    2957                 :            :                 .uart_offset    = 8,
    2958                 :            :         },
    2959                 :            :         [pbn_b0_2_115200] = {
    2960                 :            :                 .flags          = FL_BASE0,
    2961                 :            :                 .num_ports      = 2,
    2962                 :            :                 .base_baud      = 115200,
    2963                 :            :                 .uart_offset    = 8,
    2964                 :            :         },
    2965                 :            :         [pbn_b0_4_115200] = {
    2966                 :            :                 .flags          = FL_BASE0,
    2967                 :            :                 .num_ports      = 4,
    2968                 :            :                 .base_baud      = 115200,
    2969                 :            :                 .uart_offset    = 8,
    2970                 :            :         },
    2971                 :            :         [pbn_b0_5_115200] = {
    2972                 :            :                 .flags          = FL_BASE0,
    2973                 :            :                 .num_ports      = 5,
    2974                 :            :                 .base_baud      = 115200,
    2975                 :            :                 .uart_offset    = 8,
    2976                 :            :         },
    2977                 :            :         [pbn_b0_8_115200] = {
    2978                 :            :                 .flags          = FL_BASE0,
    2979                 :            :                 .num_ports      = 8,
    2980                 :            :                 .base_baud      = 115200,
    2981                 :            :                 .uart_offset    = 8,
    2982                 :            :         },
    2983                 :            :         [pbn_b0_1_921600] = {
    2984                 :            :                 .flags          = FL_BASE0,
    2985                 :            :                 .num_ports      = 1,
    2986                 :            :                 .base_baud      = 921600,
    2987                 :            :                 .uart_offset    = 8,
    2988                 :            :         },
    2989                 :            :         [pbn_b0_2_921600] = {
    2990                 :            :                 .flags          = FL_BASE0,
    2991                 :            :                 .num_ports      = 2,
    2992                 :            :                 .base_baud      = 921600,
    2993                 :            :                 .uart_offset    = 8,
    2994                 :            :         },
    2995                 :            :         [pbn_b0_4_921600] = {
    2996                 :            :                 .flags          = FL_BASE0,
    2997                 :            :                 .num_ports      = 4,
    2998                 :            :                 .base_baud      = 921600,
    2999                 :            :                 .uart_offset    = 8,
    3000                 :            :         },
    3001                 :            : 
    3002                 :            :         [pbn_b0_2_1130000] = {
    3003                 :            :                 .flags          = FL_BASE0,
    3004                 :            :                 .num_ports      = 2,
    3005                 :            :                 .base_baud      = 1130000,
    3006                 :            :                 .uart_offset    = 8,
    3007                 :            :         },
    3008                 :            : 
    3009                 :            :         [pbn_b0_4_1152000] = {
    3010                 :            :                 .flags          = FL_BASE0,
    3011                 :            :                 .num_ports      = 4,
    3012                 :            :                 .base_baud      = 1152000,
    3013                 :            :                 .uart_offset    = 8,
    3014                 :            :         },
    3015                 :            : 
    3016                 :            :         [pbn_b0_4_1250000] = {
    3017                 :            :                 .flags          = FL_BASE0,
    3018                 :            :                 .num_ports      = 4,
    3019                 :            :                 .base_baud      = 1250000,
    3020                 :            :                 .uart_offset    = 8,
    3021                 :            :         },
    3022                 :            : 
    3023                 :            :         [pbn_b0_2_1843200] = {
    3024                 :            :                 .flags          = FL_BASE0,
    3025                 :            :                 .num_ports      = 2,
    3026                 :            :                 .base_baud      = 1843200,
    3027                 :            :                 .uart_offset    = 8,
    3028                 :            :         },
    3029                 :            :         [pbn_b0_4_1843200] = {
    3030                 :            :                 .flags          = FL_BASE0,
    3031                 :            :                 .num_ports      = 4,
    3032                 :            :                 .base_baud      = 1843200,
    3033                 :            :                 .uart_offset    = 8,
    3034                 :            :         },
    3035                 :            : 
    3036                 :            :         [pbn_b0_1_4000000] = {
    3037                 :            :                 .flags          = FL_BASE0,
    3038                 :            :                 .num_ports      = 1,
    3039                 :            :                 .base_baud      = 4000000,
    3040                 :            :                 .uart_offset    = 8,
    3041                 :            :         },
    3042                 :            : 
    3043                 :            :         [pbn_b0_bt_1_115200] = {
    3044                 :            :                 .flags          = FL_BASE0|FL_BASE_BARS,
    3045                 :            :                 .num_ports      = 1,
    3046                 :            :                 .base_baud      = 115200,
    3047                 :            :                 .uart_offset    = 8,
    3048                 :            :         },
    3049                 :            :         [pbn_b0_bt_2_115200] = {
    3050                 :            :                 .flags          = FL_BASE0|FL_BASE_BARS,
    3051                 :            :                 .num_ports      = 2,
    3052                 :            :                 .base_baud      = 115200,
    3053                 :            :                 .uart_offset    = 8,
    3054                 :            :         },
    3055                 :            :         [pbn_b0_bt_4_115200] = {
    3056                 :            :                 .flags          = FL_BASE0|FL_BASE_BARS,
    3057                 :            :                 .num_ports      = 4,
    3058                 :            :                 .base_baud      = 115200,
    3059                 :            :                 .uart_offset    = 8,
    3060                 :            :         },
    3061                 :            :         [pbn_b0_bt_8_115200] = {
    3062                 :            :                 .flags          = FL_BASE0|FL_BASE_BARS,
    3063                 :            :                 .num_ports      = 8,
    3064                 :            :                 .base_baud      = 115200,
    3065                 :            :                 .uart_offset    = 8,
    3066                 :            :         },
    3067                 :            : 
    3068                 :            :         [pbn_b0_bt_1_460800] = {
    3069                 :            :                 .flags          = FL_BASE0|FL_BASE_BARS,
    3070                 :            :                 .num_ports      = 1,
    3071                 :            :                 .base_baud      = 460800,
    3072                 :            :                 .uart_offset    = 8,
    3073                 :            :         },
    3074                 :            :         [pbn_b0_bt_2_460800] = {
    3075                 :            :                 .flags          = FL_BASE0|FL_BASE_BARS,
    3076                 :            :                 .num_ports      = 2,
    3077                 :            :                 .base_baud      = 460800,
    3078                 :            :                 .uart_offset    = 8,
    3079                 :            :         },
    3080                 :            :         [pbn_b0_bt_4_460800] = {
    3081                 :            :                 .flags          = FL_BASE0|FL_BASE_BARS,
    3082                 :            :                 .num_ports      = 4,
    3083                 :            :                 .base_baud      = 460800,
    3084                 :            :                 .uart_offset    = 8,
    3085                 :            :         },
    3086                 :            : 
    3087                 :            :         [pbn_b0_bt_1_921600] = {
    3088                 :            :                 .flags          = FL_BASE0|FL_BASE_BARS,
    3089                 :            :                 .num_ports      = 1,
    3090                 :            :                 .base_baud      = 921600,
    3091                 :            :                 .uart_offset    = 8,
    3092                 :            :         },
    3093                 :            :         [pbn_b0_bt_2_921600] = {
    3094                 :            :                 .flags          = FL_BASE0|FL_BASE_BARS,
    3095                 :            :                 .num_ports      = 2,
    3096                 :            :                 .base_baud      = 921600,
    3097                 :            :                 .uart_offset    = 8,
    3098                 :            :         },
    3099                 :            :         [pbn_b0_bt_4_921600] = {
    3100                 :            :                 .flags          = FL_BASE0|FL_BASE_BARS,
    3101                 :            :                 .num_ports      = 4,
    3102                 :            :                 .base_baud      = 921600,
    3103                 :            :                 .uart_offset    = 8,
    3104                 :            :         },
    3105                 :            :         [pbn_b0_bt_8_921600] = {
    3106                 :            :                 .flags          = FL_BASE0|FL_BASE_BARS,
    3107                 :            :                 .num_ports      = 8,
    3108                 :            :                 .base_baud      = 921600,
    3109                 :            :                 .uart_offset    = 8,
    3110                 :            :         },
    3111                 :            : 
    3112                 :            :         [pbn_b1_1_115200] = {
    3113                 :            :                 .flags          = FL_BASE1,
    3114                 :            :                 .num_ports      = 1,
    3115                 :            :                 .base_baud      = 115200,
    3116                 :            :                 .uart_offset    = 8,
    3117                 :            :         },
    3118                 :            :         [pbn_b1_2_115200] = {
    3119                 :            :                 .flags          = FL_BASE1,
    3120                 :            :                 .num_ports      = 2,
    3121                 :            :                 .base_baud      = 115200,
    3122                 :            :                 .uart_offset    = 8,
    3123                 :            :         },
    3124                 :            :         [pbn_b1_4_115200] = {
    3125                 :            :                 .flags          = FL_BASE1,
    3126                 :            :                 .num_ports      = 4,
    3127                 :            :                 .base_baud      = 115200,
    3128                 :            :                 .uart_offset    = 8,
    3129                 :            :         },
    3130                 :            :         [pbn_b1_8_115200] = {
    3131                 :            :                 .flags          = FL_BASE1,
    3132                 :            :                 .num_ports      = 8,
    3133                 :            :                 .base_baud      = 115200,
    3134                 :            :                 .uart_offset    = 8,
    3135                 :            :         },
    3136                 :            :         [pbn_b1_16_115200] = {
    3137                 :            :                 .flags          = FL_BASE1,
    3138                 :            :                 .num_ports      = 16,
    3139                 :            :                 .base_baud      = 115200,
    3140                 :            :                 .uart_offset    = 8,
    3141                 :            :         },
    3142                 :            : 
    3143                 :            :         [pbn_b1_1_921600] = {
    3144                 :            :                 .flags          = FL_BASE1,
    3145                 :            :                 .num_ports      = 1,
    3146                 :            :                 .base_baud      = 921600,
    3147                 :            :                 .uart_offset    = 8,
    3148                 :            :         },
    3149                 :            :         [pbn_b1_2_921600] = {
    3150                 :            :                 .flags          = FL_BASE1,
    3151                 :            :                 .num_ports      = 2,
    3152                 :            :                 .base_baud      = 921600,
    3153                 :            :                 .uart_offset    = 8,
    3154                 :            :         },
    3155                 :            :         [pbn_b1_4_921600] = {
    3156                 :            :                 .flags          = FL_BASE1,
    3157                 :            :                 .num_ports      = 4,
    3158                 :            :                 .base_baud      = 921600,
    3159                 :            :                 .uart_offset    = 8,
    3160                 :            :         },
    3161                 :            :         [pbn_b1_8_921600] = {
    3162                 :            :                 .flags          = FL_BASE1,
    3163                 :            :                 .num_ports      = 8,
    3164                 :            :                 .base_baud      = 921600,
    3165                 :            :                 .uart_offset    = 8,
    3166                 :            :         },
    3167                 :            :         [pbn_b1_2_1250000] = {
    3168                 :            :                 .flags          = FL_BASE1,
    3169                 :            :                 .num_ports      = 2,
    3170                 :            :                 .base_baud      = 1250000,
    3171                 :            :                 .uart_offset    = 8,
    3172                 :            :         },
    3173                 :            : 
    3174                 :            :         [pbn_b1_bt_1_115200] = {
    3175                 :            :                 .flags          = FL_BASE1|FL_BASE_BARS,
    3176                 :            :                 .num_ports      = 1,
    3177                 :            :                 .base_baud      = 115200,
    3178                 :            :                 .uart_offset    = 8,
    3179                 :            :         },
    3180                 :            :         [pbn_b1_bt_2_115200] = {
    3181                 :            :                 .flags          = FL_BASE1|FL_BASE_BARS,
    3182                 :            :                 .num_ports      = 2,
    3183                 :            :                 .base_baud      = 115200,
    3184                 :            :                 .uart_offset    = 8,
    3185                 :            :         },
    3186                 :            :         [pbn_b1_bt_4_115200] = {
    3187                 :            :                 .flags          = FL_BASE1|FL_BASE_BARS,
    3188                 :            :                 .num_ports      = 4,
    3189                 :            :                 .base_baud      = 115200,
    3190                 :            :                 .uart_offset    = 8,
    3191                 :            :         },
    3192                 :            : 
    3193                 :            :         [pbn_b1_bt_2_921600] = {
    3194                 :            :                 .flags          = FL_BASE1|FL_BASE_BARS,
    3195                 :            :                 .num_ports      = 2,
    3196                 :            :                 .base_baud      = 921600,
    3197                 :            :                 .uart_offset    = 8,
    3198                 :            :         },
    3199                 :            : 
    3200                 :            :         [pbn_b1_1_1382400] = {
    3201                 :            :                 .flags          = FL_BASE1,
    3202                 :            :                 .num_ports      = 1,
    3203                 :            :                 .base_baud      = 1382400,
    3204                 :            :                 .uart_offset    = 8,
    3205                 :            :         },
    3206                 :            :         [pbn_b1_2_1382400] = {
    3207                 :            :                 .flags          = FL_BASE1,
    3208                 :            :                 .num_ports      = 2,
    3209                 :            :                 .base_baud      = 1382400,
    3210                 :            :                 .uart_offset    = 8,
    3211                 :            :         },
    3212                 :            :         [pbn_b1_4_1382400] = {
    3213                 :            :                 .flags          = FL_BASE1,
    3214                 :            :                 .num_ports      = 4,
    3215                 :            :                 .base_baud      = 1382400,
    3216                 :            :                 .uart_offset    = 8,
    3217                 :            :         },
    3218                 :            :         [pbn_b1_8_1382400] = {
    3219                 :            :                 .flags          = FL_BASE1,
    3220                 :            :                 .num_ports      = 8,
    3221                 :            :                 .base_baud      = 1382400,
    3222                 :            :                 .uart_offset    = 8,
    3223                 :            :         },
    3224                 :            : 
    3225                 :            :         [pbn_b2_1_115200] = {
    3226                 :            :                 .flags          = FL_BASE2,
    3227                 :            :                 .num_ports      = 1,
    3228                 :            :                 .base_baud      = 115200,
    3229                 :            :                 .uart_offset    = 8,
    3230                 :            :         },
    3231                 :            :         [pbn_b2_2_115200] = {
    3232                 :            :                 .flags          = FL_BASE2,
    3233                 :            :                 .num_ports      = 2,
    3234                 :            :                 .base_baud      = 115200,
    3235                 :            :                 .uart_offset    = 8,
    3236                 :            :         },
    3237                 :            :         [pbn_b2_4_115200] = {
    3238                 :            :                 .flags          = FL_BASE2,
    3239                 :            :                 .num_ports      = 4,
    3240                 :            :                 .base_baud      = 115200,
    3241                 :            :                 .uart_offset    = 8,
    3242                 :            :         },
    3243                 :            :         [pbn_b2_8_115200] = {
    3244                 :            :                 .flags          = FL_BASE2,
    3245                 :            :                 .num_ports      = 8,
    3246                 :            :                 .base_baud      = 115200,
    3247                 :            :                 .uart_offset    = 8,
    3248                 :            :         },
    3249                 :            : 
    3250                 :            :         [pbn_b2_1_460800] = {
    3251                 :            :                 .flags          = FL_BASE2,
    3252                 :            :                 .num_ports      = 1,
    3253                 :            :                 .base_baud      = 460800,
    3254                 :            :                 .uart_offset    = 8,
    3255                 :            :         },
    3256                 :            :         [pbn_b2_4_460800] = {
    3257                 :            :                 .flags          = FL_BASE2,
    3258                 :            :                 .num_ports      = 4,
    3259                 :            :                 .base_baud      = 460800,
    3260                 :            :                 .uart_offset    = 8,
    3261                 :            :         },
    3262                 :            :         [pbn_b2_8_460800] = {
    3263                 :            :                 .flags          = FL_BASE2,
    3264                 :            :                 .num_ports      = 8,
    3265                 :            :                 .base_baud      = 460800,
    3266                 :            :                 .uart_offset    = 8,
    3267                 :            :         },
    3268                 :            :         [pbn_b2_16_460800] = {
    3269                 :            :                 .flags          = FL_BASE2,
    3270                 :            :                 .num_ports      = 16,
    3271                 :            :                 .base_baud      = 460800,
    3272                 :            :                 .uart_offset    = 8,
    3273                 :            :          },
    3274                 :            : 
    3275                 :            :         [pbn_b2_1_921600] = {
    3276                 :            :                 .flags          = FL_BASE2,
    3277                 :            :                 .num_ports      = 1,
    3278                 :            :                 .base_baud      = 921600,
    3279                 :            :                 .uart_offset    = 8,
    3280                 :            :         },
    3281                 :            :         [pbn_b2_4_921600] = {
    3282                 :            :                 .flags          = FL_BASE2,
    3283                 :            :                 .num_ports      = 4,
    3284                 :            :                 .base_baud      = 921600,
    3285                 :            :                 .uart_offset    = 8,
    3286                 :            :         },
    3287                 :            :         [pbn_b2_8_921600] = {
    3288                 :            :                 .flags          = FL_BASE2,
    3289                 :            :                 .num_ports      = 8,
    3290                 :            :                 .base_baud      = 921600,
    3291                 :            :                 .uart_offset    = 8,
    3292                 :            :         },
    3293                 :            : 
    3294                 :            :         [pbn_b2_8_1152000] = {
    3295                 :            :                 .flags          = FL_BASE2,
    3296                 :            :                 .num_ports      = 8,
    3297                 :            :                 .base_baud      = 1152000,
    3298                 :            :                 .uart_offset    = 8,
    3299                 :            :         },
    3300                 :            : 
    3301                 :            :         [pbn_b2_bt_1_115200] = {
    3302                 :            :                 .flags          = FL_BASE2|FL_BASE_BARS,
    3303                 :            :                 .num_ports      = 1,
    3304                 :            :                 .base_baud      = 115200,
    3305                 :            :                 .uart_offset    = 8,
    3306                 :            :         },
    3307                 :            :         [pbn_b2_bt_2_115200] = {
    3308                 :            :                 .flags          = FL_BASE2|FL_BASE_BARS,
    3309                 :            :                 .num_ports      = 2,
    3310                 :            :                 .base_baud      = 115200,
    3311                 :            :                 .uart_offset    = 8,
    3312                 :            :         },
    3313                 :            :         [pbn_b2_bt_4_115200] = {
    3314                 :            :                 .flags          = FL_BASE2|FL_BASE_BARS,
    3315                 :            :                 .num_ports      = 4,
    3316                 :            :                 .base_baud      = 115200,
    3317                 :            :                 .uart_offset    = 8,
    3318                 :            :         },
    3319                 :            : 
    3320                 :            :         [pbn_b2_bt_2_921600] = {
    3321                 :            :                 .flags          = FL_BASE2|FL_BASE_BARS,
    3322                 :            :                 .num_ports      = 2,
    3323                 :            :                 .base_baud      = 921600,
    3324                 :            :                 .uart_offset    = 8,
    3325                 :            :         },
    3326                 :            :         [pbn_b2_bt_4_921600] = {
    3327                 :            :                 .flags          = FL_BASE2|FL_BASE_BARS,
    3328                 :            :                 .num_ports      = 4,
    3329                 :            :                 .base_baud      = 921600,
    3330                 :            :                 .uart_offset    = 8,
    3331                 :            :         },
    3332                 :            : 
    3333                 :            :         [pbn_b3_2_115200] = {
    3334                 :            :                 .flags          = FL_BASE3,
    3335                 :            :                 .num_ports      = 2,
    3336                 :            :                 .base_baud      = 115200,
    3337                 :            :                 .uart_offset    = 8,
    3338                 :            :         },
    3339                 :            :         [pbn_b3_4_115200] = {
    3340                 :            :                 .flags          = FL_BASE3,
    3341                 :            :                 .num_ports      = 4,
    3342                 :            :                 .base_baud      = 115200,
    3343                 :            :                 .uart_offset    = 8,
    3344                 :            :         },
    3345                 :            :         [pbn_b3_8_115200] = {
    3346                 :            :                 .flags          = FL_BASE3,
    3347                 :            :                 .num_ports      = 8,
    3348                 :            :                 .base_baud      = 115200,
    3349                 :            :                 .uart_offset    = 8,
    3350                 :            :         },
    3351                 :            : 
    3352                 :            :         [pbn_b4_bt_2_921600] = {
    3353                 :            :                 .flags          = FL_BASE4,
    3354                 :            :                 .num_ports      = 2,
    3355                 :            :                 .base_baud      = 921600,
    3356                 :            :                 .uart_offset    = 8,
    3357                 :            :         },
    3358                 :            :         [pbn_b4_bt_4_921600] = {
    3359                 :            :                 .flags          = FL_BASE4,
    3360                 :            :                 .num_ports      = 4,
    3361                 :            :                 .base_baud      = 921600,
    3362                 :            :                 .uart_offset    = 8,
    3363                 :            :         },
    3364                 :            :         [pbn_b4_bt_8_921600] = {
    3365                 :            :                 .flags          = FL_BASE4,
    3366                 :            :                 .num_ports      = 8,
    3367                 :            :                 .base_baud      = 921600,
    3368                 :            :                 .uart_offset    = 8,
    3369                 :            :         },
    3370                 :            : 
    3371                 :            :         /*
    3372                 :            :          * Entries following this are board-specific.
    3373                 :            :          */
    3374                 :            : 
    3375                 :            :         /*
    3376                 :            :          * Panacom - IOMEM
    3377                 :            :          */
    3378                 :            :         [pbn_panacom] = {
    3379                 :            :                 .flags          = FL_BASE2,
    3380                 :            :                 .num_ports      = 2,
    3381                 :            :                 .base_baud      = 921600,
    3382                 :            :                 .uart_offset    = 0x400,
    3383                 :            :                 .reg_shift      = 7,
    3384                 :            :         },
    3385                 :            :         [pbn_panacom2] = {
    3386                 :            :                 .flags          = FL_BASE2|FL_BASE_BARS,
    3387                 :            :                 .num_ports      = 2,
    3388                 :            :                 .base_baud      = 921600,
    3389                 :            :                 .uart_offset    = 0x400,
    3390                 :            :                 .reg_shift      = 7,
    3391                 :            :         },
    3392                 :            :         [pbn_panacom4] = {
    3393                 :            :                 .flags          = FL_BASE2|FL_BASE_BARS,
    3394                 :            :                 .num_ports      = 4,
    3395                 :            :                 .base_baud      = 921600,
    3396                 :            :                 .uart_offset    = 0x400,
    3397                 :            :                 .reg_shift      = 7,
    3398                 :            :         },
    3399                 :            : 
    3400                 :            :         /* I think this entry is broken - the first_offset looks wrong --rmk */
    3401                 :            :         [pbn_plx_romulus] = {
    3402                 :            :                 .flags          = FL_BASE2,
    3403                 :            :                 .num_ports      = 4,
    3404                 :            :                 .base_baud      = 921600,
    3405                 :            :                 .uart_offset    = 8 << 2,
    3406                 :            :                 .reg_shift      = 2,
    3407                 :            :                 .first_offset   = 0x03,
    3408                 :            :         },
    3409                 :            : 
    3410                 :            :         /*
    3411                 :            :          * EndRun Technologies
    3412                 :            :         * Uses the size of PCI Base region 0 to
    3413                 :            :         * signal now many ports are available
    3414                 :            :         * 2 port 952 Uart support
    3415                 :            :         */
    3416                 :            :         [pbn_endrun_2_4000000] = {
    3417                 :            :                 .flags          = FL_BASE0,
    3418                 :            :                 .num_ports      = 2,
    3419                 :            :                 .base_baud      = 4000000,
    3420                 :            :                 .uart_offset    = 0x200,
    3421                 :            :                 .first_offset   = 0x1000,
    3422                 :            :         },
    3423                 :            : 
    3424                 :            :         /*
    3425                 :            :          * This board uses the size of PCI Base region 0 to
    3426                 :            :          * signal now many ports are available
    3427                 :            :          */
    3428                 :            :         [pbn_oxsemi] = {
    3429                 :            :                 .flags          = FL_BASE0|FL_REGION_SZ_CAP,
    3430                 :            :                 .num_ports      = 32,
    3431                 :            :                 .base_baud      = 115200,
    3432                 :            :                 .uart_offset    = 8,
    3433                 :            :         },
    3434                 :            :         [pbn_oxsemi_1_4000000] = {
    3435                 :            :                 .flags          = FL_BASE0,
    3436                 :            :                 .num_ports      = 1,
    3437                 :            :                 .base_baud      = 4000000,
    3438                 :            :                 .uart_offset    = 0x200,
    3439                 :            :                 .first_offset   = 0x1000,
    3440                 :            :         },
    3441                 :            :         [pbn_oxsemi_2_4000000] = {
    3442                 :            :                 .flags          = FL_BASE0,
    3443                 :            :                 .num_ports      = 2,
    3444                 :            :                 .base_baud      = 4000000,
    3445                 :            :                 .uart_offset    = 0x200,
    3446                 :            :                 .first_offset   = 0x1000,
    3447                 :            :         },
    3448                 :            :         [pbn_oxsemi_4_4000000] = {
    3449                 :            :                 .flags          = FL_BASE0,
    3450                 :            :                 .num_ports      = 4,
    3451                 :            :                 .base_baud      = 4000000,
    3452                 :            :                 .uart_offset    = 0x200,
    3453                 :            :                 .first_offset   = 0x1000,
    3454                 :            :         },
    3455                 :            :         [pbn_oxsemi_8_4000000] = {
    3456                 :            :                 .flags          = FL_BASE0,
    3457                 :            :                 .num_ports      = 8,
    3458                 :            :                 .base_baud      = 4000000,
    3459                 :            :                 .uart_offset    = 0x200,
    3460                 :            :                 .first_offset   = 0x1000,
    3461                 :            :         },
    3462                 :            : 
    3463                 :            : 
    3464                 :            :         /*
    3465                 :            :          * EKF addition for i960 Boards form EKF with serial port.
    3466                 :            :          * Max 256 ports.
    3467                 :            :          */
    3468                 :            :         [pbn_intel_i960] = {
    3469                 :            :                 .flags          = FL_BASE0,
    3470                 :            :                 .num_ports      = 32,
    3471                 :            :                 .base_baud      = 921600,
    3472                 :            :                 .uart_offset    = 8 << 2,
    3473                 :            :                 .reg_shift      = 2,
    3474                 :            :                 .first_offset   = 0x10000,
    3475                 :            :         },
    3476                 :            :         [pbn_sgi_ioc3] = {
    3477                 :            :                 .flags          = FL_BASE0|FL_NOIRQ,
    3478                 :            :                 .num_ports      = 1,
    3479                 :            :                 .base_baud      = 458333,
    3480                 :            :                 .uart_offset    = 8,
    3481                 :            :                 .reg_shift      = 0,
    3482                 :            :                 .first_offset   = 0x20178,
    3483                 :            :         },
    3484                 :            : 
    3485                 :            :         /*
    3486                 :            :          * Computone - uses IOMEM.
    3487                 :            :          */
    3488                 :            :         [pbn_computone_4] = {
    3489                 :            :                 .flags          = FL_BASE0,
    3490                 :            :                 .num_ports      = 4,
    3491                 :            :                 .base_baud      = 921600,
    3492                 :            :                 .uart_offset    = 0x40,
    3493                 :            :                 .reg_shift      = 2,
    3494                 :            :                 .first_offset   = 0x200,
    3495                 :            :         },
    3496                 :            :         [pbn_computone_6] = {
    3497                 :            :                 .flags          = FL_BASE0,
    3498                 :            :                 .num_ports      = 6,
    3499                 :            :                 .base_baud      = 921600,
    3500                 :            :                 .uart_offset    = 0x40,
    3501                 :            :                 .reg_shift      = 2,
    3502                 :            :                 .first_offset   = 0x200,
    3503                 :            :         },
    3504                 :            :         [pbn_computone_8] = {
    3505                 :            :                 .flags          = FL_BASE0,
    3506                 :            :                 .num_ports      = 8,
    3507                 :            :                 .base_baud      = 921600,
    3508                 :            :                 .uart_offset    = 0x40,
    3509                 :            :                 .reg_shift      = 2,
    3510                 :            :                 .first_offset   = 0x200,
    3511                 :            :         },
    3512                 :            :         [pbn_sbsxrsio] = {
    3513                 :            :                 .flags          = FL_BASE0,
    3514                 :            :                 .num_ports      = 8,
    3515                 :            :                 .base_baud      = 460800,
    3516                 :            :                 .uart_offset    = 256,
    3517                 :            :                 .reg_shift      = 4,
    3518                 :            :         },
    3519                 :            :         /*
    3520                 :            :          * PA Semi PWRficient PA6T-1682M on-chip UART
    3521                 :            :          */
    3522                 :            :         [pbn_pasemi_1682M] = {
    3523                 :            :                 .flags          = FL_BASE0,
    3524                 :            :                 .num_ports      = 1,
    3525                 :            :                 .base_baud      = 8333333,
    3526                 :            :         },
    3527                 :            :         /*
    3528                 :            :          * National Instruments 843x
    3529                 :            :          */
    3530                 :            :         [pbn_ni8430_16] = {
    3531                 :            :                 .flags          = FL_BASE0,
    3532                 :            :                 .num_ports      = 16,
    3533                 :            :                 .base_baud      = 3686400,
    3534                 :            :                 .uart_offset    = 0x10,
    3535                 :            :                 .first_offset   = 0x800,
    3536                 :            :         },
    3537                 :            :         [pbn_ni8430_8] = {
    3538                 :            :                 .flags          = FL_BASE0,
    3539                 :            :                 .num_ports      = 8,
    3540                 :            :                 .base_baud      = 3686400,
    3541                 :            :                 .uart_offset    = 0x10,
    3542                 :            :                 .first_offset   = 0x800,
    3543                 :            :         },
    3544                 :            :         [pbn_ni8430_4] = {
    3545                 :            :                 .flags          = FL_BASE0,
    3546                 :            :                 .num_ports      = 4,
    3547                 :            :                 .base_baud      = 3686400,
    3548                 :            :                 .uart_offset    = 0x10,
    3549                 :            :                 .first_offset   = 0x800,
    3550                 :            :         },
    3551                 :            :         [pbn_ni8430_2] = {
    3552                 :            :                 .flags          = FL_BASE0,
    3553                 :            :                 .num_ports      = 2,
    3554                 :            :                 .base_baud      = 3686400,
    3555                 :            :                 .uart_offset    = 0x10,
    3556                 :            :                 .first_offset   = 0x800,
    3557                 :            :         },
    3558                 :            :         /*
    3559                 :            :          * ADDI-DATA GmbH PCI-Express communication cards <info@addi-data.com>
    3560                 :            :          */
    3561                 :            :         [pbn_ADDIDATA_PCIe_1_3906250] = {
    3562                 :            :                 .flags          = FL_BASE0,
    3563                 :            :                 .num_ports      = 1,
    3564                 :            :                 .base_baud      = 3906250,
    3565                 :            :                 .uart_offset    = 0x200,
    3566                 :            :                 .first_offset   = 0x1000,
    3567                 :            :         },
    3568                 :            :         [pbn_ADDIDATA_PCIe_2_3906250] = {
    3569                 :            :                 .flags          = FL_BASE0,
    3570                 :            :                 .num_ports      = 2,
    3571                 :            :                 .base_baud      = 3906250,
    3572                 :            :                 .uart_offset    = 0x200,
    3573                 :            :                 .first_offset   = 0x1000,
    3574                 :            :         },
    3575                 :            :         [pbn_ADDIDATA_PCIe_4_3906250] = {
    3576                 :            :                 .flags          = FL_BASE0,
    3577                 :            :                 .num_ports      = 4,
    3578                 :            :                 .base_baud      = 3906250,
    3579                 :            :                 .uart_offset    = 0x200,
    3580                 :            :                 .first_offset   = 0x1000,
    3581                 :            :         },
    3582                 :            :         [pbn_ADDIDATA_PCIe_8_3906250] = {
    3583                 :            :                 .flags          = FL_BASE0,
    3584                 :            :                 .num_ports      = 8,
    3585                 :            :                 .base_baud      = 3906250,
    3586                 :            :                 .uart_offset    = 0x200,
    3587                 :            :                 .first_offset   = 0x1000,
    3588                 :            :         },
    3589                 :            :         [pbn_ce4100_1_115200] = {
    3590                 :            :                 .flags          = FL_BASE_BARS,
    3591                 :            :                 .num_ports      = 2,
    3592                 :            :                 .base_baud      = 921600,
    3593                 :            :                 .reg_shift      = 2,
    3594                 :            :         },
    3595                 :            :         [pbn_omegapci] = {
    3596                 :            :                 .flags          = FL_BASE0,
    3597                 :            :                 .num_ports      = 8,
    3598                 :            :                 .base_baud      = 115200,
    3599                 :            :                 .uart_offset    = 0x200,
    3600                 :            :         },
    3601                 :            :         [pbn_NETMOS9900_2s_115200] = {
    3602                 :            :                 .flags          = FL_BASE0,
    3603                 :            :                 .num_ports      = 2,
    3604                 :            :                 .base_baud      = 115200,
    3605                 :            :         },
    3606                 :            :         [pbn_brcm_trumanage] = {
    3607                 :            :                 .flags          = FL_BASE0,
    3608                 :            :                 .num_ports      = 1,
    3609                 :            :                 .reg_shift      = 2,
    3610                 :            :                 .base_baud      = 115200,
    3611                 :            :         },
    3612                 :            :         [pbn_fintek_4] = {
    3613                 :            :                 .num_ports      = 4,
    3614                 :            :                 .uart_offset    = 8,
    3615                 :            :                 .base_baud      = 115200,
    3616                 :            :                 .first_offset   = 0x40,
    3617                 :            :         },
    3618                 :            :         [pbn_fintek_8] = {
    3619                 :            :                 .num_ports      = 8,
    3620                 :            :                 .uart_offset    = 8,
    3621                 :            :                 .base_baud      = 115200,
    3622                 :            :                 .first_offset   = 0x40,
    3623                 :            :         },
    3624                 :            :         [pbn_fintek_12] = {
    3625                 :            :                 .num_ports      = 12,
    3626                 :            :                 .uart_offset    = 8,
    3627                 :            :                 .base_baud      = 115200,
    3628                 :            :                 .first_offset   = 0x40,
    3629                 :            :         },
    3630                 :            :         [pbn_fintek_F81504A] = {
    3631                 :            :                 .num_ports      = 4,
    3632                 :            :                 .uart_offset    = 8,
    3633                 :            :                 .base_baud      = 115200,
    3634                 :            :         },
    3635                 :            :         [pbn_fintek_F81508A] = {
    3636                 :            :                 .num_ports      = 8,
    3637                 :            :                 .uart_offset    = 8,
    3638                 :            :                 .base_baud      = 115200,
    3639                 :            :         },
    3640                 :            :         [pbn_fintek_F81512A] = {
    3641                 :            :                 .num_ports      = 12,
    3642                 :            :                 .uart_offset    = 8,
    3643                 :            :                 .base_baud      = 115200,
    3644                 :            :         },
    3645                 :            :         [pbn_wch382_2] = {
    3646                 :            :                 .flags          = FL_BASE0,
    3647                 :            :                 .num_ports      = 2,
    3648                 :            :                 .base_baud      = 115200,
    3649                 :            :                 .uart_offset    = 8,
    3650                 :            :                 .first_offset   = 0xC0,
    3651                 :            :         },
    3652                 :            :         [pbn_wch384_4] = {
    3653                 :            :                 .flags          = FL_BASE0,
    3654                 :            :                 .num_ports      = 4,
    3655                 :            :                 .base_baud      = 115200,
    3656                 :            :                 .uart_offset    = 8,
    3657                 :            :                 .first_offset   = 0xC0,
    3658                 :            :         },
    3659                 :            :         /*
    3660                 :            :          * Pericom PI7C9X795[1248] Uno/Dual/Quad/Octal UART
    3661                 :            :          */
    3662                 :            :         [pbn_pericom_PI7C9X7951] = {
    3663                 :            :                 .flags          = FL_BASE0,
    3664                 :            :                 .num_ports      = 1,
    3665                 :            :                 .base_baud      = 921600,
    3666                 :            :                 .uart_offset    = 0x8,
    3667                 :            :         },
    3668                 :            :         [pbn_pericom_PI7C9X7952] = {
    3669                 :            :                 .flags          = FL_BASE0,
    3670                 :            :                 .num_ports      = 2,
    3671                 :            :                 .base_baud      = 921600,
    3672                 :            :                 .uart_offset    = 0x8,
    3673                 :            :         },
    3674                 :            :         [pbn_pericom_PI7C9X7954] = {
    3675                 :            :                 .flags          = FL_BASE0,
    3676                 :            :                 .num_ports      = 4,
    3677                 :            :                 .base_baud      = 921600,
    3678                 :            :                 .uart_offset    = 0x8,
    3679                 :            :         },
    3680                 :            :         [pbn_pericom_PI7C9X7958] = {
    3681                 :            :                 .flags          = FL_BASE0,
    3682                 :            :                 .num_ports      = 8,
    3683                 :            :                 .base_baud      = 921600,
    3684                 :            :                 .uart_offset    = 0x8,
    3685                 :            :         },
    3686                 :            :         [pbn_sunix_pci_1s] = {
    3687                 :            :                 .num_ports      = 1,
    3688                 :            :                 .base_baud      = 921600,
    3689                 :            :                 .uart_offset    = 0x8,
    3690                 :            :         },
    3691                 :            :         [pbn_sunix_pci_2s] = {
    3692                 :            :                 .num_ports      = 2,
    3693                 :            :                 .base_baud      = 921600,
    3694                 :            :                 .uart_offset    = 0x8,
    3695                 :            :         },
    3696                 :            :         [pbn_sunix_pci_4s] = {
    3697                 :            :                 .num_ports      = 4,
    3698                 :            :                 .base_baud      = 921600,
    3699                 :            :                 .uart_offset    = 0x8,
    3700                 :            :         },
    3701                 :            :         [pbn_sunix_pci_8s] = {
    3702                 :            :                 .num_ports      = 8,
    3703                 :            :                 .base_baud      = 921600,
    3704                 :            :                 .uart_offset    = 0x8,
    3705                 :            :         },
    3706                 :            :         [pbn_sunix_pci_16s] = {
    3707                 :            :                 .num_ports      = 16,
    3708                 :            :                 .base_baud      = 921600,
    3709                 :            :                 .uart_offset    = 0x8,
    3710                 :            :         },
    3711                 :            :         [pbn_moxa8250_2p] = {
    3712                 :            :                 .flags          = FL_BASE1,
    3713                 :            :                 .num_ports      = 2,
    3714                 :            :                 .base_baud      = 921600,
    3715                 :            :                 .uart_offset    = 0x200,
    3716                 :            :         },
    3717                 :            :         [pbn_moxa8250_4p] = {
    3718                 :            :                 .flags          = FL_BASE1,
    3719                 :            :                 .num_ports      = 4,
    3720                 :            :                 .base_baud      = 921600,
    3721                 :            :                 .uart_offset    = 0x200,
    3722                 :            :         },
    3723                 :            :         [pbn_moxa8250_8p] = {
    3724                 :            :                 .flags          = FL_BASE1,
    3725                 :            :                 .num_ports      = 8,
    3726                 :            :                 .base_baud      = 921600,
    3727                 :            :                 .uart_offset    = 0x200,
    3728                 :            :         },
    3729                 :            : };
    3730                 :            : 
    3731                 :            : static const struct pci_device_id blacklist[] = {
    3732                 :            :         /* softmodems */
    3733                 :            :         { PCI_VDEVICE(AL, 0x5457), }, /* ALi Corporation M5457 AC'97 Modem */
    3734                 :            :         { PCI_VDEVICE(MOTOROLA, 0x3052), }, /* Motorola Si3052-based modem */
    3735                 :            :         { PCI_DEVICE(0x1543, 0x3052), }, /* Si3052-based modem, default IDs */
    3736                 :            : 
    3737                 :            :         /* multi-io cards handled by parport_serial */
    3738                 :            :         { PCI_DEVICE(0x4348, 0x7053), }, /* WCH CH353 2S1P */
    3739                 :            :         { PCI_DEVICE(0x4348, 0x5053), }, /* WCH CH353 1S1P */
    3740                 :            :         { PCI_DEVICE(0x1c00, 0x3250), }, /* WCH CH382 2S1P */
    3741                 :            : 
    3742                 :            :         /* Intel platforms with MID UART */
    3743                 :            :         { PCI_VDEVICE(INTEL, 0x081b), },
    3744                 :            :         { PCI_VDEVICE(INTEL, 0x081c), },
    3745                 :            :         { PCI_VDEVICE(INTEL, 0x081d), },
    3746                 :            :         { PCI_VDEVICE(INTEL, 0x1191), },
    3747                 :            :         { PCI_VDEVICE(INTEL, 0x18d8), },
    3748                 :            :         { PCI_VDEVICE(INTEL, 0x19d8), },
    3749                 :            : 
    3750                 :            :         /* Intel platforms with DesignWare UART */
    3751                 :            :         { PCI_VDEVICE(INTEL, 0x0936), },
    3752                 :            :         { PCI_VDEVICE(INTEL, 0x0f0a), },
    3753                 :            :         { PCI_VDEVICE(INTEL, 0x0f0c), },
    3754                 :            :         { PCI_VDEVICE(INTEL, 0x228a), },
    3755                 :            :         { PCI_VDEVICE(INTEL, 0x228c), },
    3756                 :            :         { PCI_VDEVICE(INTEL, 0x9ce3), },
    3757                 :            :         { PCI_VDEVICE(INTEL, 0x9ce4), },
    3758                 :            : 
    3759                 :            :         /* Exar devices */
    3760                 :            :         { PCI_VDEVICE(EXAR, PCI_ANY_ID), },
    3761                 :            :         { PCI_VDEVICE(COMMTECH, PCI_ANY_ID), },
    3762                 :            : 
    3763                 :            :         /* End of the black list */
    3764                 :            :         { }
    3765                 :            : };
    3766                 :            : 
    3767                 :            : static int serial_pci_is_class_communication(struct pci_dev *dev)
    3768                 :            : {
    3769                 :            :         /*
    3770                 :            :          * If it is not a communications device or the programming
    3771                 :            :          * interface is greater than 6, give up.
    3772                 :            :          */
    3773                 :            :         if ((((dev->class >> 8) != PCI_CLASS_COMMUNICATION_SERIAL) &&
    3774                 :            :              ((dev->class >> 8) != PCI_CLASS_COMMUNICATION_MULTISERIAL) &&
    3775                 :            :              ((dev->class >> 8) != PCI_CLASS_COMMUNICATION_MODEM)) ||
    3776                 :            :             (dev->class & 0xff) > 6)
    3777                 :            :                 return -ENODEV;
    3778                 :            : 
    3779                 :            :         return 0;
    3780                 :            : }
    3781                 :            : 
    3782                 :            : /*
    3783                 :            :  * Given a complete unknown PCI device, try to use some heuristics to
    3784                 :            :  * guess what the configuration might be, based on the pitiful PCI
    3785                 :            :  * serial specs.  Returns 0 on success, -ENODEV on failure.
    3786                 :            :  */
    3787                 :            : static int
    3788                 :            : serial_pci_guess_board(struct pci_dev *dev, struct pciserial_board *board)
    3789                 :            : {
    3790                 :            :         int num_iomem, num_port, first_port = -1, i;
    3791                 :            :         int rc;
    3792                 :            : 
    3793                 :            :         rc = serial_pci_is_class_communication(dev);
    3794                 :            :         if (rc)
    3795                 :            :                 return rc;
    3796                 :            : 
    3797                 :            :         /*
    3798                 :            :          * Should we try to make guesses for multiport serial devices later?
    3799                 :            :          */
    3800                 :            :         if ((dev->class >> 8) == PCI_CLASS_COMMUNICATION_MULTISERIAL)
    3801                 :            :                 return -ENODEV;
    3802                 :            : 
    3803                 :            :         num_iomem = num_port = 0;
    3804                 :            :         for (i = 0; i < PCI_STD_NUM_BARS; i++) {
    3805                 :            :                 if (pci_resource_flags(dev, i) & IORESOURCE_IO) {
    3806                 :            :                         num_port++;
    3807                 :            :                         if (first_port == -1)
    3808                 :            :                                 first_port = i;
    3809                 :            :                 }
    3810                 :            :                 if (pci_resource_flags(dev, i) & IORESOURCE_MEM)
    3811                 :            :                         num_iomem++;
    3812                 :            :         }
    3813                 :            : 
    3814                 :            :         /*
    3815                 :            :          * If there is 1 or 0 iomem regions, and exactly one port,
    3816                 :            :          * use it.  We guess the number of ports based on the IO
    3817                 :            :          * region size.
    3818                 :            :          */
    3819                 :            :         if (num_iomem <= 1 && num_port == 1) {
    3820                 :            :                 board->flags = first_port;
    3821                 :            :                 board->num_ports = pci_resource_len(dev, first_port) / 8;
    3822                 :            :                 return 0;
    3823                 :            :         }
    3824                 :            : 
    3825                 :            :         /*
    3826                 :            :          * Now guess if we've got a board which indexes by BARs.
    3827                 :            :          * Each IO BAR should be 8 bytes, and they should follow
    3828                 :            :          * consecutively.
    3829                 :            :          */
    3830                 :            :         first_port = -1;
    3831                 :            :         num_port = 0;
    3832                 :            :         for (i = 0; i < PCI_STD_NUM_BARS; i++) {
    3833                 :            :                 if (pci_resource_flags(dev, i) & IORESOURCE_IO &&
    3834                 :            :                     pci_resource_len(dev, i) == 8 &&
    3835                 :            :                     (first_port == -1 || (first_port + num_port) == i)) {
    3836                 :            :                         num_port++;
    3837                 :            :                         if (first_port == -1)
    3838                 :            :                                 first_port = i;
    3839                 :            :                 }
    3840                 :            :         }
    3841                 :            : 
    3842                 :            :         if (num_port > 1) {
    3843                 :            :                 board->flags = first_port | FL_BASE_BARS;
    3844                 :            :                 board->num_ports = num_port;
    3845                 :            :                 return 0;
    3846                 :            :         }
    3847                 :            : 
    3848                 :            :         return -ENODEV;
    3849                 :            : }
    3850                 :            : 
    3851                 :            : static inline int
    3852                 :          0 : serial_pci_matches(const struct pciserial_board *board,
    3853                 :            :                    const struct pciserial_board *guessed)
    3854                 :            : {
    3855                 :          0 :         return
    3856                 :          0 :             board->num_ports == guessed->num_ports &&
    3857         [ #  # ]:          0 :             board->base_baud == guessed->base_baud &&
    3858         [ #  # ]:          0 :             board->uart_offset == guessed->uart_offset &&
    3859   [ #  #  #  # ]:          0 :             board->reg_shift == guessed->reg_shift &&
    3860         [ #  # ]:          0 :             board->first_offset == guessed->first_offset;
    3861                 :            : }
    3862                 :            : 
    3863                 :            : struct serial_private *
    3864                 :          0 : pciserial_init_ports(struct pci_dev *dev, const struct pciserial_board *board)
    3865                 :            : {
    3866                 :          0 :         struct uart_8250_port uart;
    3867                 :          0 :         struct serial_private *priv;
    3868                 :          0 :         struct pci_serial_quirk *quirk;
    3869                 :          0 :         int rc, nr_ports, i;
    3870                 :            : 
    3871                 :          0 :         nr_ports = board->num_ports;
    3872                 :            : 
    3873                 :            :         /*
    3874                 :            :          * Find an init and setup quirks.
    3875                 :            :          */
    3876                 :          0 :         quirk = find_quirk(dev);
    3877                 :            : 
    3878                 :            :         /*
    3879                 :            :          * Run the new-style initialization function.
    3880                 :            :          * The initialization function returns:
    3881                 :            :          *  <0  - error
    3882                 :            :          *   0  - use board->num_ports
    3883                 :            :          *  >0  - number of ports
    3884                 :            :          */
    3885         [ #  # ]:          0 :         if (quirk->init) {
    3886                 :          0 :                 rc = quirk->init(dev);
    3887         [ #  # ]:          0 :                 if (rc < 0) {
    3888                 :          0 :                         priv = ERR_PTR(rc);
    3889                 :          0 :                         goto err_out;
    3890                 :            :                 }
    3891         [ #  # ]:          0 :                 if (rc)
    3892                 :          0 :                         nr_ports = rc;
    3893                 :            :         }
    3894                 :            : 
    3895                 :          0 :         priv = kzalloc(sizeof(struct serial_private) +
    3896                 :            :                        sizeof(unsigned int) * nr_ports,
    3897                 :            :                        GFP_KERNEL);
    3898         [ #  # ]:          0 :         if (!priv) {
    3899                 :          0 :                 priv = ERR_PTR(-ENOMEM);
    3900                 :          0 :                 goto err_deinit;
    3901                 :            :         }
    3902                 :            : 
    3903                 :          0 :         priv->dev = dev;
    3904                 :          0 :         priv->quirk = quirk;
    3905                 :            : 
    3906                 :          0 :         memset(&uart, 0, sizeof(uart));
    3907                 :          0 :         uart.port.flags = UPF_SKIP_TEST | UPF_BOOT_AUTOCONF | UPF_SHARE_IRQ;
    3908                 :          0 :         uart.port.uartclk = board->base_baud * 16;
    3909                 :            : 
    3910         [ #  # ]:          0 :         if (pci_match_id(pci_use_msi, dev)) {
    3911                 :          0 :                 dev_dbg(&dev->dev, "Using MSI(-X) interrupts\n");
    3912                 :          0 :                 pci_set_master(dev);
    3913                 :          0 :                 rc = pci_alloc_irq_vectors(dev, 1, 1, PCI_IRQ_ALL_TYPES);
    3914                 :            :         } else {
    3915                 :          0 :                 dev_dbg(&dev->dev, "Using legacy interrupts\n");
    3916                 :          0 :                 rc = pci_alloc_irq_vectors(dev, 1, 1, PCI_IRQ_LEGACY);
    3917                 :            :         }
    3918         [ #  # ]:          0 :         if (rc < 0) {
    3919                 :          0 :                 kfree(priv);
    3920                 :          0 :                 priv = ERR_PTR(rc);
    3921                 :          0 :                 goto err_deinit;
    3922                 :            :         }
    3923                 :            : 
    3924                 :          0 :         uart.port.irq = pci_irq_vector(dev, 0);
    3925                 :          0 :         uart.port.dev = &dev->dev;
    3926                 :            : 
    3927         [ #  # ]:          0 :         for (i = 0; i < nr_ports; i++) {
    3928         [ #  # ]:          0 :                 if (quirk->setup(priv, board, &uart, i))
    3929                 :            :                         break;
    3930                 :            : 
    3931                 :          0 :                 dev_dbg(&dev->dev, "Setup PCI port: port %lx, irq %d, type %d\n",
    3932                 :            :                         uart.port.iobase, uart.port.irq, uart.port.iotype);
    3933                 :            : 
    3934                 :          0 :                 priv->line[i] = serial8250_register_8250_port(&uart);
    3935         [ #  # ]:          0 :                 if (priv->line[i] < 0) {
    3936                 :          0 :                         dev_err(&dev->dev,
    3937                 :            :                                 "Couldn't register serial port %lx, irq %d, type %d, error %d\n",
    3938                 :            :                                 uart.port.iobase, uart.port.irq,
    3939                 :            :                                 uart.port.iotype, priv->line[i]);
    3940                 :          0 :                         break;
    3941                 :            :                 }
    3942                 :            :         }
    3943                 :          0 :         priv->nr = i;
    3944                 :          0 :         priv->board = board;
    3945                 :          0 :         return priv;
    3946                 :            : 
    3947                 :          0 : err_deinit:
    3948         [ #  # ]:          0 :         if (quirk->exit)
    3949                 :          0 :                 quirk->exit(dev);
    3950                 :          0 : err_out:
    3951                 :            :         return priv;
    3952                 :            : }
    3953                 :            : EXPORT_SYMBOL_GPL(pciserial_init_ports);
    3954                 :            : 
    3955                 :          0 : static void pciserial_detach_ports(struct serial_private *priv)
    3956                 :            : {
    3957                 :          0 :         struct pci_serial_quirk *quirk;
    3958                 :          0 :         int i;
    3959                 :            : 
    3960         [ #  # ]:          0 :         for (i = 0; i < priv->nr; i++)
    3961                 :          0 :                 serial8250_unregister_port(priv->line[i]);
    3962                 :            : 
    3963                 :            :         /*
    3964                 :            :          * Find the exit quirks.
    3965                 :            :          */
    3966                 :          0 :         quirk = find_quirk(priv->dev);
    3967         [ #  # ]:          0 :         if (quirk->exit)
    3968                 :          0 :                 quirk->exit(priv->dev);
    3969                 :          0 : }
    3970                 :            : 
    3971                 :          0 : void pciserial_remove_ports(struct serial_private *priv)
    3972                 :            : {
    3973                 :          0 :         pciserial_detach_ports(priv);
    3974                 :          0 :         kfree(priv);
    3975                 :          0 : }
    3976                 :            : EXPORT_SYMBOL_GPL(pciserial_remove_ports);
    3977                 :            : 
    3978                 :          0 : void pciserial_suspend_ports(struct serial_private *priv)
    3979                 :            : {
    3980                 :          0 :         int i;
    3981                 :            : 
    3982         [ #  # ]:          0 :         for (i = 0; i < priv->nr; i++)
    3983         [ #  # ]:          0 :                 if (priv->line[i] >= 0)
    3984                 :          0 :                         serial8250_suspend_port(priv->line[i]);
    3985                 :            : 
    3986                 :            :         /*
    3987                 :            :          * Ensure that every init quirk is properly torn down
    3988                 :            :          */
    3989         [ #  # ]:          0 :         if (priv->quirk->exit)
    3990                 :          0 :                 priv->quirk->exit(priv->dev);
    3991                 :          0 : }
    3992                 :            : EXPORT_SYMBOL_GPL(pciserial_suspend_ports);
    3993                 :            : 
    3994                 :          0 : void pciserial_resume_ports(struct serial_private *priv)
    3995                 :            : {
    3996                 :          0 :         int i;
    3997                 :            : 
    3998                 :            :         /*
    3999                 :            :          * Ensure that the board is correctly configured.
    4000                 :            :          */
    4001         [ #  # ]:          0 :         if (priv->quirk->init)
    4002                 :          0 :                 priv->quirk->init(priv->dev);
    4003                 :            : 
    4004         [ #  # ]:          0 :         for (i = 0; i < priv->nr; i++)
    4005         [ #  # ]:          0 :                 if (priv->line[i] >= 0)
    4006                 :          0 :                         serial8250_resume_port(priv->line[i]);
    4007                 :          0 : }
    4008                 :            : EXPORT_SYMBOL_GPL(pciserial_resume_ports);
    4009                 :            : 
    4010                 :            : /*
    4011                 :            :  * Probe one serial board.  Unfortunately, there is no rhyme nor reason
    4012                 :            :  * to the arrangement of serial ports on a PCI card.
    4013                 :            :  */
    4014                 :            : static int
    4015                 :         21 : pciserial_init_one(struct pci_dev *dev, const struct pci_device_id *ent)
    4016                 :            : {
    4017                 :         21 :         struct pci_serial_quirk *quirk;
    4018                 :         21 :         struct serial_private *priv;
    4019                 :         21 :         const struct pciserial_board *board;
    4020                 :         21 :         const struct pci_device_id *exclude;
    4021                 :         21 :         struct pciserial_board tmp;
    4022                 :         21 :         int rc;
    4023                 :            : 
    4024                 :         21 :         quirk = find_quirk(dev);
    4025         [ -  + ]:         21 :         if (quirk->probe) {
    4026                 :          0 :                 rc = quirk->probe(dev);
    4027         [ #  # ]:          0 :                 if (rc)
    4028                 :            :                         return rc;
    4029                 :            :         }
    4030                 :            : 
    4031         [ -  + ]:         21 :         if (ent->driver_data >= ARRAY_SIZE(pci_boards)) {
    4032                 :          0 :                 dev_err(&dev->dev, "invalid driver_data: %ld\n",
    4033                 :            :                         ent->driver_data);
    4034                 :          0 :                 return -EINVAL;
    4035                 :            :         }
    4036                 :            : 
    4037                 :         21 :         board = &pci_boards[ent->driver_data];
    4038                 :            : 
    4039                 :         21 :         exclude = pci_match_id(blacklist, dev);
    4040         [ +  - ]:         21 :         if (exclude)
    4041                 :            :                 return -ENODEV;
    4042                 :            : 
    4043                 :         21 :         rc = pcim_enable_device(dev);
    4044                 :         21 :         pci_save_state(dev);
    4045         [ +  - ]:         21 :         if (rc)
    4046                 :            :                 return rc;
    4047                 :            : 
    4048         [ +  - ]:         21 :         if (ent->driver_data == pbn_default) {
    4049                 :            :                 /*
    4050                 :            :                  * Use a copy of the pci_board entry for this;
    4051                 :            :                  * avoid changing entries in the table.
    4052                 :            :                  */
    4053                 :         21 :                 memcpy(&tmp, board, sizeof(struct pciserial_board));
    4054                 :         21 :                 board = &tmp;
    4055                 :            : 
    4056                 :            :                 /*
    4057                 :            :                  * We matched one of our class entries.  Try to
    4058                 :            :                  * determine the parameters of this board.
    4059                 :            :                  */
    4060                 :         21 :                 rc = serial_pci_guess_board(dev, &tmp);
    4061         [ -  + ]:         21 :                 if (rc)
    4062                 :            :                         return rc;
    4063                 :            :         } else {
    4064                 :            :                 /*
    4065                 :            :                  * We matched an explicit entry.  If we are able to
    4066                 :            :                  * detect this boards settings with our heuristic,
    4067                 :            :                  * then we no longer need this entry.
    4068                 :            :                  */
    4069                 :          0 :                 memcpy(&tmp, &pci_boards[pbn_default],
    4070                 :            :                        sizeof(struct pciserial_board));
    4071                 :          0 :                 rc = serial_pci_guess_board(dev, &tmp);
    4072         [ #  # ]:          0 :                 if (rc == 0 && serial_pci_matches(board, &tmp))
    4073                 :          0 :                         moan_device("Redundant entry in serial pci_table.",
    4074                 :            :                                     dev);
    4075                 :            :         }
    4076                 :            : 
    4077                 :          0 :         priv = pciserial_init_ports(dev, board);
    4078         [ #  # ]:          0 :         if (IS_ERR(priv))
    4079                 :          0 :                 return PTR_ERR(priv);
    4080                 :            : 
    4081                 :          0 :         pci_set_drvdata(dev, priv);
    4082                 :          0 :         return 0;
    4083                 :            : }
    4084                 :            : 
    4085                 :          0 : static void pciserial_remove_one(struct pci_dev *dev)
    4086                 :            : {
    4087                 :          0 :         struct serial_private *priv = pci_get_drvdata(dev);
    4088                 :            : 
    4089                 :          0 :         pciserial_remove_ports(priv);
    4090                 :          0 : }
    4091                 :            : 
    4092                 :            : #ifdef CONFIG_PM_SLEEP
    4093                 :          0 : static int pciserial_suspend_one(struct device *dev)
    4094                 :            : {
    4095         [ #  # ]:          0 :         struct serial_private *priv = dev_get_drvdata(dev);
    4096                 :            : 
    4097         [ #  # ]:          0 :         if (priv)
    4098                 :          0 :                 pciserial_suspend_ports(priv);
    4099                 :            : 
    4100                 :          0 :         return 0;
    4101                 :            : }
    4102                 :            : 
    4103                 :          0 : static int pciserial_resume_one(struct device *dev)
    4104                 :            : {
    4105                 :          0 :         struct pci_dev *pdev = to_pci_dev(dev);
    4106         [ #  # ]:          0 :         struct serial_private *priv = pci_get_drvdata(pdev);
    4107                 :          0 :         int err;
    4108                 :            : 
    4109         [ #  # ]:          0 :         if (priv) {
    4110                 :            :                 /*
    4111                 :            :                  * The device may have been disabled.  Re-enable it.
    4112                 :            :                  */
    4113                 :          0 :                 err = pci_enable_device(pdev);
    4114                 :            :                 /* FIXME: We cannot simply error out here */
    4115         [ #  # ]:          0 :                 if (err)
    4116                 :          0 :                         dev_err(dev, "Unable to re-enable ports, trying to continue.\n");
    4117                 :          0 :                 pciserial_resume_ports(priv);
    4118                 :            :         }
    4119                 :          0 :         return 0;
    4120                 :            : }
    4121                 :            : #endif
    4122                 :            : 
    4123                 :            : static SIMPLE_DEV_PM_OPS(pciserial_pm_ops, pciserial_suspend_one,
    4124                 :            :                          pciserial_resume_one);
    4125                 :            : 
    4126                 :            : static const struct pci_device_id serial_pci_tbl[] = {
    4127                 :            :         /* Advantech use PCI_DEVICE_ID_ADVANTECH_PCI3620 (0x3620) as 'PCI_SUBVENDOR_ID' */
    4128                 :            :         {       PCI_VENDOR_ID_ADVANTECH, PCI_DEVICE_ID_ADVANTECH_PCI3620,
    4129                 :            :                 PCI_DEVICE_ID_ADVANTECH_PCI3620, 0x0001, 0, 0,
    4130                 :            :                 pbn_b2_8_921600 },
    4131                 :            :         /* Advantech also use 0x3618 and 0xf618 */
    4132                 :            :         {       PCI_VENDOR_ID_ADVANTECH, PCI_DEVICE_ID_ADVANTECH_PCI3618,
    4133                 :            :                 PCI_DEVICE_ID_ADVANTECH_PCI3618, PCI_ANY_ID, 0, 0,
    4134                 :            :                 pbn_b0_4_921600 },
    4135                 :            :         {       PCI_VENDOR_ID_ADVANTECH, PCI_DEVICE_ID_ADVANTECH_PCIf618,
    4136                 :            :                 PCI_DEVICE_ID_ADVANTECH_PCI3618, PCI_ANY_ID, 0, 0,
    4137                 :            :                 pbn_b0_4_921600 },
    4138                 :            :         {       PCI_VENDOR_ID_V3, PCI_DEVICE_ID_V3_V960,
    4139                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4140                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_BH8_232, 0, 0,
    4141                 :            :                 pbn_b1_8_1382400 },
    4142                 :            :         {       PCI_VENDOR_ID_V3, PCI_DEVICE_ID_V3_V960,
    4143                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4144                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_BH4_232, 0, 0,
    4145                 :            :                 pbn_b1_4_1382400 },
    4146                 :            :         {       PCI_VENDOR_ID_V3, PCI_DEVICE_ID_V3_V960,
    4147                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4148                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_BH2_232, 0, 0,
    4149                 :            :                 pbn_b1_2_1382400 },
    4150                 :            :         {       PCI_VENDOR_ID_V3, PCI_DEVICE_ID_V3_V351,
    4151                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4152                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_BH8_232, 0, 0,
    4153                 :            :                 pbn_b1_8_1382400 },
    4154                 :            :         {       PCI_VENDOR_ID_V3, PCI_DEVICE_ID_V3_V351,
    4155                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4156                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_BH4_232, 0, 0,
    4157                 :            :                 pbn_b1_4_1382400 },
    4158                 :            :         {       PCI_VENDOR_ID_V3, PCI_DEVICE_ID_V3_V351,
    4159                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4160                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_BH2_232, 0, 0,
    4161                 :            :                 pbn_b1_2_1382400 },
    4162                 :            :         {       PCI_VENDOR_ID_V3, PCI_DEVICE_ID_V3_V351,
    4163                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4164                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_BH8_485, 0, 0,
    4165                 :            :                 pbn_b1_8_921600 },
    4166                 :            :         {       PCI_VENDOR_ID_V3, PCI_DEVICE_ID_V3_V351,
    4167                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4168                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_BH8_485_4_4, 0, 0,
    4169                 :            :                 pbn_b1_8_921600 },
    4170                 :            :         {       PCI_VENDOR_ID_V3, PCI_DEVICE_ID_V3_V351,
    4171                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4172                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_BH4_485, 0, 0,
    4173                 :            :                 pbn_b1_4_921600 },
    4174                 :            :         {       PCI_VENDOR_ID_V3, PCI_DEVICE_ID_V3_V351,
    4175                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4176                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_BH4_485_2_2, 0, 0,
    4177                 :            :                 pbn_b1_4_921600 },
    4178                 :            :         {       PCI_VENDOR_ID_V3, PCI_DEVICE_ID_V3_V351,
    4179                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4180                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_BH2_485, 0, 0,
    4181                 :            :                 pbn_b1_2_921600 },
    4182                 :            :         {       PCI_VENDOR_ID_V3, PCI_DEVICE_ID_V3_V351,
    4183                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4184                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_BH8_485_2_6, 0, 0,
    4185                 :            :                 pbn_b1_8_921600 },
    4186                 :            :         {       PCI_VENDOR_ID_V3, PCI_DEVICE_ID_V3_V351,
    4187                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4188                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_BH081101V1, 0, 0,
    4189                 :            :                 pbn_b1_8_921600 },
    4190                 :            :         {       PCI_VENDOR_ID_V3, PCI_DEVICE_ID_V3_V351,
    4191                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4192                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_BH041101V1, 0, 0,
    4193                 :            :                 pbn_b1_4_921600 },
    4194                 :            :         {       PCI_VENDOR_ID_V3, PCI_DEVICE_ID_V3_V351,
    4195                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4196                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_BH2_20MHZ, 0, 0,
    4197                 :            :                 pbn_b1_2_1250000 },
    4198                 :            :         {       PCI_VENDOR_ID_OXSEMI, PCI_DEVICE_ID_OXSEMI_16PCI954,
    4199                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4200                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_TITAN_2, 0, 0,
    4201                 :            :                 pbn_b0_2_1843200 },
    4202                 :            :         {       PCI_VENDOR_ID_OXSEMI, PCI_DEVICE_ID_OXSEMI_16PCI954,
    4203                 :            :                 PCI_SUBVENDOR_ID_CONNECT_TECH,
    4204                 :            :                 PCI_SUBDEVICE_ID_CONNECT_TECH_TITAN_4, 0, 0,
    4205                 :            :                 pbn_b0_4_1843200 },
    4206                 :            :         {       PCI_VENDOR_ID_OXSEMI, PCI_DEVICE_ID_OXSEMI_16PCI954,
    4207                 :            :                 PCI_VENDOR_ID_AFAVLAB,
    4208                 :            :                 PCI_SUBDEVICE_ID_AFAVLAB_P061, 0, 0,
    4209                 :            :                 pbn_b0_4_1152000 },
    4210                 :            :         {       PCI_VENDOR_ID_SEALEVEL, PCI_DEVICE_ID_SEALEVEL_U530,
    4211                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4212                 :            :                 pbn_b2_bt_1_115200 },
    4213                 :            :         {       PCI_VENDOR_ID_SEALEVEL, PCI_DEVICE_ID_SEALEVEL_UCOMM2,
    4214                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4215                 :            :                 pbn_b2_bt_2_115200 },
    4216                 :            :         {       PCI_VENDOR_ID_SEALEVEL, PCI_DEVICE_ID_SEALEVEL_UCOMM422,
    4217                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4218                 :            :                 pbn_b2_bt_4_115200 },
    4219                 :            :         {       PCI_VENDOR_ID_SEALEVEL, PCI_DEVICE_ID_SEALEVEL_UCOMM232,
    4220                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4221                 :            :                 pbn_b2_bt_2_115200 },
    4222                 :            :         {       PCI_VENDOR_ID_SEALEVEL, PCI_DEVICE_ID_SEALEVEL_COMM4,
    4223                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4224                 :            :                 pbn_b2_bt_4_115200 },
    4225                 :            :         {       PCI_VENDOR_ID_SEALEVEL, PCI_DEVICE_ID_SEALEVEL_COMM8,
    4226                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4227                 :            :                 pbn_b2_8_115200 },
    4228                 :            :         {       PCI_VENDOR_ID_SEALEVEL, PCI_DEVICE_ID_SEALEVEL_7803,
    4229                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4230                 :            :                 pbn_b2_8_460800 },
    4231                 :            :         {       PCI_VENDOR_ID_SEALEVEL, PCI_DEVICE_ID_SEALEVEL_UCOMM8,
    4232                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4233                 :            :                 pbn_b2_8_115200 },
    4234                 :            : 
    4235                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_GTEK_SERIAL2,
    4236                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4237                 :            :                 pbn_b2_bt_2_115200 },
    4238                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_SPCOM200,
    4239                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4240                 :            :                 pbn_b2_bt_2_921600 },
    4241                 :            :         /*
    4242                 :            :          * VScom SPCOM800, from sl@s.pl
    4243                 :            :          */
    4244                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_SPCOM800,
    4245                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4246                 :            :                 pbn_b2_8_921600 },
    4247                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_1077,
    4248                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4249                 :            :                 pbn_b2_4_921600 },
    4250                 :            :         /* Unknown card - subdevice 0x1584 */
    4251                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_9050,
    4252                 :            :                 PCI_VENDOR_ID_PLX,
    4253                 :            :                 PCI_SUBDEVICE_ID_UNKNOWN_0x1584, 0, 0,
    4254                 :            :                 pbn_b2_4_115200 },
    4255                 :            :         /* Unknown card - subdevice 0x1588 */
    4256                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_9050,
    4257                 :            :                 PCI_VENDOR_ID_PLX,
    4258                 :            :                 PCI_SUBDEVICE_ID_UNKNOWN_0x1588, 0, 0,
    4259                 :            :                 pbn_b2_8_115200 },
    4260                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_9050,
    4261                 :            :                 PCI_SUBVENDOR_ID_KEYSPAN,
    4262                 :            :                 PCI_SUBDEVICE_ID_KEYSPAN_SX2, 0, 0,
    4263                 :            :                 pbn_panacom },
    4264                 :            :         {       PCI_VENDOR_ID_PANACOM, PCI_DEVICE_ID_PANACOM_QUADMODEM,
    4265                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4266                 :            :                 pbn_panacom4 },
    4267                 :            :         {       PCI_VENDOR_ID_PANACOM, PCI_DEVICE_ID_PANACOM_DUALMODEM,
    4268                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4269                 :            :                 pbn_panacom2 },
    4270                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_9030,
    4271                 :            :                 PCI_VENDOR_ID_ESDGMBH,
    4272                 :            :                 PCI_DEVICE_ID_ESDGMBH_CPCIASIO4, 0, 0,
    4273                 :            :                 pbn_b2_4_115200 },
    4274                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_9050,
    4275                 :            :                 PCI_SUBVENDOR_ID_CHASE_PCIFAST,
    4276                 :            :                 PCI_SUBDEVICE_ID_CHASE_PCIFAST4, 0, 0,
    4277                 :            :                 pbn_b2_4_460800 },
    4278                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_9050,
    4279                 :            :                 PCI_SUBVENDOR_ID_CHASE_PCIFAST,
    4280                 :            :                 PCI_SUBDEVICE_ID_CHASE_PCIFAST8, 0, 0,
    4281                 :            :                 pbn_b2_8_460800 },
    4282                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_9050,
    4283                 :            :                 PCI_SUBVENDOR_ID_CHASE_PCIFAST,
    4284                 :            :                 PCI_SUBDEVICE_ID_CHASE_PCIFAST16, 0, 0,
    4285                 :            :                 pbn_b2_16_460800 },
    4286                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_9050,
    4287                 :            :                 PCI_SUBVENDOR_ID_CHASE_PCIFAST,
    4288                 :            :                 PCI_SUBDEVICE_ID_CHASE_PCIFAST16FMC, 0, 0,
    4289                 :            :                 pbn_b2_16_460800 },
    4290                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_9050,
    4291                 :            :                 PCI_SUBVENDOR_ID_CHASE_PCIRAS,
    4292                 :            :                 PCI_SUBDEVICE_ID_CHASE_PCIRAS4, 0, 0,
    4293                 :            :                 pbn_b2_4_460800 },
    4294                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_9050,
    4295                 :            :                 PCI_SUBVENDOR_ID_CHASE_PCIRAS,
    4296                 :            :                 PCI_SUBDEVICE_ID_CHASE_PCIRAS8, 0, 0,
    4297                 :            :                 pbn_b2_8_460800 },
    4298                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_9050,
    4299                 :            :                 PCI_SUBVENDOR_ID_EXSYS,
    4300                 :            :                 PCI_SUBDEVICE_ID_EXSYS_4055, 0, 0,
    4301                 :            :                 pbn_b2_4_115200 },
    4302                 :            :         /*
    4303                 :            :          * Megawolf Romulus PCI Serial Card, from Mike Hudson
    4304                 :            :          * (Exoray@isys.ca)
    4305                 :            :          */
    4306                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_ROMULUS,
    4307                 :            :                 0x10b5, 0x106a, 0, 0,
    4308                 :            :                 pbn_plx_romulus },
    4309                 :            :         /*
    4310                 :            :         * EndRun Technologies. PCI express device range.
    4311                 :            :         *    EndRun PTP/1588 has 2 Native UARTs.
    4312                 :            :         */
    4313                 :            :         {       PCI_VENDOR_ID_ENDRUN, PCI_DEVICE_ID_ENDRUN_1588,
    4314                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4315                 :            :                 pbn_endrun_2_4000000 },
    4316                 :            :         /*
    4317                 :            :          * Quatech cards. These actually have configurable clocks but for
    4318                 :            :          * now we just use the default.
    4319                 :            :          *
    4320                 :            :          * 100 series are RS232, 200 series RS422,
    4321                 :            :          */
    4322                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_QSC100,
    4323                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4324                 :            :                 pbn_b1_4_115200 },
    4325                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_DSC100,
    4326                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4327                 :            :                 pbn_b1_2_115200 },
    4328                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_DSC100E,
    4329                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4330                 :            :                 pbn_b2_2_115200 },
    4331                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_DSC200,
    4332                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4333                 :            :                 pbn_b1_2_115200 },
    4334                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_DSC200E,
    4335                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4336                 :            :                 pbn_b2_2_115200 },
    4337                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_QSC200,
    4338                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4339                 :            :                 pbn_b1_4_115200 },
    4340                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_ESC100D,
    4341                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4342                 :            :                 pbn_b1_8_115200 },
    4343                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_ESC100M,
    4344                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4345                 :            :                 pbn_b1_8_115200 },
    4346                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_QSCP100,
    4347                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4348                 :            :                 pbn_b1_4_115200 },
    4349                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_DSCP100,
    4350                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4351                 :            :                 pbn_b1_2_115200 },
    4352                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_QSCP200,
    4353                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4354                 :            :                 pbn_b1_4_115200 },
    4355                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_DSCP200,
    4356                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4357                 :            :                 pbn_b1_2_115200 },
    4358                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_QSCLP100,
    4359                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4360                 :            :                 pbn_b2_4_115200 },
    4361                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_DSCLP100,
    4362                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4363                 :            :                 pbn_b2_2_115200 },
    4364                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_SSCLP100,
    4365                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4366                 :            :                 pbn_b2_1_115200 },
    4367                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_QSCLP200,
    4368                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4369                 :            :                 pbn_b2_4_115200 },
    4370                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_DSCLP200,
    4371                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4372                 :            :                 pbn_b2_2_115200 },
    4373                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_SSCLP200,
    4374                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4375                 :            :                 pbn_b2_1_115200 },
    4376                 :            :         {       PCI_VENDOR_ID_QUATECH, PCI_DEVICE_ID_QUATECH_ESCLP100,
    4377                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4378                 :            :                 pbn_b0_8_115200 },
    4379                 :            : 
    4380                 :            :         {       PCI_VENDOR_ID_SPECIALIX, PCI_DEVICE_ID_OXSEMI_16PCI954,
    4381                 :            :                 PCI_VENDOR_ID_SPECIALIX, PCI_SUBDEVICE_ID_SPECIALIX_SPEED4,
    4382                 :            :                 0, 0,
    4383                 :            :                 pbn_b0_4_921600 },
    4384                 :            :         {       PCI_VENDOR_ID_OXSEMI, PCI_DEVICE_ID_OXSEMI_16PCI954,
    4385                 :            :                 PCI_SUBVENDOR_ID_SIIG, PCI_SUBDEVICE_ID_SIIG_QUARTET_SERIAL,
    4386                 :            :                 0, 0,
    4387                 :            :                 pbn_b0_4_1152000 },
    4388                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0x9505,
    4389                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4390                 :            :                 pbn_b0_bt_2_921600 },
    4391                 :            : 
    4392                 :            :                 /*
    4393                 :            :                  * The below card is a little controversial since it is the
    4394                 :            :                  * subject of a PCI vendor/device ID clash.  (See
    4395                 :            :                  * www.ussg.iu.edu/hypermail/linux/kernel/0303.1/0516.html).
    4396                 :            :                  * For now just used the hex ID 0x950a.
    4397                 :            :                  */
    4398                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0x950a,
    4399                 :            :                 PCI_SUBVENDOR_ID_SIIG, PCI_SUBDEVICE_ID_SIIG_DUAL_00,
    4400                 :            :                 0, 0, pbn_b0_2_115200 },
    4401                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0x950a,
    4402                 :            :                 PCI_SUBVENDOR_ID_SIIG, PCI_SUBDEVICE_ID_SIIG_DUAL_30,
    4403                 :            :                 0, 0, pbn_b0_2_115200 },
    4404                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0x950a,
    4405                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4406                 :            :                 pbn_b0_2_1130000 },
    4407                 :            :         {       PCI_VENDOR_ID_OXSEMI, PCI_DEVICE_ID_OXSEMI_C950,
    4408                 :            :                 PCI_VENDOR_ID_OXSEMI, PCI_SUBDEVICE_ID_OXSEMI_C950, 0, 0,
    4409                 :            :                 pbn_b0_1_921600 },
    4410                 :            :         {       PCI_VENDOR_ID_OXSEMI, PCI_DEVICE_ID_OXSEMI_16PCI954,
    4411                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4412                 :            :                 pbn_b0_4_115200 },
    4413                 :            :         {       PCI_VENDOR_ID_OXSEMI, PCI_DEVICE_ID_OXSEMI_16PCI952,
    4414                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4415                 :            :                 pbn_b0_bt_2_921600 },
    4416                 :            :         {       PCI_VENDOR_ID_OXSEMI, PCI_DEVICE_ID_OXSEMI_16PCI958,
    4417                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4418                 :            :                 pbn_b2_8_1152000 },
    4419                 :            : 
    4420                 :            :         /*
    4421                 :            :          * Oxford Semiconductor Inc. Tornado PCI express device range.
    4422                 :            :          */
    4423                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc101,    /* OXPCIe952 1 Legacy UART */
    4424                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4425                 :            :                 pbn_b0_1_4000000 },
    4426                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc105,    /* OXPCIe952 1 Legacy UART */
    4427                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4428                 :            :                 pbn_b0_1_4000000 },
    4429                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc11b,    /* OXPCIe952 1 Native UART */
    4430                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4431                 :            :                 pbn_oxsemi_1_4000000 },
    4432                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc11f,    /* OXPCIe952 1 Native UART */
    4433                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4434                 :            :                 pbn_oxsemi_1_4000000 },
    4435                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc120,    /* OXPCIe952 1 Legacy UART */
    4436                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4437                 :            :                 pbn_b0_1_4000000 },
    4438                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc124,    /* OXPCIe952 1 Legacy UART */
    4439                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4440                 :            :                 pbn_b0_1_4000000 },
    4441                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc138,    /* OXPCIe952 1 Native UART */
    4442                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4443                 :            :                 pbn_oxsemi_1_4000000 },
    4444                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc13d,    /* OXPCIe952 1 Native UART */
    4445                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4446                 :            :                 pbn_oxsemi_1_4000000 },
    4447                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc140,    /* OXPCIe952 1 Legacy UART */
    4448                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4449                 :            :                 pbn_b0_1_4000000 },
    4450                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc141,    /* OXPCIe952 1 Legacy UART */
    4451                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4452                 :            :                 pbn_b0_1_4000000 },
    4453                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc144,    /* OXPCIe952 1 Legacy UART */
    4454                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4455                 :            :                 pbn_b0_1_4000000 },
    4456                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc145,    /* OXPCIe952 1 Legacy UART */
    4457                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4458                 :            :                 pbn_b0_1_4000000 },
    4459                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc158,    /* OXPCIe952 2 Native UART */
    4460                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4461                 :            :                 pbn_oxsemi_2_4000000 },
    4462                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc15d,    /* OXPCIe952 2 Native UART */
    4463                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4464                 :            :                 pbn_oxsemi_2_4000000 },
    4465                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc208,    /* OXPCIe954 4 Native UART */
    4466                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4467                 :            :                 pbn_oxsemi_4_4000000 },
    4468                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc20d,    /* OXPCIe954 4 Native UART */
    4469                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4470                 :            :                 pbn_oxsemi_4_4000000 },
    4471                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc308,    /* OXPCIe958 8 Native UART */
    4472                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4473                 :            :                 pbn_oxsemi_8_4000000 },
    4474                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc30d,    /* OXPCIe958 8 Native UART */
    4475                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4476                 :            :                 pbn_oxsemi_8_4000000 },
    4477                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc40b,    /* OXPCIe200 1 Native UART */
    4478                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4479                 :            :                 pbn_oxsemi_1_4000000 },
    4480                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc40f,    /* OXPCIe200 1 Native UART */
    4481                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4482                 :            :                 pbn_oxsemi_1_4000000 },
    4483                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc41b,    /* OXPCIe200 1 Native UART */
    4484                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4485                 :            :                 pbn_oxsemi_1_4000000 },
    4486                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc41f,    /* OXPCIe200 1 Native UART */
    4487                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4488                 :            :                 pbn_oxsemi_1_4000000 },
    4489                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc42b,    /* OXPCIe200 1 Native UART */
    4490                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4491                 :            :                 pbn_oxsemi_1_4000000 },
    4492                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc42f,    /* OXPCIe200 1 Native UART */
    4493                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4494                 :            :                 pbn_oxsemi_1_4000000 },
    4495                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc43b,    /* OXPCIe200 1 Native UART */
    4496                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4497                 :            :                 pbn_oxsemi_1_4000000 },
    4498                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc43f,    /* OXPCIe200 1 Native UART */
    4499                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4500                 :            :                 pbn_oxsemi_1_4000000 },
    4501                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc44b,    /* OXPCIe200 1 Native UART */
    4502                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4503                 :            :                 pbn_oxsemi_1_4000000 },
    4504                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc44f,    /* OXPCIe200 1 Native UART */
    4505                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4506                 :            :                 pbn_oxsemi_1_4000000 },
    4507                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc45b,    /* OXPCIe200 1 Native UART */
    4508                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4509                 :            :                 pbn_oxsemi_1_4000000 },
    4510                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc45f,    /* OXPCIe200 1 Native UART */
    4511                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4512                 :            :                 pbn_oxsemi_1_4000000 },
    4513                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc46b,    /* OXPCIe200 1 Native UART */
    4514                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4515                 :            :                 pbn_oxsemi_1_4000000 },
    4516                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc46f,    /* OXPCIe200 1 Native UART */
    4517                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4518                 :            :                 pbn_oxsemi_1_4000000 },
    4519                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc47b,    /* OXPCIe200 1 Native UART */
    4520                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4521                 :            :                 pbn_oxsemi_1_4000000 },
    4522                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc47f,    /* OXPCIe200 1 Native UART */
    4523                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4524                 :            :                 pbn_oxsemi_1_4000000 },
    4525                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc48b,    /* OXPCIe200 1 Native UART */
    4526                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4527                 :            :                 pbn_oxsemi_1_4000000 },
    4528                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc48f,    /* OXPCIe200 1 Native UART */
    4529                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4530                 :            :                 pbn_oxsemi_1_4000000 },
    4531                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc49b,    /* OXPCIe200 1 Native UART */
    4532                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4533                 :            :                 pbn_oxsemi_1_4000000 },
    4534                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc49f,    /* OXPCIe200 1 Native UART */
    4535                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4536                 :            :                 pbn_oxsemi_1_4000000 },
    4537                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc4ab,    /* OXPCIe200 1 Native UART */
    4538                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4539                 :            :                 pbn_oxsemi_1_4000000 },
    4540                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc4af,    /* OXPCIe200 1 Native UART */
    4541                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4542                 :            :                 pbn_oxsemi_1_4000000 },
    4543                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc4bb,    /* OXPCIe200 1 Native UART */
    4544                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4545                 :            :                 pbn_oxsemi_1_4000000 },
    4546                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc4bf,    /* OXPCIe200 1 Native UART */
    4547                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4548                 :            :                 pbn_oxsemi_1_4000000 },
    4549                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc4cb,    /* OXPCIe200 1 Native UART */
    4550                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4551                 :            :                 pbn_oxsemi_1_4000000 },
    4552                 :            :         {       PCI_VENDOR_ID_OXSEMI, 0xc4cf,    /* OXPCIe200 1 Native UART */
    4553                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4554                 :            :                 pbn_oxsemi_1_4000000 },
    4555                 :            :         /*
    4556                 :            :          * Mainpine Inc. IQ Express "Rev3" utilizing OxSemi Tornado
    4557                 :            :          */
    4558                 :            :         {       PCI_VENDOR_ID_MAINPINE, 0x4000, /* IQ Express 1 Port V.34 Super-G3 Fax */
    4559                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x4001, 0, 0,
    4560                 :            :                 pbn_oxsemi_1_4000000 },
    4561                 :            :         {       PCI_VENDOR_ID_MAINPINE, 0x4000, /* IQ Express 2 Port V.34 Super-G3 Fax */
    4562                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x4002, 0, 0,
    4563                 :            :                 pbn_oxsemi_2_4000000 },
    4564                 :            :         {       PCI_VENDOR_ID_MAINPINE, 0x4000, /* IQ Express 4 Port V.34 Super-G3 Fax */
    4565                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x4004, 0, 0,
    4566                 :            :                 pbn_oxsemi_4_4000000 },
    4567                 :            :         {       PCI_VENDOR_ID_MAINPINE, 0x4000, /* IQ Express 8 Port V.34 Super-G3 Fax */
    4568                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x4008, 0, 0,
    4569                 :            :                 pbn_oxsemi_8_4000000 },
    4570                 :            : 
    4571                 :            :         /*
    4572                 :            :          * Digi/IBM PCIe 2-port Async EIA-232 Adapter utilizing OxSemi Tornado
    4573                 :            :          */
    4574                 :            :         {       PCI_VENDOR_ID_DIGI, PCIE_DEVICE_ID_NEO_2_OX_IBM,
    4575                 :            :                 PCI_SUBVENDOR_ID_IBM, PCI_ANY_ID, 0, 0,
    4576                 :            :                 pbn_oxsemi_2_4000000 },
    4577                 :            : 
    4578                 :            :         /*
    4579                 :            :          * SBS Technologies, Inc. P-Octal and PMC-OCTPRO cards,
    4580                 :            :          * from skokodyn@yahoo.com
    4581                 :            :          */
    4582                 :            :         {       PCI_VENDOR_ID_SBSMODULARIO, PCI_DEVICE_ID_OCTPRO,
    4583                 :            :                 PCI_SUBVENDOR_ID_SBSMODULARIO, PCI_SUBDEVICE_ID_OCTPRO232, 0, 0,
    4584                 :            :                 pbn_sbsxrsio },
    4585                 :            :         {       PCI_VENDOR_ID_SBSMODULARIO, PCI_DEVICE_ID_OCTPRO,
    4586                 :            :                 PCI_SUBVENDOR_ID_SBSMODULARIO, PCI_SUBDEVICE_ID_OCTPRO422, 0, 0,
    4587                 :            :                 pbn_sbsxrsio },
    4588                 :            :         {       PCI_VENDOR_ID_SBSMODULARIO, PCI_DEVICE_ID_OCTPRO,
    4589                 :            :                 PCI_SUBVENDOR_ID_SBSMODULARIO, PCI_SUBDEVICE_ID_POCTAL232, 0, 0,
    4590                 :            :                 pbn_sbsxrsio },
    4591                 :            :         {       PCI_VENDOR_ID_SBSMODULARIO, PCI_DEVICE_ID_OCTPRO,
    4592                 :            :                 PCI_SUBVENDOR_ID_SBSMODULARIO, PCI_SUBDEVICE_ID_POCTAL422, 0, 0,
    4593                 :            :                 pbn_sbsxrsio },
    4594                 :            : 
    4595                 :            :         /*
    4596                 :            :          * Digitan DS560-558, from jimd@esoft.com
    4597                 :            :          */
    4598                 :            :         {       PCI_VENDOR_ID_ATT, PCI_DEVICE_ID_ATT_VENUS_MODEM,
    4599                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4600                 :            :                 pbn_b1_1_115200 },
    4601                 :            : 
    4602                 :            :         /*
    4603                 :            :          * Titan Electronic cards
    4604                 :            :          *  The 400L and 800L have a custom setup quirk.
    4605                 :            :          */
    4606                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_100,
    4607                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4608                 :            :                 pbn_b0_1_921600 },
    4609                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_200,
    4610                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4611                 :            :                 pbn_b0_2_921600 },
    4612                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_400,
    4613                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4614                 :            :                 pbn_b0_4_921600 },
    4615                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_800B,
    4616                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4617                 :            :                 pbn_b0_4_921600 },
    4618                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_100L,
    4619                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4620                 :            :                 pbn_b1_1_921600 },
    4621                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_200L,
    4622                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4623                 :            :                 pbn_b1_bt_2_921600 },
    4624                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_400L,
    4625                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4626                 :            :                 pbn_b0_bt_4_921600 },
    4627                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_800L,
    4628                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4629                 :            :                 pbn_b0_bt_8_921600 },
    4630                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_200I,
    4631                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4632                 :            :                 pbn_b4_bt_2_921600 },
    4633                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_400I,
    4634                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4635                 :            :                 pbn_b4_bt_4_921600 },
    4636                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_800I,
    4637                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4638                 :            :                 pbn_b4_bt_8_921600 },
    4639                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_400EH,
    4640                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4641                 :            :                 pbn_b0_4_921600 },
    4642                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_800EH,
    4643                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4644                 :            :                 pbn_b0_4_921600 },
    4645                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_800EHB,
    4646                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4647                 :            :                 pbn_b0_4_921600 },
    4648                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_100E,
    4649                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4650                 :            :                 pbn_oxsemi_1_4000000 },
    4651                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_200E,
    4652                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4653                 :            :                 pbn_oxsemi_2_4000000 },
    4654                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_400E,
    4655                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4656                 :            :                 pbn_oxsemi_4_4000000 },
    4657                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_800E,
    4658                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4659                 :            :                 pbn_oxsemi_8_4000000 },
    4660                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_200EI,
    4661                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4662                 :            :                 pbn_oxsemi_2_4000000 },
    4663                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_200EISI,
    4664                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4665                 :            :                 pbn_oxsemi_2_4000000 },
    4666                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_200V3,
    4667                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4668                 :            :                 pbn_b0_bt_2_921600 },
    4669                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_400V3,
    4670                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4671                 :            :                 pbn_b0_4_921600 },
    4672                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_410V3,
    4673                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4674                 :            :                 pbn_b0_4_921600 },
    4675                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_800V3,
    4676                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4677                 :            :                 pbn_b0_4_921600 },
    4678                 :            :         {       PCI_VENDOR_ID_TITAN, PCI_DEVICE_ID_TITAN_800V3B,
    4679                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4680                 :            :                 pbn_b0_4_921600 },
    4681                 :            : 
    4682                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_1S_10x_550,
    4683                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4684                 :            :                 pbn_b2_1_460800 },
    4685                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_1S_10x_650,
    4686                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4687                 :            :                 pbn_b2_1_460800 },
    4688                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_1S_10x_850,
    4689                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4690                 :            :                 pbn_b2_1_460800 },
    4691                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_2S_10x_550,
    4692                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4693                 :            :                 pbn_b2_bt_2_921600 },
    4694                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_2S_10x_650,
    4695                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4696                 :            :                 pbn_b2_bt_2_921600 },
    4697                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_2S_10x_850,
    4698                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4699                 :            :                 pbn_b2_bt_2_921600 },
    4700                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_4S_10x_550,
    4701                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4702                 :            :                 pbn_b2_bt_4_921600 },
    4703                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_4S_10x_650,
    4704                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4705                 :            :                 pbn_b2_bt_4_921600 },
    4706                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_4S_10x_850,
    4707                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4708                 :            :                 pbn_b2_bt_4_921600 },
    4709                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_1S_20x_550,
    4710                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4711                 :            :                 pbn_b0_1_921600 },
    4712                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_1S_20x_650,
    4713                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4714                 :            :                 pbn_b0_1_921600 },
    4715                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_1S_20x_850,
    4716                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4717                 :            :                 pbn_b0_1_921600 },
    4718                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_2S_20x_550,
    4719                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4720                 :            :                 pbn_b0_bt_2_921600 },
    4721                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_2S_20x_650,
    4722                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4723                 :            :                 pbn_b0_bt_2_921600 },
    4724                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_2S_20x_850,
    4725                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4726                 :            :                 pbn_b0_bt_2_921600 },
    4727                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_4S_20x_550,
    4728                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4729                 :            :                 pbn_b0_bt_4_921600 },
    4730                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_4S_20x_650,
    4731                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4732                 :            :                 pbn_b0_bt_4_921600 },
    4733                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_4S_20x_850,
    4734                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4735                 :            :                 pbn_b0_bt_4_921600 },
    4736                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_8S_20x_550,
    4737                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4738                 :            :                 pbn_b0_bt_8_921600 },
    4739                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_8S_20x_650,
    4740                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4741                 :            :                 pbn_b0_bt_8_921600 },
    4742                 :            :         {       PCI_VENDOR_ID_SIIG, PCI_DEVICE_ID_SIIG_8S_20x_850,
    4743                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4744                 :            :                 pbn_b0_bt_8_921600 },
    4745                 :            : 
    4746                 :            :         /*
    4747                 :            :          * Computone devices submitted by Doug McNash dmcnash@computone.com
    4748                 :            :          */
    4749                 :            :         {       PCI_VENDOR_ID_COMPUTONE, PCI_DEVICE_ID_COMPUTONE_PG,
    4750                 :            :                 PCI_SUBVENDOR_ID_COMPUTONE, PCI_SUBDEVICE_ID_COMPUTONE_PG4,
    4751                 :            :                 0, 0, pbn_computone_4 },
    4752                 :            :         {       PCI_VENDOR_ID_COMPUTONE, PCI_DEVICE_ID_COMPUTONE_PG,
    4753                 :            :                 PCI_SUBVENDOR_ID_COMPUTONE, PCI_SUBDEVICE_ID_COMPUTONE_PG8,
    4754                 :            :                 0, 0, pbn_computone_8 },
    4755                 :            :         {       PCI_VENDOR_ID_COMPUTONE, PCI_DEVICE_ID_COMPUTONE_PG,
    4756                 :            :                 PCI_SUBVENDOR_ID_COMPUTONE, PCI_SUBDEVICE_ID_COMPUTONE_PG6,
    4757                 :            :                 0, 0, pbn_computone_6 },
    4758                 :            : 
    4759                 :            :         {       PCI_VENDOR_ID_OXSEMI, PCI_DEVICE_ID_OXSEMI_16PCI95N,
    4760                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4761                 :            :                 pbn_oxsemi },
    4762                 :            :         {       PCI_VENDOR_ID_TIMEDIA, PCI_DEVICE_ID_TIMEDIA_1889,
    4763                 :            :                 PCI_VENDOR_ID_TIMEDIA, PCI_ANY_ID, 0, 0,
    4764                 :            :                 pbn_b0_bt_1_921600 },
    4765                 :            : 
    4766                 :            :         /*
    4767                 :            :          * Sunix PCI serial boards
    4768                 :            :          */
    4769                 :            :         {       PCI_VENDOR_ID_SUNIX, PCI_DEVICE_ID_SUNIX_1999,
    4770                 :            :                 PCI_VENDOR_ID_SUNIX, 0x0001, 0, 0,
    4771                 :            :                 pbn_sunix_pci_1s },
    4772                 :            :         {       PCI_VENDOR_ID_SUNIX, PCI_DEVICE_ID_SUNIX_1999,
    4773                 :            :                 PCI_VENDOR_ID_SUNIX, 0x0002, 0, 0,
    4774                 :            :                 pbn_sunix_pci_2s },
    4775                 :            :         {       PCI_VENDOR_ID_SUNIX, PCI_DEVICE_ID_SUNIX_1999,
    4776                 :            :                 PCI_VENDOR_ID_SUNIX, 0x0004, 0, 0,
    4777                 :            :                 pbn_sunix_pci_4s },
    4778                 :            :         {       PCI_VENDOR_ID_SUNIX, PCI_DEVICE_ID_SUNIX_1999,
    4779                 :            :                 PCI_VENDOR_ID_SUNIX, 0x0084, 0, 0,
    4780                 :            :                 pbn_sunix_pci_4s },
    4781                 :            :         {       PCI_VENDOR_ID_SUNIX, PCI_DEVICE_ID_SUNIX_1999,
    4782                 :            :                 PCI_VENDOR_ID_SUNIX, 0x0008, 0, 0,
    4783                 :            :                 pbn_sunix_pci_8s },
    4784                 :            :         {       PCI_VENDOR_ID_SUNIX, PCI_DEVICE_ID_SUNIX_1999,
    4785                 :            :                 PCI_VENDOR_ID_SUNIX, 0x0088, 0, 0,
    4786                 :            :                 pbn_sunix_pci_8s },
    4787                 :            :         {       PCI_VENDOR_ID_SUNIX, PCI_DEVICE_ID_SUNIX_1999,
    4788                 :            :                 PCI_VENDOR_ID_SUNIX, 0x0010, 0, 0,
    4789                 :            :                 pbn_sunix_pci_16s },
    4790                 :            : 
    4791                 :            :         /*
    4792                 :            :          * AFAVLAB serial card, from Harald Welte <laforge@gnumonks.org>
    4793                 :            :          */
    4794                 :            :         {       PCI_VENDOR_ID_AFAVLAB, PCI_DEVICE_ID_AFAVLAB_P028,
    4795                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4796                 :            :                 pbn_b0_bt_8_115200 },
    4797                 :            :         {       PCI_VENDOR_ID_AFAVLAB, PCI_DEVICE_ID_AFAVLAB_P030,
    4798                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4799                 :            :                 pbn_b0_bt_8_115200 },
    4800                 :            : 
    4801                 :            :         {       PCI_VENDOR_ID_LAVA, PCI_DEVICE_ID_LAVA_DSERIAL,
    4802                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4803                 :            :                 pbn_b0_bt_2_115200 },
    4804                 :            :         {       PCI_VENDOR_ID_LAVA, PCI_DEVICE_ID_LAVA_QUATRO_A,
    4805                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4806                 :            :                 pbn_b0_bt_2_115200 },
    4807                 :            :         {       PCI_VENDOR_ID_LAVA, PCI_DEVICE_ID_LAVA_QUATRO_B,
    4808                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4809                 :            :                 pbn_b0_bt_2_115200 },
    4810                 :            :         {       PCI_VENDOR_ID_LAVA, PCI_DEVICE_ID_LAVA_QUATTRO_A,
    4811                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4812                 :            :                 pbn_b0_bt_2_115200 },
    4813                 :            :         {       PCI_VENDOR_ID_LAVA, PCI_DEVICE_ID_LAVA_QUATTRO_B,
    4814                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4815                 :            :                 pbn_b0_bt_2_115200 },
    4816                 :            :         {       PCI_VENDOR_ID_LAVA, PCI_DEVICE_ID_LAVA_OCTO_A,
    4817                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4818                 :            :                 pbn_b0_bt_4_460800 },
    4819                 :            :         {       PCI_VENDOR_ID_LAVA, PCI_DEVICE_ID_LAVA_OCTO_B,
    4820                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4821                 :            :                 pbn_b0_bt_4_460800 },
    4822                 :            :         {       PCI_VENDOR_ID_LAVA, PCI_DEVICE_ID_LAVA_PORT_PLUS,
    4823                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4824                 :            :                 pbn_b0_bt_2_460800 },
    4825                 :            :         {       PCI_VENDOR_ID_LAVA, PCI_DEVICE_ID_LAVA_QUAD_A,
    4826                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4827                 :            :                 pbn_b0_bt_2_460800 },
    4828                 :            :         {       PCI_VENDOR_ID_LAVA, PCI_DEVICE_ID_LAVA_QUAD_B,
    4829                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4830                 :            :                 pbn_b0_bt_2_460800 },
    4831                 :            :         {       PCI_VENDOR_ID_LAVA, PCI_DEVICE_ID_LAVA_SSERIAL,
    4832                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4833                 :            :                 pbn_b0_bt_1_115200 },
    4834                 :            :         {       PCI_VENDOR_ID_LAVA, PCI_DEVICE_ID_LAVA_PORT_650,
    4835                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4836                 :            :                 pbn_b0_bt_1_460800 },
    4837                 :            : 
    4838                 :            :         /*
    4839                 :            :          * Korenix Jetcard F0/F1 cards (JC1204, JC1208, JC1404, JC1408).
    4840                 :            :          * Cards are identified by their subsystem vendor IDs, which
    4841                 :            :          * (in hex) match the model number.
    4842                 :            :          *
    4843                 :            :          * Note that JC140x are RS422/485 cards which require ox950
    4844                 :            :          * ACR = 0x10, and as such are not currently fully supported.
    4845                 :            :          */
    4846                 :            :         {       PCI_VENDOR_ID_KORENIX, PCI_DEVICE_ID_KORENIX_JETCARDF0,
    4847                 :            :                 0x1204, 0x0004, 0, 0,
    4848                 :            :                 pbn_b0_4_921600 },
    4849                 :            :         {       PCI_VENDOR_ID_KORENIX, PCI_DEVICE_ID_KORENIX_JETCARDF0,
    4850                 :            :                 0x1208, 0x0004, 0, 0,
    4851                 :            :                 pbn_b0_4_921600 },
    4852                 :            : /*      {       PCI_VENDOR_ID_KORENIX, PCI_DEVICE_ID_KORENIX_JETCARDF0,
    4853                 :            :                 0x1402, 0x0002, 0, 0,
    4854                 :            :                 pbn_b0_2_921600 }, */
    4855                 :            : /*      {       PCI_VENDOR_ID_KORENIX, PCI_DEVICE_ID_KORENIX_JETCARDF0,
    4856                 :            :                 0x1404, 0x0004, 0, 0,
    4857                 :            :                 pbn_b0_4_921600 }, */
    4858                 :            :         {       PCI_VENDOR_ID_KORENIX, PCI_DEVICE_ID_KORENIX_JETCARDF1,
    4859                 :            :                 0x1208, 0x0004, 0, 0,
    4860                 :            :                 pbn_b0_4_921600 },
    4861                 :            : 
    4862                 :            :         {       PCI_VENDOR_ID_KORENIX, PCI_DEVICE_ID_KORENIX_JETCARDF2,
    4863                 :            :                 0x1204, 0x0004, 0, 0,
    4864                 :            :                 pbn_b0_4_921600 },
    4865                 :            :         {       PCI_VENDOR_ID_KORENIX, PCI_DEVICE_ID_KORENIX_JETCARDF2,
    4866                 :            :                 0x1208, 0x0004, 0, 0,
    4867                 :            :                 pbn_b0_4_921600 },
    4868                 :            :         {       PCI_VENDOR_ID_KORENIX, PCI_DEVICE_ID_KORENIX_JETCARDF3,
    4869                 :            :                 0x1208, 0x0004, 0, 0,
    4870                 :            :                 pbn_b0_4_921600 },
    4871                 :            :         /*
    4872                 :            :          * Dell Remote Access Card 4 - Tim_T_Murphy@Dell.com
    4873                 :            :          */
    4874                 :            :         {       PCI_VENDOR_ID_DELL, PCI_DEVICE_ID_DELL_RAC4,
    4875                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4876                 :            :                 pbn_b1_1_1382400 },
    4877                 :            : 
    4878                 :            :         /*
    4879                 :            :          * Dell Remote Access Card III - Tim_T_Murphy@Dell.com
    4880                 :            :          */
    4881                 :            :         {       PCI_VENDOR_ID_DELL, PCI_DEVICE_ID_DELL_RACIII,
    4882                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4883                 :            :                 pbn_b1_1_1382400 },
    4884                 :            : 
    4885                 :            :         /*
    4886                 :            :          * RAStel 2 port modem, gerg@moreton.com.au
    4887                 :            :          */
    4888                 :            :         {       PCI_VENDOR_ID_MORETON, PCI_DEVICE_ID_RASTEL_2PORT,
    4889                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4890                 :            :                 pbn_b2_bt_2_115200 },
    4891                 :            : 
    4892                 :            :         /*
    4893                 :            :          * EKF addition for i960 Boards form EKF with serial port
    4894                 :            :          */
    4895                 :            :         {       PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_80960_RP,
    4896                 :            :                 0xE4BF, PCI_ANY_ID, 0, 0,
    4897                 :            :                 pbn_intel_i960 },
    4898                 :            : 
    4899                 :            :         /*
    4900                 :            :          * Xircom Cardbus/Ethernet combos
    4901                 :            :          */
    4902                 :            :         {       PCI_VENDOR_ID_XIRCOM, PCI_DEVICE_ID_XIRCOM_X3201_MDM,
    4903                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4904                 :            :                 pbn_b0_1_115200 },
    4905                 :            :         /*
    4906                 :            :          * Xircom RBM56G cardbus modem - Dirk Arnold (temp entry)
    4907                 :            :          */
    4908                 :            :         {       PCI_VENDOR_ID_XIRCOM, PCI_DEVICE_ID_XIRCOM_RBM56G,
    4909                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4910                 :            :                 pbn_b0_1_115200 },
    4911                 :            : 
    4912                 :            :         /*
    4913                 :            :          * Untested PCI modems, sent in from various folks...
    4914                 :            :          */
    4915                 :            : 
    4916                 :            :         /*
    4917                 :            :          * Elsa Model 56K PCI Modem, from Andreas Rath <arh@01019freenet.de>
    4918                 :            :          */
    4919                 :            :         {       PCI_VENDOR_ID_ROCKWELL, 0x1004,
    4920                 :            :                 0x1048, 0x1500, 0, 0,
    4921                 :            :                 pbn_b1_1_115200 },
    4922                 :            : 
    4923                 :            :         {       PCI_VENDOR_ID_SGI, PCI_DEVICE_ID_SGI_IOC3,
    4924                 :            :                 0xFF00, 0, 0, 0,
    4925                 :            :                 pbn_sgi_ioc3 },
    4926                 :            : 
    4927                 :            :         /*
    4928                 :            :          * HP Diva card
    4929                 :            :          */
    4930                 :            :         {       PCI_VENDOR_ID_HP, PCI_DEVICE_ID_HP_DIVA,
    4931                 :            :                 PCI_VENDOR_ID_HP, PCI_DEVICE_ID_HP_DIVA_RMP3, 0, 0,
    4932                 :            :                 pbn_b1_1_115200 },
    4933                 :            :         {       PCI_VENDOR_ID_HP, PCI_DEVICE_ID_HP_DIVA,
    4934                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4935                 :            :                 pbn_b0_5_115200 },
    4936                 :            :         {       PCI_VENDOR_ID_HP, PCI_DEVICE_ID_HP_DIVA_AUX,
    4937                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4938                 :            :                 pbn_b2_1_115200 },
    4939                 :            : 
    4940                 :            :         {       PCI_VENDOR_ID_DCI, PCI_DEVICE_ID_DCI_PCCOM2,
    4941                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4942                 :            :                 pbn_b3_2_115200 },
    4943                 :            :         {       PCI_VENDOR_ID_DCI, PCI_DEVICE_ID_DCI_PCCOM4,
    4944                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4945                 :            :                 pbn_b3_4_115200 },
    4946                 :            :         {       PCI_VENDOR_ID_DCI, PCI_DEVICE_ID_DCI_PCCOM8,
    4947                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4948                 :            :                 pbn_b3_8_115200 },
    4949                 :            :         /*
    4950                 :            :          * Pericom PI7C9X795[1248] Uno/Dual/Quad/Octal UART
    4951                 :            :          */
    4952                 :            :         {   PCI_VENDOR_ID_PERICOM, PCI_DEVICE_ID_PERICOM_PI7C9X7951,
    4953                 :            :                 PCI_ANY_ID, PCI_ANY_ID,
    4954                 :            :                 0,
    4955                 :            :                 0, pbn_pericom_PI7C9X7951 },
    4956                 :            :         {   PCI_VENDOR_ID_PERICOM, PCI_DEVICE_ID_PERICOM_PI7C9X7952,
    4957                 :            :                 PCI_ANY_ID, PCI_ANY_ID,
    4958                 :            :                 0,
    4959                 :            :                 0, pbn_pericom_PI7C9X7952 },
    4960                 :            :         {   PCI_VENDOR_ID_PERICOM, PCI_DEVICE_ID_PERICOM_PI7C9X7954,
    4961                 :            :                 PCI_ANY_ID, PCI_ANY_ID,
    4962                 :            :                 0,
    4963                 :            :                 0, pbn_pericom_PI7C9X7954 },
    4964                 :            :         {   PCI_VENDOR_ID_PERICOM, PCI_DEVICE_ID_PERICOM_PI7C9X7958,
    4965                 :            :                 PCI_ANY_ID, PCI_ANY_ID,
    4966                 :            :                 0,
    4967                 :            :                 0, pbn_pericom_PI7C9X7958 },
    4968                 :            :         /*
    4969                 :            :          * ACCES I/O Products quad
    4970                 :            :          */
    4971                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_COM_2SDB,
    4972                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4973                 :            :                 pbn_pericom_PI7C9X7952 },
    4974                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_MPCIE_COM_2S,
    4975                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4976                 :            :                 pbn_pericom_PI7C9X7952 },
    4977                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_COM_4SDB,
    4978                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4979                 :            :                 pbn_pericom_PI7C9X7954 },
    4980                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_MPCIE_COM_4S,
    4981                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4982                 :            :                 pbn_pericom_PI7C9X7954 },
    4983                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_COM232_2DB,
    4984                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4985                 :            :                 pbn_pericom_PI7C9X7952 },
    4986                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_MPCIE_COM232_2,
    4987                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4988                 :            :                 pbn_pericom_PI7C9X7952 },
    4989                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_COM232_4DB,
    4990                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4991                 :            :                 pbn_pericom_PI7C9X7954 },
    4992                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_MPCIE_COM232_4,
    4993                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4994                 :            :                 pbn_pericom_PI7C9X7954 },
    4995                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_COM_2SMDB,
    4996                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    4997                 :            :                 pbn_pericom_PI7C9X7952 },
    4998                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_MPCIE_COM_2SM,
    4999                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5000                 :            :                 pbn_pericom_PI7C9X7952 },
    5001                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_COM_4SMDB,
    5002                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5003                 :            :                 pbn_pericom_PI7C9X7954 },
    5004                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_MPCIE_COM_4SM,
    5005                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5006                 :            :                 pbn_pericom_PI7C9X7954 },
    5007                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_MPCIE_ICM485_1,
    5008                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5009                 :            :                 pbn_pericom_PI7C9X7951 },
    5010                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_MPCIE_ICM422_2,
    5011                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5012                 :            :                 pbn_pericom_PI7C9X7952 },
    5013                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_MPCIE_ICM485_2,
    5014                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5015                 :            :                 pbn_pericom_PI7C9X7952 },
    5016                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_MPCIE_ICM422_4,
    5017                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5018                 :            :                 pbn_pericom_PI7C9X7954 },
    5019                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_MPCIE_ICM485_4,
    5020                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5021                 :            :                 pbn_pericom_PI7C9X7954 },
    5022                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_ICM_2S,
    5023                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5024                 :            :                 pbn_pericom_PI7C9X7952 },
    5025                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_ICM_4S,
    5026                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5027                 :            :                 pbn_pericom_PI7C9X7954 },
    5028                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_ICM232_2,
    5029                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5030                 :            :                 pbn_pericom_PI7C9X7952 },
    5031                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_MPCIE_ICM232_2,
    5032                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5033                 :            :                 pbn_pericom_PI7C9X7952 },
    5034                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_ICM232_4,
    5035                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5036                 :            :                 pbn_pericom_PI7C9X7954 },
    5037                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_MPCIE_ICM232_4,
    5038                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5039                 :            :                 pbn_pericom_PI7C9X7954 },
    5040                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_ICM_2SM,
    5041                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5042                 :            :                 pbn_pericom_PI7C9X7952 },
    5043                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_COM422_4,
    5044                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5045                 :            :                 pbn_pericom_PI7C9X7954 },
    5046                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_COM485_4,
    5047                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5048                 :            :                 pbn_pericom_PI7C9X7954 },
    5049                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_COM422_8,
    5050                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5051                 :            :                 pbn_pericom_PI7C9X7958 },
    5052                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_COM485_8,
    5053                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5054                 :            :                 pbn_pericom_PI7C9X7958 },
    5055                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_COM232_4,
    5056                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5057                 :            :                 pbn_pericom_PI7C9X7954 },
    5058                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_COM232_8,
    5059                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5060                 :            :                 pbn_pericom_PI7C9X7958 },
    5061                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_COM_4SM,
    5062                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5063                 :            :                 pbn_pericom_PI7C9X7954 },
    5064                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_COM_8SM,
    5065                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5066                 :            :                 pbn_pericom_PI7C9X7958 },
    5067                 :            :         {       PCI_VENDOR_ID_ACCESIO, PCI_DEVICE_ID_ACCESIO_PCIE_ICM_4SM,
    5068                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5069                 :            :                 pbn_pericom_PI7C9X7954 },
    5070                 :            :         /*
    5071                 :            :          * Topic TP560 Data/Fax/Voice 56k modem (reported by Evan Clarke)
    5072                 :            :          */
    5073                 :            :         {       PCI_VENDOR_ID_TOPIC, PCI_DEVICE_ID_TOPIC_TP560,
    5074                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5075                 :            :                 pbn_b0_1_115200 },
    5076                 :            :         /*
    5077                 :            :          * ITE
    5078                 :            :          */
    5079                 :            :         {       PCI_VENDOR_ID_ITE, PCI_DEVICE_ID_ITE_8872,
    5080                 :            :                 PCI_ANY_ID, PCI_ANY_ID,
    5081                 :            :                 0, 0,
    5082                 :            :                 pbn_b1_bt_1_115200 },
    5083                 :            : 
    5084                 :            :         /*
    5085                 :            :          * IntaShield IS-200
    5086                 :            :          */
    5087                 :            :         {       PCI_VENDOR_ID_INTASHIELD, PCI_DEVICE_ID_INTASHIELD_IS200,
    5088                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,   /* 135a.0811 */
    5089                 :            :                 pbn_b2_2_115200 },
    5090                 :            :         /*
    5091                 :            :          * IntaShield IS-400
    5092                 :            :          */
    5093                 :            :         {       PCI_VENDOR_ID_INTASHIELD, PCI_DEVICE_ID_INTASHIELD_IS400,
    5094                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,    /* 135a.0dc0 */
    5095                 :            :                 pbn_b2_4_115200 },
    5096                 :            :         /*
    5097                 :            :          * BrainBoxes UC-260
    5098                 :            :          */
    5099                 :            :         {       PCI_VENDOR_ID_INTASHIELD, 0x0D21,
    5100                 :            :                 PCI_ANY_ID, PCI_ANY_ID,
    5101                 :            :                 PCI_CLASS_COMMUNICATION_MULTISERIAL << 8, 0xffff00,
    5102                 :            :                 pbn_b2_4_115200 },
    5103                 :            :         {       PCI_VENDOR_ID_INTASHIELD, 0x0E34,
    5104                 :            :                 PCI_ANY_ID, PCI_ANY_ID,
    5105                 :            :                  PCI_CLASS_COMMUNICATION_MULTISERIAL << 8, 0xffff00,
    5106                 :            :                 pbn_b2_4_115200 },
    5107                 :            :         /*
    5108                 :            :          * Perle PCI-RAS cards
    5109                 :            :          */
    5110                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_9030,
    5111                 :            :                 PCI_SUBVENDOR_ID_PERLE, PCI_SUBDEVICE_ID_PCI_RAS4,
    5112                 :            :                 0, 0, pbn_b2_4_921600 },
    5113                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_9030,
    5114                 :            :                 PCI_SUBVENDOR_ID_PERLE, PCI_SUBDEVICE_ID_PCI_RAS8,
    5115                 :            :                 0, 0, pbn_b2_8_921600 },
    5116                 :            : 
    5117                 :            :         /*
    5118                 :            :          * Mainpine series cards: Fairly standard layout but fools
    5119                 :            :          * parts of the autodetect in some cases and uses otherwise
    5120                 :            :          * unmatched communications subclasses in the PCI Express case
    5121                 :            :          */
    5122                 :            : 
    5123                 :            :         {       /* RockForceDUO */
    5124                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5125                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x0200,
    5126                 :            :                 0, 0, pbn_b0_2_115200 },
    5127                 :            :         {       /* RockForceQUATRO */
    5128                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5129                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x0300,
    5130                 :            :                 0, 0, pbn_b0_4_115200 },
    5131                 :            :         {       /* RockForceDUO+ */
    5132                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5133                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x0400,
    5134                 :            :                 0, 0, pbn_b0_2_115200 },
    5135                 :            :         {       /* RockForceQUATRO+ */
    5136                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5137                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x0500,
    5138                 :            :                 0, 0, pbn_b0_4_115200 },
    5139                 :            :         {       /* RockForce+ */
    5140                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5141                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x0600,
    5142                 :            :                 0, 0, pbn_b0_2_115200 },
    5143                 :            :         {       /* RockForce+ */
    5144                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5145                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x0700,
    5146                 :            :                 0, 0, pbn_b0_4_115200 },
    5147                 :            :         {       /* RockForceOCTO+ */
    5148                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5149                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x0800,
    5150                 :            :                 0, 0, pbn_b0_8_115200 },
    5151                 :            :         {       /* RockForceDUO+ */
    5152                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5153                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x0C00,
    5154                 :            :                 0, 0, pbn_b0_2_115200 },
    5155                 :            :         {       /* RockForceQUARTRO+ */
    5156                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5157                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x0D00,
    5158                 :            :                 0, 0, pbn_b0_4_115200 },
    5159                 :            :         {       /* RockForceOCTO+ */
    5160                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5161                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x1D00,
    5162                 :            :                 0, 0, pbn_b0_8_115200 },
    5163                 :            :         {       /* RockForceD1 */
    5164                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5165                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x2000,
    5166                 :            :                 0, 0, pbn_b0_1_115200 },
    5167                 :            :         {       /* RockForceF1 */
    5168                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5169                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x2100,
    5170                 :            :                 0, 0, pbn_b0_1_115200 },
    5171                 :            :         {       /* RockForceD2 */
    5172                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5173                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x2200,
    5174                 :            :                 0, 0, pbn_b0_2_115200 },
    5175                 :            :         {       /* RockForceF2 */
    5176                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5177                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x2300,
    5178                 :            :                 0, 0, pbn_b0_2_115200 },
    5179                 :            :         {       /* RockForceD4 */
    5180                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5181                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x2400,
    5182                 :            :                 0, 0, pbn_b0_4_115200 },
    5183                 :            :         {       /* RockForceF4 */
    5184                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5185                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x2500,
    5186                 :            :                 0, 0, pbn_b0_4_115200 },
    5187                 :            :         {       /* RockForceD8 */
    5188                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5189                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x2600,
    5190                 :            :                 0, 0, pbn_b0_8_115200 },
    5191                 :            :         {       /* RockForceF8 */
    5192                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5193                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x2700,
    5194                 :            :                 0, 0, pbn_b0_8_115200 },
    5195                 :            :         {       /* IQ Express D1 */
    5196                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5197                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x3000,
    5198                 :            :                 0, 0, pbn_b0_1_115200 },
    5199                 :            :         {       /* IQ Express F1 */
    5200                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5201                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x3100,
    5202                 :            :                 0, 0, pbn_b0_1_115200 },
    5203                 :            :         {       /* IQ Express D2 */
    5204                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5205                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x3200,
    5206                 :            :                 0, 0, pbn_b0_2_115200 },
    5207                 :            :         {       /* IQ Express F2 */
    5208                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5209                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x3300,
    5210                 :            :                 0, 0, pbn_b0_2_115200 },
    5211                 :            :         {       /* IQ Express D4 */
    5212                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5213                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x3400,
    5214                 :            :                 0, 0, pbn_b0_4_115200 },
    5215                 :            :         {       /* IQ Express F4 */
    5216                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5217                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x3500,
    5218                 :            :                 0, 0, pbn_b0_4_115200 },
    5219                 :            :         {       /* IQ Express D8 */
    5220                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5221                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x3C00,
    5222                 :            :                 0, 0, pbn_b0_8_115200 },
    5223                 :            :         {       /* IQ Express F8 */
    5224                 :            :                 PCI_VENDOR_ID_MAINPINE, PCI_DEVICE_ID_MAINPINE_PBRIDGE,
    5225                 :            :                 PCI_VENDOR_ID_MAINPINE, 0x3D00,
    5226                 :            :                 0, 0, pbn_b0_8_115200 },
    5227                 :            : 
    5228                 :            : 
    5229                 :            :         /*
    5230                 :            :          * PA Semi PA6T-1682M on-chip UART
    5231                 :            :          */
    5232                 :            :         {       PCI_VENDOR_ID_PASEMI, 0xa004,
    5233                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5234                 :            :                 pbn_pasemi_1682M },
    5235                 :            : 
    5236                 :            :         /*
    5237                 :            :          * National Instruments
    5238                 :            :          */
    5239                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PCI23216,
    5240                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5241                 :            :                 pbn_b1_16_115200 },
    5242                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PCI2328,
    5243                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5244                 :            :                 pbn_b1_8_115200 },
    5245                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PCI2324,
    5246                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5247                 :            :                 pbn_b1_bt_4_115200 },
    5248                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PCI2322,
    5249                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5250                 :            :                 pbn_b1_bt_2_115200 },
    5251                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PCI2324I,
    5252                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5253                 :            :                 pbn_b1_bt_4_115200 },
    5254                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PCI2322I,
    5255                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5256                 :            :                 pbn_b1_bt_2_115200 },
    5257                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PXI8420_23216,
    5258                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5259                 :            :                 pbn_b1_16_115200 },
    5260                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PXI8420_2328,
    5261                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5262                 :            :                 pbn_b1_8_115200 },
    5263                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PXI8420_2324,
    5264                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5265                 :            :                 pbn_b1_bt_4_115200 },
    5266                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PXI8420_2322,
    5267                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5268                 :            :                 pbn_b1_bt_2_115200 },
    5269                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PXI8422_2324,
    5270                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5271                 :            :                 pbn_b1_bt_4_115200 },
    5272                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PXI8422_2322,
    5273                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5274                 :            :                 pbn_b1_bt_2_115200 },
    5275                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PXI8430_2322,
    5276                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5277                 :            :                 pbn_ni8430_2 },
    5278                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PCI8430_2322,
    5279                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5280                 :            :                 pbn_ni8430_2 },
    5281                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PXI8430_2324,
    5282                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5283                 :            :                 pbn_ni8430_4 },
    5284                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PCI8430_2324,
    5285                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5286                 :            :                 pbn_ni8430_4 },
    5287                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PXI8430_2328,
    5288                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5289                 :            :                 pbn_ni8430_8 },
    5290                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PCI8430_2328,
    5291                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5292                 :            :                 pbn_ni8430_8 },
    5293                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PXI8430_23216,
    5294                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5295                 :            :                 pbn_ni8430_16 },
    5296                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PCI8430_23216,
    5297                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5298                 :            :                 pbn_ni8430_16 },
    5299                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PXI8432_2322,
    5300                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5301                 :            :                 pbn_ni8430_2 },
    5302                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PCI8432_2322,
    5303                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5304                 :            :                 pbn_ni8430_2 },
    5305                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PXI8432_2324,
    5306                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5307                 :            :                 pbn_ni8430_4 },
    5308                 :            :         {       PCI_VENDOR_ID_NI, PCI_DEVICE_ID_NI_PCI8432_2324,
    5309                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5310                 :            :                 pbn_ni8430_4 },
    5311                 :            : 
    5312                 :            :         /*
    5313                 :            :          * MOXA
    5314                 :            :          */
    5315                 :            :         {       PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_MOXA_CP102E,
    5316                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5317                 :            :                 pbn_moxa8250_2p },
    5318                 :            :         {       PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_MOXA_CP102EL,
    5319                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5320                 :            :                 pbn_moxa8250_2p },
    5321                 :            :         {       PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_MOXA_CP104EL_A,
    5322                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5323                 :            :                 pbn_moxa8250_4p },
    5324                 :            :         {       PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_MOXA_CP114EL,
    5325                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5326                 :            :                 pbn_moxa8250_4p },
    5327                 :            :         {       PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_MOXA_CP116E_A_A,
    5328                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5329                 :            :                 pbn_moxa8250_8p },
    5330                 :            :         {       PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_MOXA_CP116E_A_B,
    5331                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5332                 :            :                 pbn_moxa8250_8p },
    5333                 :            :         {       PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_MOXA_CP118EL_A,
    5334                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5335                 :            :                 pbn_moxa8250_8p },
    5336                 :            :         {       PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_MOXA_CP118E_A_I,
    5337                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5338                 :            :                 pbn_moxa8250_8p },
    5339                 :            :         {       PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_MOXA_CP132EL,
    5340                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5341                 :            :                 pbn_moxa8250_2p },
    5342                 :            :         {       PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_MOXA_CP134EL_A,
    5343                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5344                 :            :                 pbn_moxa8250_4p },
    5345                 :            :         {       PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_MOXA_CP138E_A,
    5346                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5347                 :            :                 pbn_moxa8250_8p },
    5348                 :            :         {       PCI_VENDOR_ID_MOXA, PCI_DEVICE_ID_MOXA_CP168EL_A,
    5349                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5350                 :            :                 pbn_moxa8250_8p },
    5351                 :            : 
    5352                 :            :         /*
    5353                 :            :         * ADDI-DATA GmbH communication cards <info@addi-data.com>
    5354                 :            :         */
    5355                 :            :         {       PCI_VENDOR_ID_ADDIDATA,
    5356                 :            :                 PCI_DEVICE_ID_ADDIDATA_APCI7500,
    5357                 :            :                 PCI_ANY_ID,
    5358                 :            :                 PCI_ANY_ID,
    5359                 :            :                 0,
    5360                 :            :                 0,
    5361                 :            :                 pbn_b0_4_115200 },
    5362                 :            : 
    5363                 :            :         {       PCI_VENDOR_ID_ADDIDATA,
    5364                 :            :                 PCI_DEVICE_ID_ADDIDATA_APCI7420,
    5365                 :            :                 PCI_ANY_ID,
    5366                 :            :                 PCI_ANY_ID,
    5367                 :            :                 0,
    5368                 :            :                 0,
    5369                 :            :                 pbn_b0_2_115200 },
    5370                 :            : 
    5371                 :            :         {       PCI_VENDOR_ID_ADDIDATA,
    5372                 :            :                 PCI_DEVICE_ID_ADDIDATA_APCI7300,
    5373                 :            :                 PCI_ANY_ID,
    5374                 :            :                 PCI_ANY_ID,
    5375                 :            :                 0,
    5376                 :            :                 0,
    5377                 :            :                 pbn_b0_1_115200 },
    5378                 :            : 
    5379                 :            :         {       PCI_VENDOR_ID_AMCC,
    5380                 :            :                 PCI_DEVICE_ID_AMCC_ADDIDATA_APCI7800,
    5381                 :            :                 PCI_ANY_ID,
    5382                 :            :                 PCI_ANY_ID,
    5383                 :            :                 0,
    5384                 :            :                 0,
    5385                 :            :                 pbn_b1_8_115200 },
    5386                 :            : 
    5387                 :            :         {       PCI_VENDOR_ID_ADDIDATA,
    5388                 :            :                 PCI_DEVICE_ID_ADDIDATA_APCI7500_2,
    5389                 :            :                 PCI_ANY_ID,
    5390                 :            :                 PCI_ANY_ID,
    5391                 :            :                 0,
    5392                 :            :                 0,
    5393                 :            :                 pbn_b0_4_115200 },
    5394                 :            : 
    5395                 :            :         {       PCI_VENDOR_ID_ADDIDATA,
    5396                 :            :                 PCI_DEVICE_ID_ADDIDATA_APCI7420_2,
    5397                 :            :                 PCI_ANY_ID,
    5398                 :            :                 PCI_ANY_ID,
    5399                 :            :                 0,
    5400                 :            :                 0,
    5401                 :            :                 pbn_b0_2_115200 },
    5402                 :            : 
    5403                 :            :         {       PCI_VENDOR_ID_ADDIDATA,
    5404                 :            :                 PCI_DEVICE_ID_ADDIDATA_APCI7300_2,
    5405                 :            :                 PCI_ANY_ID,
    5406                 :            :                 PCI_ANY_ID,
    5407                 :            :                 0,
    5408                 :            :                 0,
    5409                 :            :                 pbn_b0_1_115200 },
    5410                 :            : 
    5411                 :            :         {       PCI_VENDOR_ID_ADDIDATA,
    5412                 :            :                 PCI_DEVICE_ID_ADDIDATA_APCI7500_3,
    5413                 :            :                 PCI_ANY_ID,
    5414                 :            :                 PCI_ANY_ID,
    5415                 :            :                 0,
    5416                 :            :                 0,
    5417                 :            :                 pbn_b0_4_115200 },
    5418                 :            : 
    5419                 :            :         {       PCI_VENDOR_ID_ADDIDATA,
    5420                 :            :                 PCI_DEVICE_ID_ADDIDATA_APCI7420_3,
    5421                 :            :                 PCI_ANY_ID,
    5422                 :            :                 PCI_ANY_ID,
    5423                 :            :                 0,
    5424                 :            :                 0,
    5425                 :            :                 pbn_b0_2_115200 },
    5426                 :            : 
    5427                 :            :         {       PCI_VENDOR_ID_ADDIDATA,
    5428                 :            :                 PCI_DEVICE_ID_ADDIDATA_APCI7300_3,
    5429                 :            :                 PCI_ANY_ID,
    5430                 :            :                 PCI_ANY_ID,
    5431                 :            :                 0,
    5432                 :            :                 0,
    5433                 :            :                 pbn_b0_1_115200 },
    5434                 :            : 
    5435                 :            :         {       PCI_VENDOR_ID_ADDIDATA,
    5436                 :            :                 PCI_DEVICE_ID_ADDIDATA_APCI7800_3,
    5437                 :            :                 PCI_ANY_ID,
    5438                 :            :                 PCI_ANY_ID,
    5439                 :            :                 0,
    5440                 :            :                 0,
    5441                 :            :                 pbn_b0_8_115200 },
    5442                 :            : 
    5443                 :            :         {       PCI_VENDOR_ID_ADDIDATA,
    5444                 :            :                 PCI_DEVICE_ID_ADDIDATA_APCIe7500,
    5445                 :            :                 PCI_ANY_ID,
    5446                 :            :                 PCI_ANY_ID,
    5447                 :            :                 0,
    5448                 :            :                 0,
    5449                 :            :                 pbn_ADDIDATA_PCIe_4_3906250 },
    5450                 :            : 
    5451                 :            :         {       PCI_VENDOR_ID_ADDIDATA,
    5452                 :            :                 PCI_DEVICE_ID_ADDIDATA_APCIe7420,
    5453                 :            :                 PCI_ANY_ID,
    5454                 :            :                 PCI_ANY_ID,
    5455                 :            :                 0,
    5456                 :            :                 0,
    5457                 :            :                 pbn_ADDIDATA_PCIe_2_3906250 },
    5458                 :            : 
    5459                 :            :         {       PCI_VENDOR_ID_ADDIDATA,
    5460                 :            :                 PCI_DEVICE_ID_ADDIDATA_APCIe7300,
    5461                 :            :                 PCI_ANY_ID,
    5462                 :            :                 PCI_ANY_ID,
    5463                 :            :                 0,
    5464                 :            :                 0,
    5465                 :            :                 pbn_ADDIDATA_PCIe_1_3906250 },
    5466                 :            : 
    5467                 :            :         {       PCI_VENDOR_ID_ADDIDATA,
    5468                 :            :                 PCI_DEVICE_ID_ADDIDATA_APCIe7800,
    5469                 :            :                 PCI_ANY_ID,
    5470                 :            :                 PCI_ANY_ID,
    5471                 :            :                 0,
    5472                 :            :                 0,
    5473                 :            :                 pbn_ADDIDATA_PCIe_8_3906250 },
    5474                 :            : 
    5475                 :            :         {       PCI_VENDOR_ID_NETMOS, PCI_DEVICE_ID_NETMOS_9835,
    5476                 :            :                 PCI_VENDOR_ID_IBM, 0x0299,
    5477                 :            :                 0, 0, pbn_b0_bt_2_115200 },
    5478                 :            : 
    5479                 :            :         /*
    5480                 :            :          * other NetMos 9835 devices are most likely handled by the
    5481                 :            :          * parport_serial driver, check drivers/parport/parport_serial.c
    5482                 :            :          * before adding them here.
    5483                 :            :          */
    5484                 :            : 
    5485                 :            :         {       PCI_VENDOR_ID_NETMOS, PCI_DEVICE_ID_NETMOS_9901,
    5486                 :            :                 0xA000, 0x1000,
    5487                 :            :                 0, 0, pbn_b0_1_115200 },
    5488                 :            : 
    5489                 :            :         /* the 9901 is a rebranded 9912 */
    5490                 :            :         {       PCI_VENDOR_ID_NETMOS, PCI_DEVICE_ID_NETMOS_9912,
    5491                 :            :                 0xA000, 0x1000,
    5492                 :            :                 0, 0, pbn_b0_1_115200 },
    5493                 :            : 
    5494                 :            :         {       PCI_VENDOR_ID_NETMOS, PCI_DEVICE_ID_NETMOS_9922,
    5495                 :            :                 0xA000, 0x1000,
    5496                 :            :                 0, 0, pbn_b0_1_115200 },
    5497                 :            : 
    5498                 :            :         {       PCI_VENDOR_ID_NETMOS, PCI_DEVICE_ID_NETMOS_9904,
    5499                 :            :                 0xA000, 0x1000,
    5500                 :            :                 0, 0, pbn_b0_1_115200 },
    5501                 :            : 
    5502                 :            :         {       PCI_VENDOR_ID_NETMOS, PCI_DEVICE_ID_NETMOS_9900,
    5503                 :            :                 0xA000, 0x1000,
    5504                 :            :                 0, 0, pbn_b0_1_115200 },
    5505                 :            : 
    5506                 :            :         {       PCI_VENDOR_ID_NETMOS, PCI_DEVICE_ID_NETMOS_9900,
    5507                 :            :                 0xA000, 0x3002,
    5508                 :            :                 0, 0, pbn_NETMOS9900_2s_115200 },
    5509                 :            : 
    5510                 :            :         /*
    5511                 :            :          * Best Connectivity and Rosewill PCI Multi I/O cards
    5512                 :            :          */
    5513                 :            : 
    5514                 :            :         {       PCI_VENDOR_ID_NETMOS, PCI_DEVICE_ID_NETMOS_9865,
    5515                 :            :                 0xA000, 0x1000,
    5516                 :            :                 0, 0, pbn_b0_1_115200 },
    5517                 :            : 
    5518                 :            :         {       PCI_VENDOR_ID_NETMOS, PCI_DEVICE_ID_NETMOS_9865,
    5519                 :            :                 0xA000, 0x3002,
    5520                 :            :                 0, 0, pbn_b0_bt_2_115200 },
    5521                 :            : 
    5522                 :            :         {       PCI_VENDOR_ID_NETMOS, PCI_DEVICE_ID_NETMOS_9865,
    5523                 :            :                 0xA000, 0x3004,
    5524                 :            :                 0, 0, pbn_b0_bt_4_115200 },
    5525                 :            :         /* Intel CE4100 */
    5526                 :            :         {       PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_CE4100_UART,
    5527                 :            :                 PCI_ANY_ID,  PCI_ANY_ID, 0, 0,
    5528                 :            :                 pbn_ce4100_1_115200 },
    5529                 :            : 
    5530                 :            :         /*
    5531                 :            :          * Cronyx Omega PCI
    5532                 :            :          */
    5533                 :            :         {       PCI_VENDOR_ID_PLX, PCI_DEVICE_ID_PLX_CRONYX_OMEGA,
    5534                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5535                 :            :                 pbn_omegapci },
    5536                 :            : 
    5537                 :            :         /*
    5538                 :            :          * Broadcom TruManage
    5539                 :            :          */
    5540                 :            :         {       PCI_VENDOR_ID_BROADCOM, PCI_DEVICE_ID_BROADCOM_TRUMANAGE,
    5541                 :            :                 PCI_ANY_ID, PCI_ANY_ID, 0, 0,
    5542                 :            :                 pbn_brcm_trumanage },
    5543                 :            : 
    5544                 :            :         /*
    5545                 :            :          * AgeStar as-prs2-009
    5546                 :            :          */
    5547                 :            :         {       PCI_VENDOR_ID_AGESTAR, PCI_DEVICE_ID_AGESTAR_9375,
    5548                 :            :                 PCI_ANY_ID, PCI_ANY_ID,
    5549                 :            :                 0, 0, pbn_b0_bt_2_115200 },
    5550                 :            : 
    5551                 :            :         /*
    5552                 :            :          * WCH CH353 series devices: The 2S1P is handled by parport_serial
    5553                 :            :          * so not listed here.
    5554                 :            :          */
    5555                 :            :         {       PCI_VENDOR_ID_WCH, PCI_DEVICE_ID_WCH_CH353_4S,
    5556                 :            :                 PCI_ANY_ID, PCI_ANY_ID,
    5557                 :            :                 0, 0, pbn_b0_bt_4_115200 },
    5558                 :            : 
    5559                 :            :         {       PCI_VENDOR_ID_WCH, PCI_DEVICE_ID_WCH_CH353_2S1PF,
    5560                 :            :                 PCI_ANY_ID, PCI_ANY_ID,
    5561                 :            :                 0, 0, pbn_b0_bt_2_115200 },
    5562                 :            : 
    5563                 :            :         {       PCI_VENDOR_ID_WCH, PCI_DEVICE_ID_WCH_CH355_4S,
    5564                 :            :                 PCI_ANY_ID, PCI_ANY_ID,
    5565                 :            :                 0, 0, pbn_b0_bt_4_115200 },
    5566                 :            : 
    5567                 :            :         {       PCIE_VENDOR_ID_WCH, PCIE_DEVICE_ID_WCH_CH382_2S,
    5568                 :            :                 PCI_ANY_ID, PCI_ANY_ID,
    5569                 :            :                 0, 0, pbn_wch382_2 },
    5570                 :            : 
    5571                 :            :         {       PCIE_VENDOR_ID_WCH, PCIE_DEVICE_ID_WCH_CH384_4S,
    5572                 :            :                 PCI_ANY_ID, PCI_ANY_ID,
    5573                 :            :                 0, 0, pbn_wch384_4 },
    5574                 :            : 
    5575                 :            :         /* Fintek PCI serial cards */
    5576                 :            :         { PCI_DEVICE(0x1c29, 0x1104), .driver_data = pbn_fintek_4 },
    5577                 :            :         { PCI_DEVICE(0x1c29, 0x1108), .driver_data = pbn_fintek_8 },
    5578                 :            :         { PCI_DEVICE(0x1c29, 0x1112), .driver_data = pbn_fintek_12 },
    5579                 :            :         { PCI_DEVICE(0x1c29, 0x1204), .driver_data = pbn_fintek_F81504A },
    5580                 :            :         { PCI_DEVICE(0x1c29, 0x1208), .driver_data = pbn_fintek_F81508A },
    5581                 :            :         { PCI_DEVICE(0x1c29, 0x1212), .driver_data = pbn_fintek_F81512A },
    5582                 :            : 
    5583                 :            :         /* MKS Tenta SCOM-080x serial cards */
    5584                 :            :         { PCI_DEVICE(0x1601, 0x0800), .driver_data = pbn_b0_4_1250000 },
    5585                 :            :         { PCI_DEVICE(0x1601, 0xa801), .driver_data = pbn_b0_4_1250000 },
    5586                 :            : 
    5587                 :            :         /* Amazon PCI serial device */
    5588                 :            :         { PCI_DEVICE(0x1d0f, 0x8250), .driver_data = pbn_b0_1_115200 },
    5589                 :            : 
    5590                 :            :         /*
    5591                 :            :          * These entries match devices with class COMMUNICATION_SERIAL,
    5592                 :            :          * COMMUNICATION_MODEM or COMMUNICATION_MULTISERIAL
    5593                 :            :          */
    5594                 :            :         {       PCI_ANY_ID, PCI_ANY_ID,
    5595                 :            :                 PCI_ANY_ID, PCI_ANY_ID,
    5596                 :            :                 PCI_CLASS_COMMUNICATION_SERIAL << 8,
    5597                 :            :                 0xffff00, pbn_default },
    5598                 :            :         {       PCI_ANY_ID, PCI_ANY_ID,
    5599                 :            :                 PCI_ANY_ID, PCI_ANY_ID,
    5600                 :            :                 PCI_CLASS_COMMUNICATION_MODEM << 8,
    5601                 :            :                 0xffff00, pbn_default },
    5602                 :            :         {       PCI_ANY_ID, PCI_ANY_ID,
    5603                 :            :                 PCI_ANY_ID, PCI_ANY_ID,
    5604                 :            :                 PCI_CLASS_COMMUNICATION_MULTISERIAL << 8,
    5605                 :            :                 0xffff00, pbn_default },
    5606                 :            :         { 0, }
    5607                 :            : };
    5608                 :            : 
    5609                 :          0 : static pci_ers_result_t serial8250_io_error_detected(struct pci_dev *dev,
    5610                 :            :                                                 pci_channel_state_t state)
    5611                 :            : {
    5612         [ #  # ]:          0 :         struct serial_private *priv = pci_get_drvdata(dev);
    5613                 :            : 
    5614         [ #  # ]:          0 :         if (state == pci_channel_io_perm_failure)
    5615                 :            :                 return PCI_ERS_RESULT_DISCONNECT;
    5616                 :            : 
    5617         [ #  # ]:          0 :         if (priv)
    5618                 :          0 :                 pciserial_detach_ports(priv);
    5619                 :            : 
    5620                 :          0 :         pci_disable_device(dev);
    5621                 :            : 
    5622                 :          0 :         return PCI_ERS_RESULT_NEED_RESET;
    5623                 :            : }
    5624                 :            : 
    5625                 :          0 : static pci_ers_result_t serial8250_io_slot_reset(struct pci_dev *dev)
    5626                 :            : {
    5627                 :          0 :         int rc;
    5628                 :            : 
    5629                 :          0 :         rc = pci_enable_device(dev);
    5630                 :            : 
    5631         [ #  # ]:          0 :         if (rc)
    5632                 :            :                 return PCI_ERS_RESULT_DISCONNECT;
    5633                 :            : 
    5634                 :          0 :         pci_restore_state(dev);
    5635                 :          0 :         pci_save_state(dev);
    5636                 :            : 
    5637                 :          0 :         return PCI_ERS_RESULT_RECOVERED;
    5638                 :            : }
    5639                 :            : 
    5640                 :          0 : static void serial8250_io_resume(struct pci_dev *dev)
    5641                 :            : {
    5642         [ #  # ]:          0 :         struct serial_private *priv = pci_get_drvdata(dev);
    5643                 :          0 :         struct serial_private *new;
    5644                 :            : 
    5645         [ #  # ]:          0 :         if (!priv)
    5646                 :            :                 return;
    5647                 :            : 
    5648                 :          0 :         new = pciserial_init_ports(dev, priv->board);
    5649         [ #  # ]:          0 :         if (!IS_ERR(new)) {
    5650                 :          0 :                 pci_set_drvdata(dev, new);
    5651                 :          0 :                 kfree(priv);
    5652                 :            :         }
    5653                 :            : }
    5654                 :            : 
    5655                 :            : static const struct pci_error_handlers serial8250_err_handler = {
    5656                 :            :         .error_detected = serial8250_io_error_detected,
    5657                 :            :         .slot_reset = serial8250_io_slot_reset,
    5658                 :            :         .resume = serial8250_io_resume,
    5659                 :            : };
    5660                 :            : 
    5661                 :            : static struct pci_driver serial_pci_driver = {
    5662                 :            :         .name           = "serial",
    5663                 :            :         .probe          = pciserial_init_one,
    5664                 :            :         .remove         = pciserial_remove_one,
    5665                 :            :         .driver         = {
    5666                 :            :                 .pm     = &pciserial_pm_ops,
    5667                 :            :         },
    5668                 :            :         .id_table       = serial_pci_tbl,
    5669                 :            :         .err_handler    = &serial8250_err_handler,
    5670                 :            : };
    5671                 :            : 
    5672                 :         21 : module_pci_driver(serial_pci_driver);
    5673                 :            : 
    5674                 :            : MODULE_LICENSE("GPL");
    5675                 :            : MODULE_DESCRIPTION("Generic 8250/16x50 PCI serial probe module");
    5676                 :            : MODULE_DEVICE_TABLE(pci, serial_pci_tbl);

Generated by: LCOV version 1.14