diff options
| author | Gertjan van Wingerde <gwingerde@gmail.com> | 2011-04-18 15:32:13 +0200 | 
|---|---|---|
| committer | John W. Linville <linville@tuxdriver.com> | 2011-04-19 15:39:45 -0400 | 
| commit | e01ae27f8ce6bd3ee26ef33c704f62449ce8233b (patch) | |
| tree | 28c022b0e755e244e4834f741d2bfce600606624 | |
| parent | ce2919c9fffe2aa52f9c3e327176d03764dbf9b5 (diff) | |
rt2x00: Allow dynamic addition of PCI/USB IDs.
Both USB and PCI drivers allow a system administrator to dynamically add
USB/PCI IDs to the device table that a driver supports via the
/sys/bus/{usb,pci,pci_express}/drivers/<driver-name>/new_id files.
However, for the rt2x00 drivers using this method currently crashes the
system with a NULL pointer failure.
This is due to the set-up of rt2x00 where the probe functions require a
rt2x00_ops structure in the driver_info field of the probed device. As
this field is empty for the dynamically added devices this fails for
these devices.
Fix this by introducing driver-specific probe wrappers that do nothing
but calling the bus-specific probe functions with the rt2x00_ops structure
as an argument, rather than depending on the driver_info field.
Signed-off-by: Gertjan van Wingerde <gwingerde@gmail.com>
Signed-off-by: Ivo van Doorn <IvDoorn@gmail.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
| -rw-r--r-- | drivers/net/wireless/rt2x00/rt2400pci.c | 11 | ||||
| -rw-r--r-- | drivers/net/wireless/rt2x00/rt2500pci.c | 10 | ||||
| -rw-r--r-- | drivers/net/wireless/rt2x00/rt2500usb.c | 70 | ||||
| -rw-r--r-- | drivers/net/wireless/rt2x00/rt2800pci.c | 58 | ||||
| -rw-r--r-- | drivers/net/wireless/rt2x00/rt2800usb.c | 440 | ||||
| -rw-r--r-- | drivers/net/wireless/rt2x00/rt2x00pci.c | 3 | ||||
| -rw-r--r-- | drivers/net/wireless/rt2x00/rt2x00pci.h | 2 | ||||
| -rw-r--r-- | drivers/net/wireless/rt2x00/rt2x00usb.c | 3 | ||||
| -rw-r--r-- | drivers/net/wireless/rt2x00/rt2x00usb.h | 8 | ||||
| -rw-r--r-- | drivers/net/wireless/rt2x00/rt61pci.c | 14 | ||||
| -rw-r--r-- | drivers/net/wireless/rt2x00/rt73usb.c | 154 | 
11 files changed, 404 insertions, 369 deletions
| diff --git a/drivers/net/wireless/rt2x00/rt2400pci.c b/drivers/net/wireless/rt2x00/rt2400pci.c index 01e951717f0f..d4acdde7c75a 100644 --- a/drivers/net/wireless/rt2x00/rt2400pci.c +++ b/drivers/net/wireless/rt2x00/rt2400pci.c @@ -1802,10 +1802,11 @@ static const struct rt2x00_ops rt2400pci_ops = {   * RT2400pci module information.   */  static DEFINE_PCI_DEVICE_TABLE(rt2400pci_device_table) = { -	{ PCI_DEVICE(0x1814, 0x0101), PCI_DEVICE_DATA(&rt2400pci_ops) }, +	{ PCI_DEVICE(0x1814, 0x0101) },  	{ 0, }  }; +  MODULE_AUTHOR(DRV_PROJECT);  MODULE_VERSION(DRV_VERSION);  MODULE_DESCRIPTION("Ralink RT2400 PCI & PCMCIA Wireless LAN driver."); @@ -1813,10 +1814,16 @@ MODULE_SUPPORTED_DEVICE("Ralink RT2460 PCI & PCMCIA chipset based cards");  MODULE_DEVICE_TABLE(pci, rt2400pci_device_table);  MODULE_LICENSE("GPL"); +static int rt2400pci_probe(struct pci_dev *pci_dev, +			   const struct pci_device_id *id) +{ +	return rt2x00pci_probe(pci_dev, &rt2400pci_ops); +} +  static struct pci_driver rt2400pci_driver = {  	.name		= KBUILD_MODNAME,  	.id_table	= rt2400pci_device_table, -	.probe		= rt2x00pci_probe, +	.probe		= rt2400pci_probe,  	.remove		= __devexit_p(rt2x00pci_remove),  	.suspend	= rt2x00pci_suspend,  	.resume		= rt2x00pci_resume, diff --git a/drivers/net/wireless/rt2x00/rt2500pci.c b/drivers/net/wireless/rt2x00/rt2500pci.c index c8deeeb9d812..15f5649e2cae 100644 --- a/drivers/net/wireless/rt2x00/rt2500pci.c +++ b/drivers/net/wireless/rt2x00/rt2500pci.c @@ -2095,7 +2095,7 @@ static const struct rt2x00_ops rt2500pci_ops = {   * RT2500pci module information.   */  static DEFINE_PCI_DEVICE_TABLE(rt2500pci_device_table) = { -	{ PCI_DEVICE(0x1814, 0x0201), PCI_DEVICE_DATA(&rt2500pci_ops) }, +	{ PCI_DEVICE(0x1814, 0x0201) },  	{ 0, }  }; @@ -2106,10 +2106,16 @@ MODULE_SUPPORTED_DEVICE("Ralink RT2560 PCI & PCMCIA chipset based cards");  MODULE_DEVICE_TABLE(pci, rt2500pci_device_table);  MODULE_LICENSE("GPL"); +static int rt2500pci_probe(struct pci_dev *pci_dev, +			   const struct pci_device_id *id) +{ +	return rt2x00pci_probe(pci_dev, &rt2500pci_ops); +} +  static struct pci_driver rt2500pci_driver = {  	.name		= KBUILD_MODNAME,  	.id_table	= rt2500pci_device_table, -	.probe		= rt2x00pci_probe, +	.probe		= rt2500pci_probe,  	.remove		= __devexit_p(rt2x00pci_remove),  	.suspend	= rt2x00pci_suspend,  	.resume		= rt2x00pci_resume, diff --git a/drivers/net/wireless/rt2x00/rt2500usb.c b/drivers/net/wireless/rt2x00/rt2500usb.c index dbbd8bc851f1..d88c36712ef0 100644 --- a/drivers/net/wireless/rt2x00/rt2500usb.c +++ b/drivers/net/wireless/rt2x00/rt2500usb.c @@ -1904,54 +1904,54 @@ static const struct rt2x00_ops rt2500usb_ops = {   */  static struct usb_device_id rt2500usb_device_table[] = {  	/* ASUS */ -	{ USB_DEVICE(0x0b05, 0x1706), USB_DEVICE_DATA(&rt2500usb_ops) }, -	{ USB_DEVICE(0x0b05, 0x1707), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x0b05, 0x1706) }, +	{ USB_DEVICE(0x0b05, 0x1707) },  	/* Belkin */ -	{ USB_DEVICE(0x050d, 0x7050), USB_DEVICE_DATA(&rt2500usb_ops) }, -	{ USB_DEVICE(0x050d, 0x7051), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x050d, 0x7050) }, +	{ USB_DEVICE(0x050d, 0x7051) },  	/* Cisco Systems */ -	{ USB_DEVICE(0x13b1, 0x000d), USB_DEVICE_DATA(&rt2500usb_ops) }, -	{ USB_DEVICE(0x13b1, 0x0011), USB_DEVICE_DATA(&rt2500usb_ops) }, -	{ USB_DEVICE(0x13b1, 0x001a), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x13b1, 0x000d) }, +	{ USB_DEVICE(0x13b1, 0x0011) }, +	{ USB_DEVICE(0x13b1, 0x001a) },  	/* Conceptronic */ -	{ USB_DEVICE(0x14b2, 0x3c02), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x14b2, 0x3c02) },  	/* D-LINK */ -	{ USB_DEVICE(0x2001, 0x3c00), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x2001, 0x3c00) },  	/* Gigabyte */ -	{ USB_DEVICE(0x1044, 0x8001), USB_DEVICE_DATA(&rt2500usb_ops) }, -	{ USB_DEVICE(0x1044, 0x8007), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x1044, 0x8001) }, +	{ USB_DEVICE(0x1044, 0x8007) },  	/* Hercules */ -	{ USB_DEVICE(0x06f8, 0xe000), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x06f8, 0xe000) },  	/* Melco */ -	{ USB_DEVICE(0x0411, 0x005e), USB_DEVICE_DATA(&rt2500usb_ops) }, -	{ USB_DEVICE(0x0411, 0x0066), USB_DEVICE_DATA(&rt2500usb_ops) }, -	{ USB_DEVICE(0x0411, 0x0067), USB_DEVICE_DATA(&rt2500usb_ops) }, -	{ USB_DEVICE(0x0411, 0x008b), USB_DEVICE_DATA(&rt2500usb_ops) }, -	{ USB_DEVICE(0x0411, 0x0097), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x0411, 0x005e) }, +	{ USB_DEVICE(0x0411, 0x0066) }, +	{ USB_DEVICE(0x0411, 0x0067) }, +	{ USB_DEVICE(0x0411, 0x008b) }, +	{ USB_DEVICE(0x0411, 0x0097) },  	/* MSI */ -	{ USB_DEVICE(0x0db0, 0x6861), USB_DEVICE_DATA(&rt2500usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x6865), USB_DEVICE_DATA(&rt2500usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x6869), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x0db0, 0x6861) }, +	{ USB_DEVICE(0x0db0, 0x6865) }, +	{ USB_DEVICE(0x0db0, 0x6869) },  	/* Ralink */ -	{ USB_DEVICE(0x148f, 0x1706), USB_DEVICE_DATA(&rt2500usb_ops) }, -	{ USB_DEVICE(0x148f, 0x2570), USB_DEVICE_DATA(&rt2500usb_ops) }, -	{ USB_DEVICE(0x148f, 0x9020), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x148f, 0x1706) }, +	{ USB_DEVICE(0x148f, 0x2570) }, +	{ USB_DEVICE(0x148f, 0x9020) },  	/* Sagem */ -	{ USB_DEVICE(0x079b, 0x004b), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x079b, 0x004b) },  	/* Siemens */ -	{ USB_DEVICE(0x0681, 0x3c06), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x0681, 0x3c06) },  	/* SMC */ -	{ USB_DEVICE(0x0707, 0xee13), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x0707, 0xee13) },  	/* Spairon */ -	{ USB_DEVICE(0x114b, 0x0110), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x114b, 0x0110) },  	/* SURECOM */ -	{ USB_DEVICE(0x0769, 0x11f3), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x0769, 0x11f3) },  	/* Trust */ -	{ USB_DEVICE(0x0eb0, 0x9020), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x0eb0, 0x9020) },  	/* VTech */ -	{ USB_DEVICE(0x0f88, 0x3012), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x0f88, 0x3012) },  	/* Zinwell */ -	{ USB_DEVICE(0x5a57, 0x0260), USB_DEVICE_DATA(&rt2500usb_ops) }, +	{ USB_DEVICE(0x5a57, 0x0260) },  	{ 0, }  }; @@ -1962,10 +1962,16 @@ MODULE_SUPPORTED_DEVICE("Ralink RT2570 USB chipset based cards");  MODULE_DEVICE_TABLE(usb, rt2500usb_device_table);  MODULE_LICENSE("GPL"); +static int rt2500usb_probe(struct usb_interface *usb_intf, +			   const struct usb_device_id *id) +{ +	return rt2x00usb_probe(usb_intf, &rt2500usb_ops); +} +  static struct usb_driver rt2500usb_driver = {  	.name		= KBUILD_MODNAME,  	.id_table	= rt2500usb_device_table, -	.probe		= rt2x00usb_probe, +	.probe		= rt2500usb_probe,  	.disconnect	= rt2x00usb_disconnect,  	.suspend	= rt2x00usb_suspend,  	.resume		= rt2x00usb_resume, diff --git a/drivers/net/wireless/rt2x00/rt2800pci.c b/drivers/net/wireless/rt2x00/rt2800pci.c index 46c3e3c83e31..6f91a9ad4d31 100644 --- a/drivers/net/wireless/rt2x00/rt2800pci.c +++ b/drivers/net/wireless/rt2x00/rt2800pci.c @@ -1117,36 +1117,36 @@ static const struct rt2x00_ops rt2800pci_ops = {   */  #ifdef CONFIG_PCI  static DEFINE_PCI_DEVICE_TABLE(rt2800pci_device_table) = { -	{ PCI_DEVICE(0x1814, 0x0601), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1814, 0x0681), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1814, 0x0701), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1814, 0x0781), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1814, 0x3090), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1814, 0x3091), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1814, 0x3092), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1432, 0x7708), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1432, 0x7727), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1432, 0x7728), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1432, 0x7738), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1432, 0x7748), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1432, 0x7758), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1432, 0x7768), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1462, 0x891a), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1a3b, 0x1059), PCI_DEVICE_DATA(&rt2800pci_ops) }, +	{ PCI_DEVICE(0x1814, 0x0601) }, +	{ PCI_DEVICE(0x1814, 0x0681) }, +	{ PCI_DEVICE(0x1814, 0x0701) }, +	{ PCI_DEVICE(0x1814, 0x0781) }, +	{ PCI_DEVICE(0x1814, 0x3090) }, +	{ PCI_DEVICE(0x1814, 0x3091) }, +	{ PCI_DEVICE(0x1814, 0x3092) }, +	{ PCI_DEVICE(0x1432, 0x7708) }, +	{ PCI_DEVICE(0x1432, 0x7727) }, +	{ PCI_DEVICE(0x1432, 0x7728) }, +	{ PCI_DEVICE(0x1432, 0x7738) }, +	{ PCI_DEVICE(0x1432, 0x7748) }, +	{ PCI_DEVICE(0x1432, 0x7758) }, +	{ PCI_DEVICE(0x1432, 0x7768) }, +	{ PCI_DEVICE(0x1462, 0x891a) }, +	{ PCI_DEVICE(0x1a3b, 0x1059) },  #ifdef CONFIG_RT2800PCI_RT33XX -	{ PCI_DEVICE(0x1814, 0x3390), PCI_DEVICE_DATA(&rt2800pci_ops) }, +	{ PCI_DEVICE(0x1814, 0x3390) },  #endif  #ifdef CONFIG_RT2800PCI_RT35XX -	{ PCI_DEVICE(0x1432, 0x7711), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1432, 0x7722), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1814, 0x3060), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1814, 0x3062), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1814, 0x3562), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1814, 0x3592), PCI_DEVICE_DATA(&rt2800pci_ops) }, -	{ PCI_DEVICE(0x1814, 0x3593), PCI_DEVICE_DATA(&rt2800pci_ops) }, +	{ PCI_DEVICE(0x1432, 0x7711) }, +	{ PCI_DEVICE(0x1432, 0x7722) }, +	{ PCI_DEVICE(0x1814, 0x3060) }, +	{ PCI_DEVICE(0x1814, 0x3062) }, +	{ PCI_DEVICE(0x1814, 0x3562) }, +	{ PCI_DEVICE(0x1814, 0x3592) }, +	{ PCI_DEVICE(0x1814, 0x3593) },  #endif  #ifdef CONFIG_RT2800PCI_RT53XX -	{ PCI_DEVICE(0x1814, 0x5390), PCI_DEVICE_DATA(&rt2800pci_ops) }, +	{ PCI_DEVICE(0x1814, 0x5390) },  #endif  	{ 0, }  }; @@ -1182,10 +1182,16 @@ static struct platform_driver rt2800soc_driver = {  #endif /* CONFIG_RALINK_RT288X || CONFIG_RALINK_RT305X */  #ifdef CONFIG_PCI +static int rt2800pci_probe(struct pci_dev *pci_dev, +			   const struct pci_device_id *id) +{ +	return rt2x00pci_probe(pci_dev, &rt2800pci_ops); +} +  static struct pci_driver rt2800pci_driver = {  	.name		= KBUILD_MODNAME,  	.id_table	= rt2800pci_device_table, -	.probe		= rt2x00pci_probe, +	.probe		= rt2800pci_probe,  	.remove		= __devexit_p(rt2x00pci_remove),  	.suspend	= rt2x00pci_suspend,  	.resume		= rt2x00pci_resume, diff --git a/drivers/net/wireless/rt2x00/rt2800usb.c b/drivers/net/wireless/rt2x00/rt2800usb.c index 1bb9a7d09de5..6f7c16174575 100644 --- a/drivers/net/wireless/rt2x00/rt2800usb.c +++ b/drivers/net/wireless/rt2x00/rt2800usb.c @@ -768,230 +768,230 @@ static const struct rt2x00_ops rt2800usb_ops = {   */  static struct usb_device_id rt2800usb_device_table[] = {  	/* Abocom */ -	{ USB_DEVICE(0x07b8, 0x2870), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x07b8, 0x2770), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x07b8, 0x3070), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x07b8, 0x3071), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x07b8, 0x3072), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1482, 0x3c09), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x07b8, 0x2870) }, +	{ USB_DEVICE(0x07b8, 0x2770) }, +	{ USB_DEVICE(0x07b8, 0x3070) }, +	{ USB_DEVICE(0x07b8, 0x3071) }, +	{ USB_DEVICE(0x07b8, 0x3072) }, +	{ USB_DEVICE(0x1482, 0x3c09) },  	/* AirTies */ -	{ USB_DEVICE(0x1eda, 0x2310), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x1eda, 0x2310) },  	/* Allwin */ -	{ USB_DEVICE(0x8516, 0x2070), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x8516, 0x2770), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x8516, 0x2870), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x8516, 0x3070), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x8516, 0x3071), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x8516, 0x3072), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x8516, 0x2070) }, +	{ USB_DEVICE(0x8516, 0x2770) }, +	{ USB_DEVICE(0x8516, 0x2870) }, +	{ USB_DEVICE(0x8516, 0x3070) }, +	{ USB_DEVICE(0x8516, 0x3071) }, +	{ USB_DEVICE(0x8516, 0x3072) },  	/* Alpha Networks */ -	{ USB_DEVICE(0x14b2, 0x3c06), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x14b2, 0x3c07), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x14b2, 0x3c09), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x14b2, 0x3c12), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x14b2, 0x3c23), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x14b2, 0x3c25), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x14b2, 0x3c27), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x14b2, 0x3c28), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x14b2, 0x3c2c), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x14b2, 0x3c06) }, +	{ USB_DEVICE(0x14b2, 0x3c07) }, +	{ USB_DEVICE(0x14b2, 0x3c09) }, +	{ USB_DEVICE(0x14b2, 0x3c12) }, +	{ USB_DEVICE(0x14b2, 0x3c23) }, +	{ USB_DEVICE(0x14b2, 0x3c25) }, +	{ USB_DEVICE(0x14b2, 0x3c27) }, +	{ USB_DEVICE(0x14b2, 0x3c28) }, +	{ USB_DEVICE(0x14b2, 0x3c2c) },  	/* Amit */ -	{ USB_DEVICE(0x15c5, 0x0008), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x15c5, 0x0008) },  	/* Askey */ -	{ USB_DEVICE(0x1690, 0x0740), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x1690, 0x0740) },  	/* ASUS */ -	{ USB_DEVICE(0x0b05, 0x1731), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0b05, 0x1732), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0b05, 0x1742), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0b05, 0x1784), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1761, 0x0b05), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x0b05, 0x1731) }, +	{ USB_DEVICE(0x0b05, 0x1732) }, +	{ USB_DEVICE(0x0b05, 0x1742) }, +	{ USB_DEVICE(0x0b05, 0x1784) }, +	{ USB_DEVICE(0x1761, 0x0b05) },  	/* AzureWave */ -	{ USB_DEVICE(0x13d3, 0x3247), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x13d3, 0x3273), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x13d3, 0x3305), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x13d3, 0x3307), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x13d3, 0x3321), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x13d3, 0x3247) }, +	{ USB_DEVICE(0x13d3, 0x3273) }, +	{ USB_DEVICE(0x13d3, 0x3305) }, +	{ USB_DEVICE(0x13d3, 0x3307) }, +	{ USB_DEVICE(0x13d3, 0x3321) },  	/* Belkin */ -	{ USB_DEVICE(0x050d, 0x8053), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x050d, 0x805c), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x050d, 0x815c), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x050d, 0x825b), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x050d, 0x935a), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x050d, 0x935b), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x050d, 0x8053) }, +	{ USB_DEVICE(0x050d, 0x805c) }, +	{ USB_DEVICE(0x050d, 0x815c) }, +	{ USB_DEVICE(0x050d, 0x825b) }, +	{ USB_DEVICE(0x050d, 0x935a) }, +	{ USB_DEVICE(0x050d, 0x935b) },  	/* Buffalo */ -	{ USB_DEVICE(0x0411, 0x00e8), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0411, 0x016f), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0411, 0x01a2), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x0411, 0x00e8) }, +	{ USB_DEVICE(0x0411, 0x016f) }, +	{ USB_DEVICE(0x0411, 0x01a2) },  	/* Corega */ -	{ USB_DEVICE(0x07aa, 0x002f), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x07aa, 0x003c), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x07aa, 0x003f), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x18c5, 0x0012), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x07aa, 0x002f) }, +	{ USB_DEVICE(0x07aa, 0x003c) }, +	{ USB_DEVICE(0x07aa, 0x003f) }, +	{ USB_DEVICE(0x18c5, 0x0012) },  	/* D-Link */ -	{ USB_DEVICE(0x07d1, 0x3c09), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x07d1, 0x3c0a), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x07d1, 0x3c0d), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x07d1, 0x3c0e), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x07d1, 0x3c0f), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x07d1, 0x3c11), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x07d1, 0x3c16), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x07d1, 0x3c09) }, +	{ USB_DEVICE(0x07d1, 0x3c0a) }, +	{ USB_DEVICE(0x07d1, 0x3c0d) }, +	{ USB_DEVICE(0x07d1, 0x3c0e) }, +	{ USB_DEVICE(0x07d1, 0x3c0f) }, +	{ USB_DEVICE(0x07d1, 0x3c11) }, +	{ USB_DEVICE(0x07d1, 0x3c16) },  	/* Draytek */ -	{ USB_DEVICE(0x07fa, 0x7712), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x07fa, 0x7712) },  	/* Edimax */ -	{ USB_DEVICE(0x7392, 0x7711), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x7392, 0x7717), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x7392, 0x7718), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x7392, 0x7711) }, +	{ USB_DEVICE(0x7392, 0x7717) }, +	{ USB_DEVICE(0x7392, 0x7718) },  	/* Encore */ -	{ USB_DEVICE(0x203d, 0x1480), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x203d, 0x14a9), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x203d, 0x1480) }, +	{ USB_DEVICE(0x203d, 0x14a9) },  	/* EnGenius */ -	{ USB_DEVICE(0x1740, 0x9701), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1740, 0x9702), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1740, 0x9703), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1740, 0x9705), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1740, 0x9706), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1740, 0x9707), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1740, 0x9708), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1740, 0x9709), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x1740, 0x9701) }, +	{ USB_DEVICE(0x1740, 0x9702) }, +	{ USB_DEVICE(0x1740, 0x9703) }, +	{ USB_DEVICE(0x1740, 0x9705) }, +	{ USB_DEVICE(0x1740, 0x9706) }, +	{ USB_DEVICE(0x1740, 0x9707) }, +	{ USB_DEVICE(0x1740, 0x9708) }, +	{ USB_DEVICE(0x1740, 0x9709) },  	/* Gemtek */ -	{ USB_DEVICE(0x15a9, 0x0012), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x15a9, 0x0012) },  	/* Gigabyte */ -	{ USB_DEVICE(0x1044, 0x800b), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1044, 0x800d), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x1044, 0x800b) }, +	{ USB_DEVICE(0x1044, 0x800d) },  	/* Hawking */ -	{ USB_DEVICE(0x0e66, 0x0001), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0e66, 0x0003), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0e66, 0x0009), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0e66, 0x000b), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0e66, 0x0013), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0e66, 0x0017), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0e66, 0x0018), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x0e66, 0x0001) }, +	{ USB_DEVICE(0x0e66, 0x0003) }, +	{ USB_DEVICE(0x0e66, 0x0009) }, +	{ USB_DEVICE(0x0e66, 0x000b) }, +	{ USB_DEVICE(0x0e66, 0x0013) }, +	{ USB_DEVICE(0x0e66, 0x0017) }, +	{ USB_DEVICE(0x0e66, 0x0018) },  	/* I-O DATA */ -	{ USB_DEVICE(0x04bb, 0x0945), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x04bb, 0x0947), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x04bb, 0x0948), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x04bb, 0x0945) }, +	{ USB_DEVICE(0x04bb, 0x0947) }, +	{ USB_DEVICE(0x04bb, 0x0948) },  	/* Linksys */ -	{ USB_DEVICE(0x13b1, 0x0031), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1737, 0x0070), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1737, 0x0071), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x13b1, 0x0031) }, +	{ USB_DEVICE(0x1737, 0x0070) }, +	{ USB_DEVICE(0x1737, 0x0071) },  	/* Logitec */ -	{ USB_DEVICE(0x0789, 0x0162), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0789, 0x0163), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0789, 0x0164), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0789, 0x0166), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x0789, 0x0162) }, +	{ USB_DEVICE(0x0789, 0x0163) }, +	{ USB_DEVICE(0x0789, 0x0164) }, +	{ USB_DEVICE(0x0789, 0x0166) },  	/* Motorola */ -	{ USB_DEVICE(0x100d, 0x9031), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x100d, 0x9031) },  	/* MSI */ -	{ USB_DEVICE(0x0db0, 0x3820), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x3821), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x3822), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x3870), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x3871), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x6899), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x821a), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x822a), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x822b), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x822c), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x870a), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x871a), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x871b), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x871c), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x899a), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x0db0, 0x3820) }, +	{ USB_DEVICE(0x0db0, 0x3821) }, +	{ USB_DEVICE(0x0db0, 0x3822) }, +	{ USB_DEVICE(0x0db0, 0x3870) }, +	{ USB_DEVICE(0x0db0, 0x3871) }, +	{ USB_DEVICE(0x0db0, 0x6899) }, +	{ USB_DEVICE(0x0db0, 0x821a) }, +	{ USB_DEVICE(0x0db0, 0x822a) }, +	{ USB_DEVICE(0x0db0, 0x822b) }, +	{ USB_DEVICE(0x0db0, 0x822c) }, +	{ USB_DEVICE(0x0db0, 0x870a) }, +	{ USB_DEVICE(0x0db0, 0x871a) }, +	{ USB_DEVICE(0x0db0, 0x871b) }, +	{ USB_DEVICE(0x0db0, 0x871c) }, +	{ USB_DEVICE(0x0db0, 0x899a) },  	/* Para */ -	{ USB_DEVICE(0x20b8, 0x8888), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x20b8, 0x8888) },  	/* Pegatron */ -	{ USB_DEVICE(0x1d4d, 0x000c), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1d4d, 0x000e), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1d4d, 0x0011), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x1d4d, 0x000c) }, +	{ USB_DEVICE(0x1d4d, 0x000e) }, +	{ USB_DEVICE(0x1d4d, 0x0011) },  	/* Philips */ -	{ USB_DEVICE(0x0471, 0x200f), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x0471, 0x200f) },  	/* Planex */ -	{ USB_DEVICE(0x2019, 0xab25), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x2019, 0xed06), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x2019, 0xab25) }, +	{ USB_DEVICE(0x2019, 0xed06) },  	/* Quanta */ -	{ USB_DEVICE(0x1a32, 0x0304), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x1a32, 0x0304) },  	/* Ralink */ -	{ USB_DEVICE(0x148f, 0x2070), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x148f, 0x2770), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x148f, 0x2870), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x148f, 0x3070), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x148f, 0x3071), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x148f, 0x3072), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x148f, 0x2070) }, +	{ USB_DEVICE(0x148f, 0x2770) }, +	{ USB_DEVICE(0x148f, 0x2870) }, +	{ USB_DEVICE(0x148f, 0x3070) }, +	{ USB_DEVICE(0x148f, 0x3071) }, +	{ USB_DEVICE(0x148f, 0x3072) },  	/* Samsung */ -	{ USB_DEVICE(0x04e8, 0x2018), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x04e8, 0x2018) },  	/* Siemens */ -	{ USB_DEVICE(0x129b, 0x1828), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x129b, 0x1828) },  	/* Sitecom */ -	{ USB_DEVICE(0x0df6, 0x0017), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0df6, 0x002b), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0df6, 0x002c), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0df6, 0x002d), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0df6, 0x0039), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0df6, 0x003b), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0df6, 0x003d), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0df6, 0x003e), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0df6, 0x003f), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0df6, 0x0040), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0df6, 0x0042), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0df6, 0x0047), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0df6, 0x0048), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x0df6, 0x0017) }, +	{ USB_DEVICE(0x0df6, 0x002b) }, +	{ USB_DEVICE(0x0df6, 0x002c) }, +	{ USB_DEVICE(0x0df6, 0x002d) }, +	{ USB_DEVICE(0x0df6, 0x0039) }, +	{ USB_DEVICE(0x0df6, 0x003b) }, +	{ USB_DEVICE(0x0df6, 0x003d) }, +	{ USB_DEVICE(0x0df6, 0x003e) }, +	{ USB_DEVICE(0x0df6, 0x003f) }, +	{ USB_DEVICE(0x0df6, 0x0040) }, +	{ USB_DEVICE(0x0df6, 0x0042) }, +	{ USB_DEVICE(0x0df6, 0x0047) }, +	{ USB_DEVICE(0x0df6, 0x0048) },  	/* SMC */ -	{ USB_DEVICE(0x083a, 0x6618), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x083a, 0x7511), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x083a, 0x7512), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x083a, 0x7522), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x083a, 0x8522), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x083a, 0xa618), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x083a, 0xa701), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x083a, 0xa702), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x083a, 0xa703), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x083a, 0xb522), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x083a, 0x6618) }, +	{ USB_DEVICE(0x083a, 0x7511) }, +	{ USB_DEVICE(0x083a, 0x7512) }, +	{ USB_DEVICE(0x083a, 0x7522) }, +	{ USB_DEVICE(0x083a, 0x8522) }, +	{ USB_DEVICE(0x083a, 0xa618) }, +	{ USB_DEVICE(0x083a, 0xa701) }, +	{ USB_DEVICE(0x083a, 0xa702) }, +	{ USB_DEVICE(0x083a, 0xa703) }, +	{ USB_DEVICE(0x083a, 0xb522) },  	/* Sparklan */ -	{ USB_DEVICE(0x15a9, 0x0006), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x15a9, 0x0006) },  	/* Sweex */ -	{ USB_DEVICE(0x177f, 0x0302), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x177f, 0x0302) },  	/* U-Media */ -	{ USB_DEVICE(0x157e, 0x300e), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x157e, 0x3013), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x157e, 0x300e) }, +	{ USB_DEVICE(0x157e, 0x3013) },  	/* ZCOM */ -	{ USB_DEVICE(0x0cde, 0x0022), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0cde, 0x0025), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x0cde, 0x0022) }, +	{ USB_DEVICE(0x0cde, 0x0025) },  	/* Zinwell */ -	{ USB_DEVICE(0x5a57, 0x0280), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x5a57, 0x0282), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x5a57, 0x0283), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x5a57, 0x5257), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x5a57, 0x0280) }, +	{ USB_DEVICE(0x5a57, 0x0282) }, +	{ USB_DEVICE(0x5a57, 0x0283) }, +	{ USB_DEVICE(0x5a57, 0x5257) },  	/* Zyxel */ -	{ USB_DEVICE(0x0586, 0x3416), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0586, 0x3418), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0586, 0x341e), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x0586, 0x3416) }, +	{ USB_DEVICE(0x0586, 0x3418) }, +	{ USB_DEVICE(0x0586, 0x341e) },  #ifdef CONFIG_RT2800USB_RT33XX  	/* Ralink */ -	{ USB_DEVICE(0x148f, 0x3370), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x148f, 0x8070), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x148f, 0x3370) }, +	{ USB_DEVICE(0x148f, 0x8070) },  	/* Sitecom */ -	{ USB_DEVICE(0x0df6, 0x0050), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x0df6, 0x0050) },  #endif  #ifdef CONFIG_RT2800USB_RT35XX  	/* Allwin */ -	{ USB_DEVICE(0x8516, 0x3572), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x8516, 0x3572) },  	/* Askey */ -	{ USB_DEVICE(0x1690, 0x0744), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x1690, 0x0744) },  	/* Cisco */ -	{ USB_DEVICE(0x167b, 0x4001), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x167b, 0x4001) },  	/* EnGenius */ -	{ USB_DEVICE(0x1740, 0x9801), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x1740, 0x9801) },  	/* I-O DATA */ -	{ USB_DEVICE(0x04bb, 0x0944), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x04bb, 0x0944) },  	/* Linksys */ -	{ USB_DEVICE(0x13b1, 0x002f), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1737, 0x0079), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x13b1, 0x002f) }, +	{ USB_DEVICE(0x1737, 0x0079) },  	/* Ralink */ -	{ USB_DEVICE(0x148f, 0x3572), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x148f, 0x3572) },  	/* Sitecom */ -	{ USB_DEVICE(0x0df6, 0x0041), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x0df6, 0x0041) },  	/* Toshiba */ -	{ USB_DEVICE(0x0930, 0x0a07), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x0930, 0x0a07) },  	/* Zinwell */ -	{ USB_DEVICE(0x5a57, 0x0284), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x5a57, 0x0284) },  #endif  #ifdef CONFIG_RT2800USB_UNKNOWN  	/* @@ -999,73 +999,73 @@ static struct usb_device_id rt2800usb_device_table[] = {  	 * vendor linux driver).  	 */  	/* Alpha Networks */ -	{ USB_DEVICE(0x14b2, 0x3c08), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x14b2, 0x3c11), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x14b2, 0x3c08) }, +	{ USB_DEVICE(0x14b2, 0x3c11) },  	/* Amigo */ -	{ USB_DEVICE(0x0e0b, 0x9031), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0e0b, 0x9041), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x0e0b, 0x9031) }, +	{ USB_DEVICE(0x0e0b, 0x9041) },  	/* ASUS */ -	{ USB_DEVICE(0x0b05, 0x1760), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0b05, 0x1761), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0b05, 0x1790), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x0b05, 0x1760) }, +	{ USB_DEVICE(0x0b05, 0x1761) }, +	{ USB_DEVICE(0x0b05, 0x1790) },  	/* AzureWave */ -	{ USB_DEVICE(0x13d3, 0x3262), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x13d3, 0x3284), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x13d3, 0x3322), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x13d3, 0x3262) }, +	{ USB_DEVICE(0x13d3, 0x3284) }, +	{ USB_DEVICE(0x13d3, 0x3322) },  	/* Belkin */ -	{ USB_DEVICE(0x050d, 0x825a), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x050d, 0x825a) },  	/* Buffalo */ -	{ USB_DEVICE(0x0411, 0x012e), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0411, 0x0148), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0411, 0x0150), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x0411, 0x015d), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x0411, 0x012e) }, +	{ USB_DEVICE(0x0411, 0x0148) }, +	{ USB_DEVICE(0x0411, 0x0150) }, +	{ USB_DEVICE(0x0411, 0x015d) },  	/* Corega */ -	{ USB_DEVICE(0x07aa, 0x0041), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x07aa, 0x0042), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x18c5, 0x0008), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x07aa, 0x0041) }, +	{ USB_DEVICE(0x07aa, 0x0042) }, +	{ USB_DEVICE(0x18c5, 0x0008) },  	/* D-Link */ -	{ USB_DEVICE(0x07d1, 0x3c0b), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x07d1, 0x3c13), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x07d1, 0x3c15), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x07d1, 0x3c17), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x07d1, 0x3c0b) }, +	{ USB_DEVICE(0x07d1, 0x3c13) }, +	{ USB_DEVICE(0x07d1, 0x3c15) }, +	{ USB_DEVICE(0x07d1, 0x3c17) },  	/* Edimax */ -	{ USB_DEVICE(0x7392, 0x4085), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x7392, 0x4085) },  	/* Encore */ -	{ USB_DEVICE(0x203d, 0x14a1), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x203d, 0x14a1) },  	/* Gemtek */ -	{ USB_DEVICE(0x15a9, 0x0010), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x15a9, 0x0010) },  	/* Gigabyte */ -	{ USB_DEVICE(0x1044, 0x800c), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x1044, 0x800c) },  	/* LevelOne */ -	{ USB_DEVICE(0x1740, 0x0605), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1740, 0x0615), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x1740, 0x0605) }, +	{ USB_DEVICE(0x1740, 0x0615) },  	/* Linksys */ -	{ USB_DEVICE(0x1737, 0x0077), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1737, 0x0078), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x1737, 0x0077) }, +	{ USB_DEVICE(0x1737, 0x0078) },  	/* Motorola */ -	{ USB_DEVICE(0x100d, 0x9032), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x100d, 0x9032) },  	/* Ovislink */ -	{ USB_DEVICE(0x1b75, 0x3071), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1b75, 0x3072), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x1b75, 0x3071) }, +	{ USB_DEVICE(0x1b75, 0x3072) },  	/* Pegatron */ -	{ USB_DEVICE(0x05a6, 0x0101), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1d4d, 0x0002), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x1d4d, 0x0010), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x05a6, 0x0101) }, +	{ USB_DEVICE(0x1d4d, 0x0002) }, +	{ USB_DEVICE(0x1d4d, 0x0010) },  	/* Planex */ -	{ USB_DEVICE(0x2019, 0x5201), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x2019, 0xab24), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x2019, 0x5201) }, +	{ USB_DEVICE(0x2019, 0xab24) },  	/* Qcom */ -	{ USB_DEVICE(0x18e8, 0x6259), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x18e8, 0x6259) },  	/* SMC */ -	{ USB_DEVICE(0x083a, 0xa512), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x083a, 0xc522), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x083a, 0xd522), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x083a, 0xf511), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x083a, 0xa512) }, +	{ USB_DEVICE(0x083a, 0xc522) }, +	{ USB_DEVICE(0x083a, 0xd522) }, +	{ USB_DEVICE(0x083a, 0xf511) },  	/* Sweex */ -	{ USB_DEVICE(0x177f, 0x0153), USB_DEVICE_DATA(&rt2800usb_ops) }, -	{ USB_DEVICE(0x177f, 0x0313), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x177f, 0x0153) }, +	{ USB_DEVICE(0x177f, 0x0313) },  	/* Zyxel */ -	{ USB_DEVICE(0x0586, 0x341a), USB_DEVICE_DATA(&rt2800usb_ops) }, +	{ USB_DEVICE(0x0586, 0x341a) },  #endif  	{ 0, }  }; @@ -1078,10 +1078,16 @@ MODULE_DEVICE_TABLE(usb, rt2800usb_device_table);  MODULE_FIRMWARE(FIRMWARE_RT2870);  MODULE_LICENSE("GPL"); +static int rt2800usb_probe(struct usb_interface *usb_intf, +			   const struct usb_device_id *id) +{ +	return rt2x00usb_probe(usb_intf, &rt2800usb_ops); +} +  static struct usb_driver rt2800usb_driver = {  	.name		= KBUILD_MODNAME,  	.id_table	= rt2800usb_device_table, -	.probe		= rt2x00usb_probe, +	.probe		= rt2800usb_probe,  	.disconnect	= rt2x00usb_disconnect,  	.suspend	= rt2x00usb_suspend,  	.resume		= rt2x00usb_resume, diff --git a/drivers/net/wireless/rt2x00/rt2x00pci.c b/drivers/net/wireless/rt2x00/rt2x00pci.c index 695aecf6bd03..17148bb24426 100644 --- a/drivers/net/wireless/rt2x00/rt2x00pci.c +++ b/drivers/net/wireless/rt2x00/rt2x00pci.c @@ -251,9 +251,8 @@ exit:  	return -ENOMEM;  } -int rt2x00pci_probe(struct pci_dev *pci_dev, const struct pci_device_id *id) +int rt2x00pci_probe(struct pci_dev *pci_dev, const struct rt2x00_ops *ops)  { -	struct rt2x00_ops *ops = (struct rt2x00_ops *)id->driver_data;  	struct ieee80211_hw *hw;  	struct rt2x00_dev *rt2x00dev;  	int retval; diff --git a/drivers/net/wireless/rt2x00/rt2x00pci.h b/drivers/net/wireless/rt2x00/rt2x00pci.h index 5d5887426f7a..e2c99f2b9a14 100644 --- a/drivers/net/wireless/rt2x00/rt2x00pci.h +++ b/drivers/net/wireless/rt2x00/rt2x00pci.h @@ -126,7 +126,7 @@ void rt2x00pci_uninitialize(struct rt2x00_dev *rt2x00dev);  /*   * PCI driver handlers.   */ -int rt2x00pci_probe(struct pci_dev *pci_dev, const struct pci_device_id *id); +int rt2x00pci_probe(struct pci_dev *pci_dev, const struct rt2x00_ops *ops);  void rt2x00pci_remove(struct pci_dev *pci_dev);  #ifdef CONFIG_PM  int rt2x00pci_suspend(struct pci_dev *pci_dev, pm_message_t state); diff --git a/drivers/net/wireless/rt2x00/rt2x00usb.c b/drivers/net/wireless/rt2x00/rt2x00usb.c index 9957579248c4..570184ee163c 100644 --- a/drivers/net/wireless/rt2x00/rt2x00usb.c +++ b/drivers/net/wireless/rt2x00/rt2x00usb.c @@ -791,10 +791,9 @@ exit:  }  int rt2x00usb_probe(struct usb_interface *usb_intf, -		    const struct usb_device_id *id) +		    const struct rt2x00_ops *ops)  {  	struct usb_device *usb_dev = interface_to_usbdev(usb_intf); -	struct rt2x00_ops *ops = (struct rt2x00_ops *)id->driver_info;  	struct ieee80211_hw *hw;  	struct rt2x00_dev *rt2x00dev;  	int retval; diff --git a/drivers/net/wireless/rt2x00/rt2x00usb.h b/drivers/net/wireless/rt2x00/rt2x00usb.h index 6aeba71b665b..52b09d2e11de 100644 --- a/drivers/net/wireless/rt2x00/rt2x00usb.h +++ b/drivers/net/wireless/rt2x00/rt2x00usb.h @@ -35,12 +35,6 @@  })  /* - * This variable should be used with the - * usb_driver structure initialization. - */ -#define USB_DEVICE_DATA(__ops)	.driver_info = (kernel_ulong_t)(__ops) - -/*   * For USB vendor requests we need to pass a timeout   * time in ms, for this we use the REGISTER_TIMEOUT,   * however when loading firmware a higher value is @@ -433,7 +427,7 @@ void rt2x00usb_uninitialize(struct rt2x00_dev *rt2x00dev);   * USB driver handlers.   */  int rt2x00usb_probe(struct usb_interface *usb_intf, -		    const struct usb_device_id *id); +		    const struct rt2x00_ops *ops);  void rt2x00usb_disconnect(struct usb_interface *usb_intf);  #ifdef CONFIG_PM  int rt2x00usb_suspend(struct usb_interface *usb_intf, pm_message_t state); diff --git a/drivers/net/wireless/rt2x00/rt61pci.c b/drivers/net/wireless/rt2x00/rt61pci.c index 264508f31a2a..c5dccdb2f175 100644 --- a/drivers/net/wireless/rt2x00/rt61pci.c +++ b/drivers/net/wireless/rt2x00/rt61pci.c @@ -3061,11 +3061,11 @@ static const struct rt2x00_ops rt61pci_ops = {   */  static DEFINE_PCI_DEVICE_TABLE(rt61pci_device_table) = {  	/* RT2561s */ -	{ PCI_DEVICE(0x1814, 0x0301), PCI_DEVICE_DATA(&rt61pci_ops) }, +	{ PCI_DEVICE(0x1814, 0x0301) },  	/* RT2561 v2 */ -	{ PCI_DEVICE(0x1814, 0x0302), PCI_DEVICE_DATA(&rt61pci_ops) }, +	{ PCI_DEVICE(0x1814, 0x0302) },  	/* RT2661 */ -	{ PCI_DEVICE(0x1814, 0x0401), PCI_DEVICE_DATA(&rt61pci_ops) }, +	{ PCI_DEVICE(0x1814, 0x0401) },  	{ 0, }  }; @@ -3080,10 +3080,16 @@ MODULE_FIRMWARE(FIRMWARE_RT2561s);  MODULE_FIRMWARE(FIRMWARE_RT2661);  MODULE_LICENSE("GPL"); +static int rt61pci_probe(struct pci_dev *pci_dev, +			 const struct pci_device_id *id) +{ +	return rt2x00pci_probe(pci_dev, &rt61pci_ops); +} +  static struct pci_driver rt61pci_driver = {  	.name		= KBUILD_MODNAME,  	.id_table	= rt61pci_device_table, -	.probe		= rt2x00pci_probe, +	.probe		= rt61pci_probe,  	.remove		= __devexit_p(rt2x00pci_remove),  	.suspend	= rt2x00pci_suspend,  	.resume		= rt2x00pci_resume, diff --git a/drivers/net/wireless/rt2x00/rt73usb.c b/drivers/net/wireless/rt2x00/rt73usb.c index cdb026d076db..be3eb5e894ef 100644 --- a/drivers/net/wireless/rt2x00/rt73usb.c +++ b/drivers/net/wireless/rt2x00/rt73usb.c @@ -2388,113 +2388,113 @@ static const struct rt2x00_ops rt73usb_ops = {   */  static struct usb_device_id rt73usb_device_table[] = {  	/* AboCom */ -	{ USB_DEVICE(0x07b8, 0xb21b), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x07b8, 0xb21c), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x07b8, 0xb21d), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x07b8, 0xb21e), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x07b8, 0xb21f), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x07b8, 0xb21b) }, +	{ USB_DEVICE(0x07b8, 0xb21c) }, +	{ USB_DEVICE(0x07b8, 0xb21d) }, +	{ USB_DEVICE(0x07b8, 0xb21e) }, +	{ USB_DEVICE(0x07b8, 0xb21f) },  	/* AL */ -	{ USB_DEVICE(0x14b2, 0x3c10), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x14b2, 0x3c10) },  	/* Amigo */ -	{ USB_DEVICE(0x148f, 0x9021), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x0eb0, 0x9021), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x148f, 0x9021) }, +	{ USB_DEVICE(0x0eb0, 0x9021) },  	/* AMIT  */ -	{ USB_DEVICE(0x18c5, 0x0002), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x18c5, 0x0002) },  	/* Askey */ -	{ USB_DEVICE(0x1690, 0x0722), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x1690, 0x0722) },  	/* ASUS */ -	{ USB_DEVICE(0x0b05, 0x1723), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x0b05, 0x1724), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x0b05, 0x1723) }, +	{ USB_DEVICE(0x0b05, 0x1724) },  	/* Belkin */ -	{ USB_DEVICE(0x050d, 0x705a), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x050d, 0x905b), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x050d, 0x905c), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x050d, 0x705a) }, +	{ USB_DEVICE(0x050d, 0x905b) }, +	{ USB_DEVICE(0x050d, 0x905c) },  	/* Billionton */ -	{ USB_DEVICE(0x1631, 0xc019), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x08dd, 0x0120), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x1631, 0xc019) }, +	{ USB_DEVICE(0x08dd, 0x0120) },  	/* Buffalo */ -	{ USB_DEVICE(0x0411, 0x00d8), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x0411, 0x00d9), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x0411, 0x00f4), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x0411, 0x0116), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x0411, 0x0119), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x0411, 0x0137), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x0411, 0x00d8) }, +	{ USB_DEVICE(0x0411, 0x00d9) }, +	{ USB_DEVICE(0x0411, 0x00f4) }, +	{ USB_DEVICE(0x0411, 0x0116) }, +	{ USB_DEVICE(0x0411, 0x0119) }, +	{ USB_DEVICE(0x0411, 0x0137) },  	/* CEIVA */ -	{ USB_DEVICE(0x178d, 0x02be), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x178d, 0x02be) },  	/* CNet */ -	{ USB_DEVICE(0x1371, 0x9022), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x1371, 0x9032), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x1371, 0x9022) }, +	{ USB_DEVICE(0x1371, 0x9032) },  	/* Conceptronic */ -	{ USB_DEVICE(0x14b2, 0x3c22), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x14b2, 0x3c22) },  	/* Corega */ -	{ USB_DEVICE(0x07aa, 0x002e), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x07aa, 0x002e) },  	/* D-Link */ -	{ USB_DEVICE(0x07d1, 0x3c03), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x07d1, 0x3c04), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x07d1, 0x3c06), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x07d1, 0x3c07), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x07d1, 0x3c03) }, +	{ USB_DEVICE(0x07d1, 0x3c04) }, +	{ USB_DEVICE(0x07d1, 0x3c06) }, +	{ USB_DEVICE(0x07d1, 0x3c07) },  	/* Edimax */ -	{ USB_DEVICE(0x7392, 0x7318), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x7392, 0x7618), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x7392, 0x7318) }, +	{ USB_DEVICE(0x7392, 0x7618) },  	/* EnGenius */ -	{ USB_DEVICE(0x1740, 0x3701), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x1740, 0x3701) },  	/* Gemtek */ -	{ USB_DEVICE(0x15a9, 0x0004), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x15a9, 0x0004) },  	/* Gigabyte */ -	{ USB_DEVICE(0x1044, 0x8008), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x1044, 0x800a), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x1044, 0x8008) }, +	{ USB_DEVICE(0x1044, 0x800a) },  	/* Huawei-3Com */ -	{ USB_DEVICE(0x1472, 0x0009), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x1472, 0x0009) },  	/* Hercules */ -	{ USB_DEVICE(0x06f8, 0xe002), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x06f8, 0xe010), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x06f8, 0xe020), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x06f8, 0xe002) }, +	{ USB_DEVICE(0x06f8, 0xe010) }, +	{ USB_DEVICE(0x06f8, 0xe020) },  	/* Linksys */ -	{ USB_DEVICE(0x13b1, 0x0020), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x13b1, 0x0023), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x13b1, 0x0028), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x13b1, 0x0020) }, +	{ USB_DEVICE(0x13b1, 0x0023) }, +	{ USB_DEVICE(0x13b1, 0x0028) },  	/* MSI */ -	{ USB_DEVICE(0x0db0, 0x4600), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x6877), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x0db0, 0x6874), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x0db0, 0xa861), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x0db0, 0xa874), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x0db0, 0x4600) }, +	{ USB_DEVICE(0x0db0, 0x6877) }, +	{ USB_DEVICE(0x0db0, 0x6874) }, +	{ USB_DEVICE(0x0db0, 0xa861) }, +	{ USB_DEVICE(0x0db0, 0xa874) },  	/* Ovislink */ -	{ USB_DEVICE(0x1b75, 0x7318), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x1b75, 0x7318) },  	/* Ralink */ -	{ USB_DEVICE(0x04bb, 0x093d), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x148f, 0x2573), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x148f, 0x2671), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x0812, 0x3101), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x04bb, 0x093d) }, +	{ USB_DEVICE(0x148f, 0x2573) }, +	{ USB_DEVICE(0x148f, 0x2671) }, +	{ USB_DEVICE(0x0812, 0x3101) },  	/* Qcom */ -	{ USB_DEVICE(0x18e8, 0x6196), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x18e8, 0x6229), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x18e8, 0x6238), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x18e8, 0x6196) }, +	{ USB_DEVICE(0x18e8, 0x6229) }, +	{ USB_DEVICE(0x18e8, 0x6238) },  	/* Samsung */ -	{ USB_DEVICE(0x04e8, 0x4471), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x04e8, 0x4471) },  	/* Senao */ -	{ USB_DEVICE(0x1740, 0x7100), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x1740, 0x7100) },  	/* Sitecom */ -	{ USB_DEVICE(0x0df6, 0x0024), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x0df6, 0x0027), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x0df6, 0x002f), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x0df6, 0x90ac), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x0df6, 0x9712), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x0df6, 0x0024) }, +	{ USB_DEVICE(0x0df6, 0x0027) }, +	{ USB_DEVICE(0x0df6, 0x002f) }, +	{ USB_DEVICE(0x0df6, 0x90ac) }, +	{ USB_DEVICE(0x0df6, 0x9712) },  	/* Surecom */ -	{ USB_DEVICE(0x0769, 0x31f3), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x0769, 0x31f3) },  	/* Tilgin */ -	{ USB_DEVICE(0x6933, 0x5001), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x6933, 0x5001) },  	/* Philips */ -	{ USB_DEVICE(0x0471, 0x200a), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x0471, 0x200a) },  	/* Planex */ -	{ USB_DEVICE(0x2019, 0xab01), USB_DEVICE_DATA(&rt73usb_ops) }, -	{ USB_DEVICE(0x2019, 0xab50), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x2019, 0xab01) }, +	{ USB_DEVICE(0x2019, 0xab50) },  	/* WideTell */ -	{ USB_DEVICE(0x7167, 0x3840), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x7167, 0x3840) },  	/* Zcom */ -	{ USB_DEVICE(0x0cde, 0x001c), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x0cde, 0x001c) },  	/* ZyXEL */ -	{ USB_DEVICE(0x0586, 0x3415), USB_DEVICE_DATA(&rt73usb_ops) }, +	{ USB_DEVICE(0x0586, 0x3415) },  	{ 0, }  }; @@ -2506,10 +2506,16 @@ MODULE_DEVICE_TABLE(usb, rt73usb_device_table);  MODULE_FIRMWARE(FIRMWARE_RT2571);  MODULE_LICENSE("GPL"); +static int rt73usb_probe(struct usb_interface *usb_intf, +			 const struct usb_device_id *id) +{ +	return rt2x00usb_probe(usb_intf, &rt73usb_ops); +} +  static struct usb_driver rt73usb_driver = {  	.name		= KBUILD_MODNAME,  	.id_table	= rt73usb_device_table, -	.probe		= rt2x00usb_probe, +	.probe		= rt73usb_probe,  	.disconnect	= rt2x00usb_disconnect,  	.suspend	= rt2x00usb_suspend,  	.resume		= rt2x00usb_resume, | 
