Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/sage/ceph...
[GitHub/mt8127/android_kernel_alcatel_ttab.git] / drivers / staging / serqt_usb2 / serqt_usb2.c
index 8a362f7af379b4a2cfc6935f50d5a0a5db082fe3..099bc69ca00c2d3bea1c9c9d7c2e56cd66a56f88 100644 (file)
@@ -16,8 +16,6 @@
 #include <linux/usb/serial.h>
 #include <linux/uaccess.h>
 
-static bool debug;
-
 /* Version Information */
 #define DRIVER_VERSION "v2.14"
 #define DRIVER_AUTHOR "Tim Gobeli, Quatech, Inc"
@@ -184,11 +182,11 @@ static int port_paranoia_check(struct usb_serial_port *port,
                               const char *function)
 {
        if (!port) {
-               dbg("%s - port == NULL", function);
+               pr_debug("%s - port == NULL", function);
                return -1;
        }
        if (!port->serial) {
-               dbg("%s - port->serial == NULL\n", function);
+               pr_debug("%s - port->serial == NULL\n", function);
                return -1;
        }
 
@@ -199,12 +197,12 @@ static int serial_paranoia_check(struct usb_serial *serial,
                                 const char *function)
 {
        if (!serial) {
-               dbg("%s - serial == NULL\n", function);
+               pr_debug("%s - serial == NULL\n", function);
                return -1;
        }
 
        if (!serial->type) {
-               dbg("%s - serial->type == NULL!", function);
+               pr_debug("%s - serial->type == NULL!", function);
                return -1;
        }
 
@@ -247,7 +245,6 @@ static void ProcessLineStatus(struct quatech_port *qt_port,
        qt_port->shadowLSR =
            line_status & (SERIAL_LSR_OE | SERIAL_LSR_PE | SERIAL_LSR_FE |
                           SERIAL_LSR_BI);
-       return;
 }
 
 static void ProcessModemStatus(struct quatech_port *qt_port,
@@ -256,7 +253,6 @@ static void ProcessModemStatus(struct quatech_port *qt_port,
 
        qt_port->shadowMSR = modem_status;
        wake_up_interruptible(&qt_port->wait);
-       return;
 }
 
 static void ProcessRxChar(struct tty_struct *tty, struct usb_serial_port *port,
@@ -276,7 +272,7 @@ static void qt_write_bulk_callback(struct urb *urb)
        status = urb->status;
 
        if (status) {
-               dbg("nonzero write bulk status received:%d\n", status);
+               dev_dbg(&urb->dev->dev, "nonzero write bulk status received:%d\n", status);
                return;
        }
 
@@ -309,16 +305,14 @@ static void qt_read_bulk_callback(struct urb *urb)
 
        if (urb->status) {
                qt_port->ReadBulkStopped = 1;
-               dbg("%s - nonzero write bulk status received: %d\n",
-                   __func__, urb->status);
+               dev_dbg(&urb->dev->dev, "%s - nonzero write bulk status received: %d\n",
+                       __func__, urb->status);
                return;
        }
 
        tty = tty_port_tty_get(&port->port);
-       if (!tty) {
-               dbg("%s - bad tty pointer - exiting", __func__);
+       if (!tty)
                return;
-       }
 
        data = urb->transfer_buffer;
 
@@ -327,21 +321,19 @@ static void qt_read_bulk_callback(struct urb *urb)
        /* index = MINOR(port->tty->device) - serial->minor; */
        index = tty->index - serial->minor;
 
-       dbg("%s - port->RxHolding = %d\n", __func__, qt_port->RxHolding);
+       dev_dbg(&port->dev, "%s - port->RxHolding = %d\n", __func__, qt_port->RxHolding);
 
        if (port_paranoia_check(port, __func__) != 0) {
-               dbg("%s - port_paranoia_check, exiting\n", __func__);
                qt_port->ReadBulkStopped = 1;
                goto exit;
        }
 
-       if (!serial) {
-               dbg("%s - bad serial pointer, exiting\n", __func__);
+       if (!serial)
                goto exit;
-       }
+
        if (qt_port->closePending == 1) {
                /* Were closing , stop reading */
-               dbg("%s - (qt_port->closepending == 1\n", __func__);
+               dev_dbg(&port->dev, "%s - (qt_port->closepending == 1\n", __func__);
                qt_port->ReadBulkStopped = 1;
                goto exit;
        }
@@ -359,12 +351,12 @@ static void qt_read_bulk_callback(struct urb *urb)
        if (urb->status) {
                qt_port->ReadBulkStopped = 1;
 
-               dbg("%s - nonzero read bulk status received: %d\n",
-                   __func__, urb->status);
+               dev_dbg(&port->dev, "%s - nonzero read bulk status received: %d\n",
+                       __func__, urb->status);
                goto exit;
        }
 
-       if (tty && RxCount) {
+       if (RxCount) {
                flag_data = 0;
                for (i = 0; i < RxCount; ++i) {
                        /* Look ahead code here */
@@ -375,7 +367,7 @@ static void qt_read_bulk_callback(struct urb *urb)
                                case 0x00:
                                        /* line status change 4th byte must follow */
                                        if (i > (RxCount - 4)) {
-                                               dbg("Illegal escape seuences in received data\n");
+                                               dev_dbg(&port->dev, "Illegal escape seuences in received data\n");
                                                break;
                                        }
                                        ProcessLineStatus(qt_port, data[i + 3]);
@@ -385,9 +377,9 @@ static void qt_read_bulk_callback(struct urb *urb)
 
                                case 0x01:
                                        /* Modem status status change 4th byte must follow */
-                                       dbg("Modem status status.\n");
+                                       dev_dbg(&port->dev, "Modem status status.\n");
                                        if (i > (RxCount - 4)) {
-                                               dbg("Illegal escape sequences in received data\n");
+                                               dev_dbg(&port->dev, "Illegal escape sequences in received data\n");
                                                break;
                                        }
                                        ProcessModemStatus(qt_port,
@@ -396,7 +388,7 @@ static void qt_read_bulk_callback(struct urb *urb)
                                        flag = 1;
                                        break;
                                case 0xff:
-                                       dbg("No status sequence.\n");
+                                       dev_dbg(&port->dev, "No status sequence.\n");
 
                                        if (tty) {
                                                ProcessRxChar(tty, port, data[i]);
@@ -425,10 +417,10 @@ static void qt_read_bulk_callback(struct urb *urb)
                          qt_read_bulk_callback, port);
        result = usb_submit_urb(port->read_urb, GFP_ATOMIC);
        if (result)
-               dbg("%s - failed resubmitting read urb, error %d",
-                   __func__, result);
+               dev_dbg(&port->dev, "%s - failed resubmitting read urb, error %d",
+                       __func__, result);
        else {
-               if (tty && RxCount) {
+               if (RxCount) {
                        tty_flip_buffer_push(tty);
                        tty_schedule_flip(tty);
                }
@@ -521,7 +513,6 @@ static int qt_set_device(struct usb_serial *serial,
        PortSettings += ((__u16) (device_data->porta));
 
        length = sizeof(struct qt_get_device_data);
-       dbg("%s - PortSettings = 0x%x\n", __func__, PortSettings);
 
        result = usb_control_msg(serial->dev, usb_sndctrlpipe(serial->dev, 0),
                                 QT_SET_GET_DEVICE, 0x40, PortSettings,
@@ -695,6 +686,7 @@ static int BoxDisable_SW_FlowCtrl(struct usb_serial *serial, __u16 index)
 
 static int qt_startup(struct usb_serial *serial)
 {
+       struct device *dev = &serial->dev->dev;
        struct usb_serial_port *port;
        struct quatech_port *qt_port;
        struct qt_get_device_data DeviceData;
@@ -706,8 +698,6 @@ static int qt_startup(struct usb_serial *serial)
                port = serial->port[i];
                qt_port = kzalloc(sizeof(*qt_port), GFP_KERNEL);
                if (!qt_port) {
-                       dbg("%s: kmalloc for quatech_port (%d) failed!.",
-                           __func__, i);
                        for (--i; i >= 0; i--) {
                                port = serial->port[i];
                                kfree(usb_get_serial_port_data(port));
@@ -722,25 +712,23 @@ static int qt_startup(struct usb_serial *serial)
        }
 
        status = qt_get_device(serial, &DeviceData);
-       if (status < 0) {
-               dbg(__FILE__ "box_get_device failed");
+       if (status < 0)
                goto startup_error;
-       }
 
-       dbg(__FILE__ "DeviceData.portb = 0x%x", DeviceData.portb);
+       dev_dbg(dev, "DeviceData.portb = 0x%x\n", DeviceData.portb);
 
        DeviceData.portb &= ~FULLPWRBIT;
-       dbg(__FILE__ "Changing DeviceData.portb to 0x%x", DeviceData.portb);
+       dev_dbg(dev, "Changing DeviceData.portb to 0x%x\n", DeviceData.portb);
 
        status = qt_set_device(serial, &DeviceData);
        if (status < 0) {
-               dbg(__FILE__ "qt_set_device failed\n");
+               dev_dbg(dev, "qt_set_device failed\n");
                goto startup_error;
        }
 
        status = qt_get_device(serial, &DeviceData);
        if (status < 0) {
-               dbg(__FILE__ "qt_get_device failed");
+               dev_dbg(dev, "qt_get_device failed\n");
                goto startup_error;
        }
 
@@ -784,29 +772,27 @@ static int qt_startup(struct usb_serial *serial)
 
        status = BoxSetPrebufferLevel(serial);  /* sets to default value */
        if (status < 0) {
-               dbg(__FILE__ "BoxSetPrebufferLevel failed\n");
+               dev_dbg(dev, "BoxSetPrebufferLevel failed\n");
                goto startup_error;
        }
 
        status = BoxSetATC(serial, ATC_DISABLED);
        if (status < 0) {
-               dbg(__FILE__ "BoxSetATC failed\n");
+               dev_dbg(dev, "BoxSetATC failed\n");
                goto startup_error;
        }
 
-       dbg(__FILE__ "DeviceData.portb = 0x%x", DeviceData.portb);
+       dev_dbg(dev, "DeviceData.portb = 0x%x\n", DeviceData.portb);
 
        DeviceData.portb |= NEXT_BOARD_POWER_BIT;
-       dbg(__FILE__ "Changing DeviceData.portb to 0x%x", DeviceData.portb);
+       dev_dbg(dev, "Changing DeviceData.portb to 0x%x\n", DeviceData.portb);
 
        status = qt_set_device(serial, &DeviceData);
        if (status < 0) {
-               dbg(__FILE__ "qt_set_device failed\n");
+               dev_dbg(dev, "qt_set_device failed\n");
                goto startup_error;
        }
 
-       dbg("Exit Success %s\n", __func__);
-
        return 0;
 
 startup_error:
@@ -817,8 +803,6 @@ startup_error:
                usb_set_serial_port_data(port, NULL);
        }
 
-       dbg("Exit fail %s\n", __func__);
-
        return -EIO;
 }
 
@@ -873,10 +857,10 @@ static int qt_open(struct tty_struct *tty,
        /* Port specific setups */
        result = qt_open_channel(serial, port->number, &ChannelData);
        if (result < 0) {
-               dbg(__FILE__ "qt_open_channel failed\n");
+               dev_dbg(&port->dev, "qt_open_channel failed\n");
                return result;
        }
-       dbg(__FILE__ "qt_open_channel completed.\n");
+       dev_dbg(&port->dev, "qt_open_channel completed.\n");
 
 /* FIXME: are these needed?  Does it even do anything useful? */
        quatech_port->shadowLSR = ChannelData.line_status &
@@ -888,17 +872,15 @@ static int qt_open(struct tty_struct *tty,
        /* Set Baud rate to default and turn off (default)flow control here */
        result = qt_setuart(serial, port->number, DEFAULT_DIVISOR, DEFAULT_LCR);
        if (result < 0) {
-               dbg(__FILE__ "qt_setuart failed\n");
+               dev_dbg(&port->dev, "qt_setuart failed\n");
                return result;
        }
-       dbg(__FILE__ "qt_setuart completed.\n");
+       dev_dbg(&port->dev, "qt_setuart completed.\n");
 
        /*
         * Put this here to make it responsive to stty and defaults set by
         * the tty layer
         */
-       /* FIXME: is this needed? */
-       /* qt_set_termios(tty, port, NULL); */
 
        /*  Check to see if we've set up our endpoint info yet */
        if (port0->open_ports == 1) {
@@ -928,12 +910,12 @@ static int qt_open(struct tty_struct *tty,
 
        }
 
-       dbg("port number is %d\n", port->number);
-       dbg("serial number is %d\n", port->serial->minor);
-       dbg("Bulkin endpoint is %d\n", port->bulk_in_endpointAddress);
-       dbg("BulkOut endpoint is %d\n", port->bulk_out_endpointAddress);
-       dbg("Interrupt endpoint is %d\n", port->interrupt_in_endpointAddress);
-       dbg("port's number in the device is %d\n", quatech_port->port_num);
+       dev_dbg(&port->dev, "port number is %d\n", port->number);
+       dev_dbg(&port->dev, "serial number is %d\n", port->serial->minor);
+       dev_dbg(&port->dev, "Bulkin endpoint is %d\n", port->bulk_in_endpointAddress);
+       dev_dbg(&port->dev, "BulkOut endpoint is %d\n", port->bulk_out_endpointAddress);
+       dev_dbg(&port->dev, "Interrupt endpoint is %d\n", port->interrupt_in_endpointAddress);
+       dev_dbg(&port->dev, "port's number in the device is %d\n", quatech_port->port_num);
        quatech_port->read_urb = port->read_urb;
 
        /* set up our bulk in urb */
@@ -946,7 +928,7 @@ static int qt_open(struct tty_struct *tty,
                          quatech_port->read_urb->transfer_buffer_length,
                          qt_read_bulk_callback, quatech_port);
 
-       dbg("qt_open: bulkin endpoint is %d\n", port->bulk_in_endpointAddress);
+       dev_dbg(&port->dev, "qt_open: bulkin endpoint is %d\n", port->bulk_in_endpointAddress);
        quatech_port->read_urb_busy = true;
        result = usb_submit_urb(quatech_port->read_urb, GFP_KERNEL);
        if (result) {
@@ -980,8 +962,6 @@ static int qt_chars_in_buffer(struct tty_struct *tty)
                        chars = port->write_urb->transfer_buffer_length;
        }
 
-       dbg("%s - returns %d\n", __func__, chars);
-
        return chars;
 }
 
@@ -1003,7 +983,7 @@ static void qt_block_until_empty(struct tty_struct *tty,
 
                wait--;
                if (wait == 0) {
-                       dbg("%s - TIMEOUT", __func__);
+                       dev_dbg(&qt_port->port->dev, "%s - TIMEOUT", __func__);
                        return;
                } else {
                        wait = 30;
@@ -1041,17 +1021,15 @@ static void qt_close(struct usb_serial_port *port)
        /* Close uart channel */
        status = qt_close_channel(serial, index);
        if (status < 0)
-               dbg("%s - port %d qt_close_channel failed.\n",
-                   __func__, port->number);
+               dev_dbg(&port->dev, "%s - port %d qt_close_channel failed.\n", __func__, port->number);
 
        port0->open_ports--;
 
-       dbg("qt_num_open_ports in close%d:in port%d\n",
-           port0->open_ports, port->number);
+       dev_dbg(&port->dev, "qt_num_open_ports in close%d:in port%d\n", port0->open_ports, port->number);
 
        if (port0->open_ports == 0) {
                if (serial->port[0]->interrupt_in_urb) {
-                       dbg("%s", "Shutdown interrupt_in_urb\n");
+                       dev_dbg(&port->dev, "%s", "Shutdown interrupt_in_urb\n");
                        usb_kill_urb(serial->port[0]->interrupt_in_urb);
                }
 
@@ -1075,14 +1053,14 @@ static int qt_write(struct tty_struct *tty, struct usb_serial_port *port,
                return -ENODEV;
 
        if (count == 0) {
-               dbg("%s - write request of 0 bytes\n", __func__);
+               dev_dbg(&port->dev, "%s - write request of 0 bytes\n", __func__);
                return 0;
        }
 
        /* only do something if we have a bulk out endpoint */
        if (serial->num_bulk_out) {
                if (port->write_urb->status == -EINPROGRESS) {
-                       dbg("%s - already writing\n", __func__);
+                       dev_dbg(&port->dev, "%s - already writing\n", __func__);
                        return 0;
                }
 
@@ -1102,8 +1080,8 @@ static int qt_write(struct tty_struct *tty, struct usb_serial_port *port,
                /* send the data out the bulk port */
                result = usb_submit_urb(port->write_urb, GFP_ATOMIC);
                if (result)
-                       dbg("%s - failed submitting write urb, error %d\n",
-                           __func__, result);
+                       dev_dbg(&port->dev, "%s - failed submitting write urb, error %d\n",
+                               __func__, result);
                else
                        result = count;
 
@@ -1122,10 +1100,8 @@ static int qt_write_room(struct tty_struct *tty)
 
        int retval = -EINVAL;
 
-       if (port_paranoia_check(port, __func__)) {
-               dbg("%s", "Invalid port\n");
+       if (port_paranoia_check(port, __func__))
                return -1;
-       }
 
        serial = get_usb_serial(port, __func__);
 
@@ -1154,7 +1130,7 @@ static int qt_ioctl(struct tty_struct *tty,
        struct usb_serial *serial = get_usb_serial(port, __func__);
        unsigned int index;
 
-       dbg("%s cmd 0x%04x", __func__, cmd);
+       dev_dbg(&port->dev, "%s cmd 0x%04x\n", __func__, cmd);
 
        index = tty->index - serial->minor;
 
@@ -1187,7 +1163,7 @@ static int qt_ioctl(struct tty_struct *tty,
                return 0;
        }
 
-       dbg("%s -No ioctl for that one.  port = %d\n", __func__, port->number);
+       dev_dbg(&port->dev, "%s -No ioctl for that one.  port = %d\n", __func__, port->number);
        return -ENOIOCTLCMD;
 }
 
@@ -1195,7 +1171,7 @@ static void qt_set_termios(struct tty_struct *tty,
                           struct usb_serial_port *port,
                           struct ktermios *old_termios)
 {
-       struct ktermios *termios = tty->termios;
+       struct ktermios *termios = &tty->termios;
        unsigned char new_LCR = 0;
        unsigned int cflag = termios->c_cflag;
        unsigned int index;
@@ -1204,7 +1180,7 @@ static void qt_set_termios(struct tty_struct *tty,
 
        index = tty->index - port->serial->minor;
 
-       switch (cflag) {
+       switch (cflag & CSIZE) {
        case CS5:
                new_LCR |= SERIAL_5_DATA;
                break;
@@ -1215,6 +1191,8 @@ static void qt_set_termios(struct tty_struct *tty,
                new_LCR |= SERIAL_7_DATA;
                break;
        default:
+               termios->c_cflag &= ~CSIZE;
+               termios->c_cflag |= CS8;
        case CS8:
                new_LCR |= SERIAL_8_DATA;
                break;
@@ -1232,7 +1210,7 @@ static void qt_set_termios(struct tty_struct *tty,
        else
                new_LCR |= SERIAL_ONE_STOPB;
 
-       dbg("%s - 4\n", __func__);
+       dev_dbg(&port->dev, "%s - 4\n", __func__);
 
        /* Thats the LCR stuff, go ahead and set it */
        baud = tty_get_baud_rate(tty);
@@ -1240,7 +1218,7 @@ static void qt_set_termios(struct tty_struct *tty,
                /* pick a default, any default... */
                baud = 9600;
 
-       dbg("%s - got baud = %d\n", __func__, baud);
+       dev_dbg(&port->dev, "%s - got baud = %d\n", __func__, baud);
 
        divisor = MAX_BAUD_RATE / baud;
        remainder = MAX_BAUD_RATE % baud;
@@ -1254,30 +1232,28 @@ static void qt_set_termios(struct tty_struct *tty,
        status =
            qt_setuart(port->serial, index, (unsigned short)divisor, new_LCR);
        if (status < 0) {
-               dbg(__FILE__ "qt_setuart failed\n");
+               dev_dbg(&port->dev, "qt_setuart failed\n");
                return;
        }
 
        /* Now determine flow control */
        if (cflag & CRTSCTS) {
-               dbg("%s - Enabling HW flow control port %d\n", __func__,
-                   port->number);
+               dev_dbg(&port->dev, "%s - Enabling HW flow control port %d\n", __func__, port->number);
 
                /* Enable RTS/CTS flow control */
                status = BoxSetHW_FlowCtrl(port->serial, index, 1);
 
                if (status < 0) {
-                       dbg(__FILE__ "BoxSetHW_FlowCtrl failed\n");
+                       dev_dbg(&port->dev, "BoxSetHW_FlowCtrl failed\n");
                        return;
                }
        } else {
                /* Disable RTS/CTS flow control */
-               dbg("%s - disabling HW flow control port %d\n", __func__,
-                   port->number);
+               dev_dbg(&port->dev, "%s - disabling HW flow control port %d\n", __func__, port->number);
 
                status = BoxSetHW_FlowCtrl(port->serial, index, 0);
                if (status < 0) {
-                       dbg(__FILE__ "BoxSetHW_FlowCtrl failed\n");
+                       dev_dbg(&port->dev, "BoxSetHW_FlowCtrl failed\n");
                        return;
                }
 
@@ -1292,16 +1268,16 @@ static void qt_set_termios(struct tty_struct *tty,
                    BoxSetSW_FlowCtrl(port->serial, index, stop_char,
                                      start_char);
                if (status < 0)
-                       dbg(__FILE__ "BoxSetSW_FlowCtrl (enabled) failed\n");
+                       dev_dbg(&port->dev, "BoxSetSW_FlowCtrl (enabled) failed\n");
 
        } else {
                /* disable SW flow control */
                status = BoxDisable_SW_FlowCtrl(port->serial, index);
                if (status < 0)
-                       dbg(__FILE__ "BoxSetSW_FlowCtrl (diabling) failed\n");
+                       dev_dbg(&port->dev, "BoxSetSW_FlowCtrl (diabling) failed\n");
 
        }
-       tty->termios->c_cflag &= ~CMSPAR;
+       termios->c_cflag &= ~CMSPAR;
        /* FIXME: Error cases should be returning the actual bits changed only */
 }
 
@@ -1412,7 +1388,7 @@ static int qt_tiocmget(struct tty_struct *tty)
        struct usb_serial_port *port = tty->driver_data;
        struct usb_serial *serial = get_usb_serial(port, __func__);
        struct quatech_port *qt_port = qt_get_port_private(port);
-       int retval = -ENODEV;
+       int retval;
 
        if (!serial)
                return -ENODEV;
@@ -1430,7 +1406,7 @@ static int qt_tiocmset(struct tty_struct *tty,
        struct usb_serial_port *port = tty->driver_data;
        struct usb_serial *serial = get_usb_serial(port, __func__);
        struct quatech_port *qt_port = qt_get_port_private(port);
-       int retval = -ENODEV;
+       int retval;
 
        if (!serial)
                return -ENODEV;
@@ -1458,7 +1434,6 @@ static void qt_throttle(struct tty_struct *tty)
        qt_port->RxHolding = 1;
 
        mutex_unlock(&qt_port->lock);
-       return;
 }
 
 static void qt_unthrottle(struct tty_struct *tty)
@@ -1476,10 +1451,10 @@ static void qt_unthrottle(struct tty_struct *tty)
        mutex_lock(&qt_port->lock);
 
        if (qt_port->RxHolding == 1) {
-               dbg("%s -qt_port->RxHolding == 1\n", __func__);
+               dev_dbg(&port->dev, "%s -qt_port->RxHolding == 1\n", __func__);
 
                qt_port->RxHolding = 0;
-               dbg("%s - qt_port->RxHolding = 0\n", __func__);
+               dev_dbg(&port->dev, "%s - qt_port->RxHolding = 0\n", __func__);
 
                /* if we have a bulk endpoint, start it up */
                if ((serial->num_bulk_in) && (qt_port->ReadBulkStopped == 1)) {
@@ -1499,19 +1474,12 @@ static void qt_unthrottle(struct tty_struct *tty)
                }
        }
        mutex_unlock(&qt_port->lock);
-       return;
-
 }
 
 static int qt_calc_num_ports(struct usb_serial *serial)
 {
        int num_ports;
 
-       dbg("numberofendpoints: %d\n",
-           (int)serial->interface->cur_altsetting->desc.bNumEndpoints);
-       dbg("numberofendpoints: %d\n",
-           (int)serial->interface->altsetting->desc.bNumEndpoints);
-
        num_ports =
            (serial->interface->cur_altsetting->desc.bNumEndpoints - 1) / 2;
 
@@ -1552,6 +1520,3 @@ module_usb_serial_driver(serial_drivers, id_table);
 MODULE_AUTHOR(DRIVER_AUTHOR);
 MODULE_DESCRIPTION(DRIVER_DESC);
 MODULE_LICENSE("GPL");
-
-module_param(debug, bool, S_IRUGO | S_IWUSR);
-MODULE_PARM_DESC(debug, "Debug enabled or not");