]> rtime.felk.cvut.cz Git - lincan.git/blobdiff - lincan/include/constants.h
Added attach_to_chip() and release_chip() functions for each chip.
[lincan.git] / lincan / include / constants.h
index ce3d742fa625c9f03171f9e7736aa6e2ebceaec8..e838a9eee321e4f67b979cce718621dc3168f2e9 100644 (file)
@@ -35,7 +35,7 @@
 #define MAX_TOT_CHIPS (MAX_HW_CHIPS*MAX_HW_CARDS)
 #define MAX_TOT_CHIPS_STR 32   /* must be explicit for MODULE_PARM */
 #define MAX_IRQ 32
-#define MAX_MSGOBJS 15
+#define MAX_MSGOBJS 32
 #define MAX_TOT_MSGOBJS (MAX_TOT_CHIPS*MAX_MSGOBJS)
 #define MAX_BUF_LENGTH 64
 //#define MAX_BUF_LENGTH 4
 
 
 /* These flags can be used for the canchip_t structure flags data entry */
-#define CHIP_CONFIGURED  (1<<0)
-#define CHIP_SEGMENTED   (1<<1)
-#define CHIP_IRQ_SETUP   (1<<2)
-#define CHIP_IRQ_PCI     (1<<3)
-#define CHIP_IRQ_VME     (1<<4)
+#define CHIP_ATTACHED    (1<<0)  /* chip is attached to HW, release_chip() has to be called */
+#define CHIP_CONFIGURED  (1<<1)  /* chip is configured and prepared for communication */
+#define CHIP_SEGMENTED   (1<<2)  /* segmented access, ex: i82527 with 16 byte window*/
+#define CHIP_IRQ_SETUP   (1<<3)  /* IRQ handler has been set */
+#define CHIP_IRQ_PCI     (1<<4)  /* chip is on PCI board and uses PCI interrupt  */
+#define CHIP_IRQ_VME     (1<<5)  /* interrupt is VME bus and requires VME bridge */
+#define CHIP_IRQ_CUSTOM  (1<<6)  /* custom interrupt provided by board or chip code */
+#define CHIP_IRQ_FAST    (1<<7)  /* interrupt handler only schedules postponed processing */
+
+#define CHIP_MAX_IRQLOOP 1000
 
 /* System independent defines of IRQ handled state */
-#define CANCHIP_IRQ_NONE    0
-#define CANCHIP_IRQ_HANDLED 1
+#define CANCHIP_IRQ_NONE     0
+#define CANCHIP_IRQ_HANDLED  1
+#define CANCHIP_IRQ_ACCEPTED 2
+#define CANCHIP_IRQ_STUCK    3
 
 /* These flags can be used for the candevices_t structure flags data entry */
 #define CANDEV_PROGRAMMABLE_IRQ (1<<0)