3556c61551b9456794c5446753eb5cf05b1982cd
[firefly-linux-kernel-4.4.55.git] / drivers / staging / comedi / drivers / addi_apci_1564.c
1 #include "../comedidev.h"
2 #include "comedi_fc.h"
3 #include "amcc_s5933.h"
4
5 #include "addi-data/addi_common.h"
6
7 #include "addi-data/addi_eeprom.c"
8 #include "addi-data/hwdrv_apci1564.c"
9 #include "addi-data/addi_common.c"
10
11 static const struct addi_board apci1564_boardtypes[] = {
12         {
13                 .pc_DriverName          = "apci1564",
14                 .i_VendorId             = PCI_VENDOR_ID_ADDIDATA,
15                 .i_DeviceId             = 0x1006,
16                 .i_IorangeBase0         = 128,
17                 .i_IorangeBase1         = APCI1564_ADDRESS_RANGE,
18                 .i_PCIEeprom            = ADDIDATA_EEPROM,
19                 .pc_EepromChip          = ADDIDATA_93C76,
20                 .i_NbrDiChannel         = 32,
21                 .i_NbrDoChannel         = 32,
22                 .i_DoMaxdata            = 0xffffffff,
23                 .i_Timer                = 1,
24                 .interrupt              = v_APCI1564_Interrupt,
25                 .reset                  = i_APCI1564_Reset,
26                 .di_config              = i_APCI1564_ConfigDigitalInput,
27                 .di_bits                = apci1564_di_insn_bits,
28                 .do_config              = i_APCI1564_ConfigDigitalOutput,
29                 .do_bits                = apci1564_do_insn_bits,
30                 .do_read                = i_APCI1564_ReadInterruptStatus,
31                 .timer_config           = i_APCI1564_ConfigTimerCounterWatchdog,
32                 .timer_write            = i_APCI1564_StartStopWriteTimerCounterWatchdog,
33                 .timer_read             = i_APCI1564_ReadTimerCounterWatchdog,
34         },
35 };
36
37 static struct comedi_driver apci1564_driver = {
38         .driver_name    = "addi_apci_1564",
39         .module         = THIS_MODULE,
40         .auto_attach    = addi_auto_attach,
41         .detach         = i_ADDI_Detach,
42         .num_names      = ARRAY_SIZE(apci1564_boardtypes),
43         .board_name     = &apci1564_boardtypes[0].pc_DriverName,
44         .offset         = sizeof(struct addi_board),
45 };
46
47 static int apci1564_pci_probe(struct pci_dev *dev,
48                                         const struct pci_device_id *ent)
49 {
50         return comedi_pci_auto_config(dev, &apci1564_driver);
51 }
52
53 static DEFINE_PCI_DEVICE_TABLE(apci1564_pci_table) = {
54         { PCI_DEVICE(PCI_VENDOR_ID_ADDIDATA, 0x1006) },
55         { 0 }
56 };
57 MODULE_DEVICE_TABLE(pci, apci1564_pci_table);
58
59 static struct pci_driver apci1564_pci_driver = {
60         .name           = "addi_apci_1564",
61         .id_table       = apci1564_pci_table,
62         .probe          = apci1564_pci_probe,
63         .remove         = comedi_pci_auto_unconfig,
64 };
65 module_comedi_pci_driver(apci1564_driver, apci1564_pci_driver);
66
67 MODULE_AUTHOR("Comedi http://www.comedi.org");
68 MODULE_DESCRIPTION("Comedi low-level driver");
69 MODULE_LICENSE("GPL");