1 #include <linux/module.h>
4 #include "../comedidev.h"
6 #include "amcc_s5933.h"
8 #include "addi-data/addi_common.h"
10 #include "addi-data/addi_eeprom.c"
11 #include "addi-data/hwdrv_apci1564.c"
12 #include "addi-data/addi_common.c"
14 static const struct addi_board apci1564_boardtypes[] = {
16 .pc_DriverName = "apci1564",
17 .i_IorangeBase1 = APCI1564_ADDRESS_RANGE,
18 .i_PCIEeprom = ADDIDATA_EEPROM,
19 .pc_EepromChip = ADDIDATA_93C76,
22 .i_DoMaxdata = 0xffffffff,
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,
37 static int apci1564_auto_attach(struct comedi_device *dev,
38 unsigned long context)
40 dev->board_ptr = &apci1564_boardtypes[0];
42 return addi_auto_attach(dev, context);
45 static struct comedi_driver apci1564_driver = {
46 .driver_name = "addi_apci_1564",
47 .module = THIS_MODULE,
48 .auto_attach = apci1564_auto_attach,
49 .detach = i_ADDI_Detach,
52 static int apci1564_pci_probe(struct pci_dev *dev,
53 const struct pci_device_id *id)
55 return comedi_pci_auto_config(dev, &apci1564_driver, id->driver_data);
58 static DEFINE_PCI_DEVICE_TABLE(apci1564_pci_table) = {
59 { PCI_DEVICE(PCI_VENDOR_ID_ADDIDATA, 0x1006) },
62 MODULE_DEVICE_TABLE(pci, apci1564_pci_table);
64 static struct pci_driver apci1564_pci_driver = {
65 .name = "addi_apci_1564",
66 .id_table = apci1564_pci_table,
67 .probe = apci1564_pci_probe,
68 .remove = comedi_pci_auto_unconfig,
70 module_comedi_pci_driver(apci1564_driver, apci1564_pci_driver);
72 MODULE_AUTHOR("Comedi http://www.comedi.org");
73 MODULE_DESCRIPTION("Comedi low-level driver");
74 MODULE_LICENSE("GPL");