staging: comedi: 8255_pci: fix for newer PCI-DIO48H
At some point, Measurement Computing / ComputerBoards redesigned the PCI-DIO48H to use a PLX PCI interface chip instead of an AMCC chip. This meant they had to put their hardware registers in the PCI BAR 2 region instead of PCI BAR 1. Unfortunately, they kept the same PCI device ID for the new design. This means the driver recognizes the newer cards, but doesn't work (and is likely to screw up the local configuration registers of the PLX chip) because it's using the wrong region. Since the PCI subvendor and subdevice IDs were both zero on the old design, but are the same as the vendor and device on the new design, we can tell the old design and new design apart easily enough. Split the existing entry for the PCI-DIO48H in `pci_8255_boards[]` into two new entries, referenced by different entries in the PCI device ID table `pci_8255_pci_table[]`. Use the same board name for both entries. Signed-off-by: Ian Abbott <abbotti@mev.co.uk> Cc: stablle <stable@vger.kernel.org> # 3.10.y # 3.11.y # 3.12.y # 3.13.y Acked-by: H Hartley Sweeten <hsweeten@visionengravers.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
27dc779835
commit
0283f7a100
1 changed files with 12 additions and 3 deletions
|
@ -63,7 +63,8 @@ enum pci_8255_boardid {
|
|||
BOARD_ADLINK_PCI7296,
|
||||
BOARD_CB_PCIDIO24,
|
||||
BOARD_CB_PCIDIO24H,
|
||||
BOARD_CB_PCIDIO48H,
|
||||
BOARD_CB_PCIDIO48H_OLD,
|
||||
BOARD_CB_PCIDIO48H_NEW,
|
||||
BOARD_CB_PCIDIO96H,
|
||||
BOARD_NI_PCIDIO96,
|
||||
BOARD_NI_PCIDIO96B,
|
||||
|
@ -106,11 +107,16 @@ static const struct pci_8255_boardinfo pci_8255_boards[] = {
|
|||
.dio_badr = 2,
|
||||
.n_8255 = 1,
|
||||
},
|
||||
[BOARD_CB_PCIDIO48H] = {
|
||||
[BOARD_CB_PCIDIO48H_OLD] = {
|
||||
.name = "cb_pci-dio48h",
|
||||
.dio_badr = 1,
|
||||
.n_8255 = 2,
|
||||
},
|
||||
[BOARD_CB_PCIDIO48H_NEW] = {
|
||||
.name = "cb_pci-dio48h",
|
||||
.dio_badr = 2,
|
||||
.n_8255 = 2,
|
||||
},
|
||||
[BOARD_CB_PCIDIO96H] = {
|
||||
.name = "cb_pci-dio96h",
|
||||
.dio_badr = 2,
|
||||
|
@ -263,7 +269,10 @@ static DEFINE_PCI_DEVICE_TABLE(pci_8255_pci_table) = {
|
|||
{ PCI_VDEVICE(ADLINK, 0x7296), BOARD_ADLINK_PCI7296 },
|
||||
{ PCI_VDEVICE(CB, 0x0028), BOARD_CB_PCIDIO24 },
|
||||
{ PCI_VDEVICE(CB, 0x0014), BOARD_CB_PCIDIO24H },
|
||||
{ PCI_VDEVICE(CB, 0x000b), BOARD_CB_PCIDIO48H },
|
||||
{ PCI_DEVICE_SUB(PCI_VENDOR_ID_CB, 0x000b, 0x0000, 0x0000),
|
||||
.driver_data = BOARD_CB_PCIDIO48H_OLD },
|
||||
{ PCI_DEVICE_SUB(PCI_VENDOR_ID_CB, 0x000b, PCI_VENDOR_ID_CB, 0x000b),
|
||||
.driver_data = BOARD_CB_PCIDIO48H_NEW },
|
||||
{ PCI_VDEVICE(CB, 0x0017), BOARD_CB_PCIDIO96H },
|
||||
{ PCI_VDEVICE(NI, 0x0160), BOARD_NI_PCIDIO96 },
|
||||
{ PCI_VDEVICE(NI, 0x1630), BOARD_NI_PCIDIO96B },
|
||||
|
|
Loading…
Reference in a new issue