]> rtime.felk.cvut.cz Git - lincan.git/blobdiff - lincan/src/ioctl.c
Added support for local message processing and some cleanups.
[lincan.git] / lincan / src / ioctl.c
index 40a420494dc0572e3e557b8ffbf1c47e1f17abee..08b3aa0aa2646cfbf6fec0e9bf9664e7556bdfda 100644 (file)
@@ -63,6 +63,10 @@ int can_ioctl(struct inode *inode, struct file *file, unsigned int cmd, unsigned
                                return -1;
                        break;
                }
+               case CANQUE_FLUSH: {
+                       canque_flush(canuser->rx_edge0);
+                       break;
+               }
                case CONF_FILTER: {
                    #if 0
                        if (!strcmp(chip->chip_type,"i82527")) {
@@ -83,19 +87,17 @@ int can_ioctl(struct inode *inode, struct file *file, unsigned int cmd, unsigned
                        /* In- and output buffer re-initialization */
                        
                        if(canuser->rx_edge0){
-                               canque_set_filt(canuser->rx_edge0, arg, ~0);
-                               canque_flush(canuser->rx_edge0);
+                               canque_set_filt(canuser->rx_edge0, arg, ~0, 0);
                        }
 
                        break;
                }
                
-               case CONF_FILTER_QUE0: {
+               case CANQUE_FILTER: {
                        struct canfilt_t canfilt;
                        copy_from_user(&canfilt, (void*)arg, sizeof(struct canfilt_t));
                        if(canuser->rx_edge0){
-                               canque_set_filt(canuser->rx_edge0, canfilt.id, canfilt.mask);
-                               canque_flush(canuser->rx_edge0);
+                               canque_set_filt(canuser->rx_edge0, canfilt.id, canfilt.mask, canfilt.flags);
                        }
                        break;
                }