diff options
author | Pekka Enberg <penberg@cs.helsinki.fi> | 2008-10-22 11:04:23 +0300 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2009-01-06 13:51:41 -0800 |
commit | 1523ddc4826155b76614e75375e2bbb27b4603f7 (patch) | |
tree | cca61f81559033b6e48b9eece7717c40845f21a4 /drivers/staging | |
parent | 581f67cf3c5a4fa533775dd6f50d70f819b48de0 (diff) |
Staging: w35und: wb35_probe() cleanup
Fix error handling in wb35_probe() function and clean it up a bit.
Signed-off-by: Pekka Enberg <penberg@cs.helsinki.fi>
Acked-by: Pavel Machek <pavel@suse.cz>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/staging')
-rw-r--r-- | drivers/staging/winbond/linux/wbusb.c | 102 |
1 files changed, 45 insertions, 57 deletions
diff --git a/drivers/staging/winbond/linux/wbusb.c b/drivers/staging/winbond/linux/wbusb.c index 5f09fd49f52..c1c2642f69c 100644 --- a/drivers/staging/winbond/linux/wbusb.c +++ b/drivers/staging/winbond/linux/wbusb.c @@ -191,26 +191,33 @@ static int wb35_probe(struct usb_interface *intf, const struct usb_device_id *id PWBUSB pWbUsb; struct usb_host_interface *interface; struct usb_endpoint_descriptor *endpoint; - int ret = -1; u32 ltmp; struct usb_device *udev = interface_to_usbdev(intf); + struct wbsoft_priv *priv; + struct ieee80211_hw *dev; + static struct ieee80211_supported_band band; + int err; usb_get_dev(udev); - printk("[w35und]wb35_probe ->\n"); - // 20060630.2 Check the device if it already be opened - ret = usb_control_msg(udev, usb_rcvctrlpipe( udev, 0 ), + err = usb_control_msg(udev, usb_rcvctrlpipe( udev, 0 ), 0x01, USB_TYPE_VENDOR|USB_RECIP_DEVICE|USB_DIR_IN, 0x0, 0x400, <mp, 4, HZ*100 ); - if (ret < 0) + if (err) goto error; ltmp = cpu_to_le32(ltmp); - if (ltmp) // Is already initialized? + if (ltmp) { // Is already initialized? + err = -EBUSY; goto error; + } adapter = kzalloc(sizeof(*adapter), GFP_KERNEL); + if (!adapter) { + err = -ENOMEM; + goto error; + } my_adapter = adapter; pWbUsb = &adapter->sHwData.WbUsb; @@ -225,69 +232,50 @@ static int wb35_probe(struct usb_interface *intf, const struct usb_device_id *id } if (!WbWLanInitialize(adapter)) { - printk("[w35und]WbWLanInitialize fail\n"); - goto error; + err = -EINVAL; + goto error_free_adapter; } - { - struct wbsoft_priv *priv; - struct ieee80211_hw *dev; - static struct ieee80211_supported_band band; - int res; - - dev = ieee80211_alloc_hw(sizeof(*priv), &wbsoft_ops); - - if (!dev) { - printk("w35und: ieee80211 alloc failed\n" ); - BUG(); - } - - my_dev = dev; - - SET_IEEE80211_DEV(dev, &udev->dev); - { - phw_data_t pHwData = &adapter->sHwData; - unsigned char dev_addr[MAX_ADDR_LEN]; - hal_get_permanent_address(pHwData, dev_addr); - SET_IEEE80211_PERM_ADDR(dev, dev_addr); - } - - - dev->extra_tx_headroom = 12; /* FIXME */ - dev->flags = 0; + dev = ieee80211_alloc_hw(sizeof(*priv), &wbsoft_ops); + if (!dev) + goto error_free_adapter; - dev->channel_change_time = 1000; -// dev->max_rssi = 100; + my_dev = dev; - dev->queues = 1; + SET_IEEE80211_DEV(dev, &udev->dev); + { + phw_data_t pHwData = &adapter->sHwData; + unsigned char dev_addr[MAX_ADDR_LEN]; + hal_get_permanent_address(pHwData, dev_addr); + SET_IEEE80211_PERM_ADDR(dev, dev_addr); + } - band.channels = wbsoft_channels; - band.n_channels = ARRAY_SIZE(wbsoft_channels); - band.bitrates = wbsoft_rates; - band.n_bitrates = ARRAY_SIZE(wbsoft_rates); + dev->extra_tx_headroom = 12; /* FIXME */ + dev->flags = 0; - dev->wiphy->bands[IEEE80211_BAND_2GHZ] = &band; -#if 0 - wbsoft_modes[0].num_channels = 1; - wbsoft_modes[0].channels = wbsoft_channels; - wbsoft_modes[0].mode = MODE_IEEE80211B; - wbsoft_modes[0].num_rates = ARRAY_SIZE(wbsoft_rates); - wbsoft_modes[0].rates = wbsoft_rates; + dev->channel_change_time = 1000; + dev->queues = 1; - res = ieee80211_register_hwmode(dev, &wbsoft_modes[0]); - BUG_ON(res); -#endif + band.channels = wbsoft_channels; + band.n_channels = ARRAY_SIZE(wbsoft_channels); + band.bitrates = wbsoft_rates; + band.n_bitrates = ARRAY_SIZE(wbsoft_rates); - res = ieee80211_register_hw(dev); - BUG_ON(res); - } + dev->wiphy->bands[IEEE80211_BAND_2GHZ] = &band; + err = ieee80211_register_hw(dev); + if (err) + goto error_free_hw; - usb_set_intfdata( intf, adapter ); + usb_set_intfdata(intf, adapter); - printk("[w35und] _probe OK\n"); return 0; + +error_free_hw: + ieee80211_free_hw(dev); +error_free_adapter: + kfree(adapter); error: - return -ENOMEM; + return err; } void packet_came(char *pRxBufferAddress, int PacketSize) |