Linux Headquarters
[ Register ]
[ About us ] [ Home Page ]

Advertisement
[ Kernel ] [ Documentation ] [ Links ] [ Books ]

Advertisement

Kernel v2.6.22-git8 /drivers/usb/misc/berry_charge.c

Filename:/drivers/usb/misc/berry_charge.c
Lines Added:35
Lines Deleted:0
Also changed in: (Previous) 2.6.22-git7  2.6.22-git6  2.6.22-git5  2.6.22-git4  2.6.22-git3  2.6.21 
(Following) 2.6.22-git9  2.6.22-git10  2.6.22-git11  2.6.22-git12  2.6.22-git13  2.6.22-git14 

Location
[  2.6.22-git8
  [  drivers
    [  usb
      [  misc
         o  berry_charge.c

Patch

diff --git a/drivers/usb/misc/berry_charge.c b/drivers/usb/misc/berry_charge.c
index b15f2fd..92c1d27 100644
--- a/drivers/usb/misc/berry_charge.c
+++ b/drivers/usb/misc/berry_charge.c
@@ -26,8 +26,11 @@
 
 #define RIM_VENDOR      0x0fca
 #define BLACKBERRY      0x0001
+#define BLACKBERRY_PEARL_DUAL   0x0004
+#define BLACKBERRY_PEARL        0x0006
 
 static int debug;
+static int pearl_dual_mode = 1;
 
 #ifdef dbg
 #undef dbg
@@ -38,6 +41,8 @@ static int debug;
 
 static struct usb_device_id id_table [] = {
    { USB_DEVICE(RIM_VENDOR, BLACKBERRY) },
+   { USB_DEVICE(RIM_VENDOR, BLACKBERRY_PEARL) },
+   { USB_DEVICE(RIM_VENDOR, BLACKBERRY_PEARL_DUAL) },
    { },               /* Terminating entry */
 };
 MODULE_DEVICE_TABLE(usb, id_table);
@@ -86,6 +91,30 @@ static int magic_charge(struct usb_device *udev)
    return retval;
 }
 
+static int magic_dual_mode(struct usb_device *udev)
+{
+   char *dummy_buffer = kzalloc(2, GFP_KERNEL);
+   int retval;
+
+   if (!dummy_buffer)
+      return -ENOMEM;
+
+   /* send magic command so that the Blackberry Pearl device exposes
+    * two interfaces: both the USB mass-storage one and one which can
+    * be used for database access. */
+   dbg(&udev->dev, "Sending magic pearl command\n");
+   retval = usb_control_msg(udev, usb_rcvctrlpipe(udev, 0),
+             0xa9, 0xc0, 1, 1, dummy_buffer, 2, 100);
+   dbg(&udev->dev, "Magic pearl command returned %d\n", retval);
+
+   dbg(&udev->dev, "Calling set_configuration\n");
+   retval = usb_driver_set_configuration(udev, 1);
+   if (retval)
+      dev_err(&udev->dev, "Set Configuration failed :%d.\n", retval);
+
+   return retval;
+}
+
 static int berry_probe(struct usb_interface *intf,
              const struct usb_device_id *id)
 {
@@ -105,6 +134,10 @@ static int berry_probe(struct usb_interface *intf,
    /* turn the power on */
    magic_charge(udev);
 
+   if ((le16_to_cpu(udev->descriptor.idProduct) == BLACKBERRY_PEARL) &&
+       (pearl_dual_mode))
+      magic_dual_mode(udev);
+
    /* we don't really want to bind to the device, userspace programs can
     * handle the syncing just fine, so get outta here. */
    return -ENODEV;
@@ -138,3 +171,5 @@ MODULE_LICENSE("GPL");
 MODULE_AUTHOR("Greg Kroah-Hartman <gregkh@suse.de>");
 module_param(debug, bool, S_IRUGO | S_IWUSR);
 MODULE_PARM_DESC(debug, "Debug enabled or not");
+module_param(pearl_dual_mode, bool, S_IRUGO | S_IWUSR);
+MODULE_PARM_DESC(pearl_dual_mode, "Change Blackberry Pearl to run in dual mode");


Comments: webmaster (at) linuxhq.com.
Advertising: banners (at) linuxhq.com.
Compilation ©1998-2008 Linux Headquarters, Inc.