1 #include <linux/module.h>
4 #include "../comedidev.h"
6 #include "amcc_s5933.h"
8 #include "addi-data/addi_common.h"
10 #define ADDIDATA_WATCHDOG 2 /* Or shold it be something else */
12 #include "addi-data/addi_eeprom.c"
13 #include "addi-data/hwdrv_apci035.c"
14 #include "addi-data/addi_common.c"
16 static const struct addi_board apci035_boardtypes[] = {
18 .pc_DriverName = "apci035",
19 .i_IorangeBase1 = APCI035_ADDRESS_RANGE,
21 .pc_EepromChip = ADDIDATA_S5920,
23 .i_NbrAiChannelDiff = 8,
24 .i_AiChannelList = 16,
26 .pr_AiRangelist = &range_apci035_ai,
28 .ui_MinAcquisitiontimeNs = 10000,
29 .ui_MinDelaytimeNs = 100000,
30 .interrupt = v_APCI035_Interrupt,
31 .reset = i_APCI035_Reset,
32 .ai_config = i_APCI035_ConfigAnalogInput,
33 .ai_read = i_APCI035_ReadAnalogInput,
34 .timer_config = i_APCI035_ConfigTimerWatchdog,
35 .timer_write = i_APCI035_StartStopWriteTimerWatchdog,
36 .timer_read = i_APCI035_ReadTimerWatchdog,
40 static int apci035_auto_attach(struct comedi_device *dev,
41 unsigned long context)
43 dev->board_ptr = &apci035_boardtypes[0];
45 return addi_auto_attach(dev, context);
48 static struct comedi_driver apci035_driver = {
49 .driver_name = "addi_apci_035",
50 .module = THIS_MODULE,
51 .auto_attach = apci035_auto_attach,
52 .detach = i_ADDI_Detach,
55 static int apci035_pci_probe(struct pci_dev *dev,
56 const struct pci_device_id *id)
58 return comedi_pci_auto_config(dev, &apci035_driver, id->driver_data);
61 static DEFINE_PCI_DEVICE_TABLE(apci035_pci_table) = {
62 { PCI_DEVICE(PCI_VENDOR_ID_ADDIDATA, 0x0300) },
65 MODULE_DEVICE_TABLE(pci, apci035_pci_table);
67 static struct pci_driver apci035_pci_driver = {
68 .name = "addi_apci_035",
69 .id_table = apci035_pci_table,
70 .probe = apci035_pci_probe,
71 .remove = comedi_pci_auto_unconfig,
73 module_comedi_pci_driver(apci035_driver, apci035_pci_driver);
75 MODULE_AUTHOR("Comedi http://www.comedi.org");
76 MODULE_DESCRIPTION("Comedi low-level driver");
77 MODULE_LICENSE("GPL");