mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-07-23 15:27:29 +00:00
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>
This commit is contained in:
parent
ce2919c9ff
commit
e01ae27f8c
11 changed files with 404 additions and 369 deletions
|
@ -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,
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue