]> rtime.felk.cvut.cz Git - lincan.git/blobdiff - lincan/src/can_devrtl.c
Correction for RTL build
[lincan.git] / lincan / src / can_devrtl.c
index 37bbbf1c023fb54f4769669d04c97f9422475005..25b8b482f8a9d7a0b57d7319835e512fb7b0a577 100644 (file)
@@ -3,7 +3,7 @@
  * New CAN queues by Pavel Pisa - OCERA team member
  * email:pisa@cmp.felk.cvut.cz
  * This software is released under the GPL-License.
- * Version lincan-0.2  9 Jul 2003
+ * Version lincan-0.3  17 Jun 2004
  */
 
 #ifdef CAN_WITH_RTL
@@ -102,7 +102,7 @@ void * can_chip_worker_thread(void *arg)
                        DEBUGMSG("IRQ_REQUEST processing ...\n");
                        loop_cnt = 100;
                        if(chip->chipspecops->irq_handler) do{
-                               ret=chip->chipspecops->irq_handler(chip->chip_irq,chip,NULL);
+                               ret=chip->chipspecops->irq_handler(chip->chip_irq,chip);
                        }while(ret && --loop_cnt);
                        continue;
                }
@@ -111,10 +111,15 @@ void * can_chip_worker_thread(void *arg)
                        for(i=0;i<chip->max_objects;i++){
                                if((obj=chip->msgobj[i])==NULL)
                                        continue;
-                               if(!can_msgobj_test_and_clear_fl(obj,TX_REQUEST))
-                                       continue;
-                               DEBUGMSG("Calling wakeup_tx\n");
-                               chip->chipspecops->wakeup_tx(chip, obj);
+                               if(can_msgobj_test_fl(obj,TX_REQUEST)) {
+                                       DEBUGMSG("Calling wakeup_tx\n");
+                                       chip->chipspecops->wakeup_tx(chip, obj);
+                               }
+                               if(can_msgobj_test_fl(obj,FILTCH_REQUEST)) {
+                                       DEBUGMSG("Calling filtch_rq\n");
+                                       if(chip->chipspecops->filtch_rq)
+                                               chip->chipspecops->filtch_rq(chip, obj);
+                               }
                        }
                        continue;
                }