diff options
author | Russell King <rmk+kernel@arm.linux.org.uk> | 2013-10-07 10:43:04 -0400 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2013-10-07 10:43:04 -0400 |
commit | a56e74f546b64be93731e42d83baf5b538cc1b11 (patch) | |
tree | 18f6dee45d801e57ac9db2a31664b0d5c0762c50 /drivers/net/wireless/rtl818x/rtl8187/dev.c | |
parent | d08e2e09042bd3f7ef66a35cb4bb92794ab26bb2 (diff) | |
parent | e4e7f10bfc4069925e99cc4b428c3434e30b6c3f (diff) |
Merge branch 'arm-aesbs' of git://git.linaro.org/people/ardbiesheuvel/linux-arm into devel-stable
Diffstat (limited to 'drivers/net/wireless/rtl818x/rtl8187/dev.c')
-rw-r--r-- | drivers/net/wireless/rtl818x/rtl8187/dev.c | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/drivers/net/wireless/rtl818x/rtl8187/dev.c b/drivers/net/wireless/rtl818x/rtl8187/dev.c index 841fb9dfc9da..9a6edb0c014e 100644 --- a/drivers/net/wireless/rtl818x/rtl8187/dev.c +++ b/drivers/net/wireless/rtl818x/rtl8187/dev.c | |||
@@ -438,17 +438,16 @@ static int rtl8187_init_urbs(struct ieee80211_hw *dev) | |||
438 | skb_queue_tail(&priv->rx_queue, skb); | 438 | skb_queue_tail(&priv->rx_queue, skb); |
439 | usb_anchor_urb(entry, &priv->anchored); | 439 | usb_anchor_urb(entry, &priv->anchored); |
440 | ret = usb_submit_urb(entry, GFP_KERNEL); | 440 | ret = usb_submit_urb(entry, GFP_KERNEL); |
441 | usb_put_urb(entry); | ||
441 | if (ret) { | 442 | if (ret) { |
442 | skb_unlink(skb, &priv->rx_queue); | 443 | skb_unlink(skb, &priv->rx_queue); |
443 | usb_unanchor_urb(entry); | 444 | usb_unanchor_urb(entry); |
444 | goto err; | 445 | goto err; |
445 | } | 446 | } |
446 | usb_free_urb(entry); | ||
447 | } | 447 | } |
448 | return ret; | 448 | return ret; |
449 | 449 | ||
450 | err: | 450 | err: |
451 | usb_free_urb(entry); | ||
452 | kfree_skb(skb); | 451 | kfree_skb(skb); |
453 | usb_kill_anchored_urbs(&priv->anchored); | 452 | usb_kill_anchored_urbs(&priv->anchored); |
454 | return ret; | 453 | return ret; |
@@ -956,8 +955,12 @@ static int rtl8187_start(struct ieee80211_hw *dev) | |||
956 | (RETRY_COUNT << 8 /* short retry limit */) | | 955 | (RETRY_COUNT << 8 /* short retry limit */) | |
957 | (RETRY_COUNT << 0 /* long retry limit */) | | 956 | (RETRY_COUNT << 0 /* long retry limit */) | |
958 | (7 << 21 /* MAX TX DMA */)); | 957 | (7 << 21 /* MAX TX DMA */)); |
959 | rtl8187_init_urbs(dev); | 958 | ret = rtl8187_init_urbs(dev); |
960 | rtl8187b_init_status_urb(dev); | 959 | if (ret) |
960 | goto rtl8187_start_exit; | ||
961 | ret = rtl8187b_init_status_urb(dev); | ||
962 | if (ret) | ||
963 | usb_kill_anchored_urbs(&priv->anchored); | ||
961 | goto rtl8187_start_exit; | 964 | goto rtl8187_start_exit; |
962 | } | 965 | } |
963 | 966 | ||
@@ -966,7 +969,9 @@ static int rtl8187_start(struct ieee80211_hw *dev) | |||
966 | rtl818x_iowrite32(priv, &priv->map->MAR[0], ~0); | 969 | rtl818x_iowrite32(priv, &priv->map->MAR[0], ~0); |
967 | rtl818x_iowrite32(priv, &priv->map->MAR[1], ~0); | 970 | rtl818x_iowrite32(priv, &priv->map->MAR[1], ~0); |
968 | 971 | ||
969 | rtl8187_init_urbs(dev); | 972 | ret = rtl8187_init_urbs(dev); |
973 | if (ret) | ||
974 | goto rtl8187_start_exit; | ||
970 | 975 | ||
971 | reg = RTL818X_RX_CONF_ONLYERLPKT | | 976 | reg = RTL818X_RX_CONF_ONLYERLPKT | |
972 | RTL818X_RX_CONF_RX_AUTORESETPHY | | 977 | RTL818X_RX_CONF_RX_AUTORESETPHY | |