@ -641,9 +641,9 @@ err:
static void ath9k_hif_usb_rx_cb ( struct urb * urb )
{
struct rx_buf * rx_buf = ( struct rx_bu f * ) urb - > context ;
struct hif_device_usb * hif_dev = rx_buf - > hif_dev ;
struct sk_buff * skb = rx_buf - > skb ;
struct sk_buff * skb = ( struct sk_buf f * ) urb - > context ;
struct hif_device_usb * hif_dev =
usb_get_intfdata ( usb_ifnum_to_if ( urb - > dev , 0 ) ) ;
int ret ;
if ( ! skb )
@ -683,15 +683,14 @@ resubmit:
return ;
free :
kfree_skb ( skb ) ;
kfree ( rx_buf ) ;
}
static void ath9k_hif_usb_reg_in_cb ( struct urb * urb )
{
struct rx_buf * rx_buf = ( struct rx_buf * ) urb - > context ;
struct hif_device_usb * hif_dev = rx_buf - > hif_dev ;
struct sk_buff * skb = rx_buf - > skb ;
struct sk_buff * skb = ( struct sk_buff * ) urb - > context ;
struct sk_buff * nskb ;
struct hif_device_usb * hif_dev =
usb_get_intfdata ( usb_ifnum_to_if ( urb - > dev , 0 ) ) ;
int ret ;
if ( ! skb )
@ -749,7 +748,6 @@ resubmit:
return ;
free :
kfree_skb ( skb ) ;
kfree ( rx_buf ) ;
urb - > context = NULL ;
}
@ -795,7 +793,7 @@ static int ath9k_hif_usb_alloc_tx_urbs(struct hif_device_usb *hif_dev)
init_usb_anchor ( & hif_dev - > mgmt_submitted ) ;
for ( i = 0 ; i < MAX_TX_URB_NUM ; i + + ) {
tx_buf = kzalloc ( sizeof ( * tx_buf ) , GFP_KERNEL ) ;
tx_buf = kzalloc ( sizeof ( struct tx_buf ) , GFP_KERNEL ) ;
if ( ! tx_buf )
goto err ;
@ -832,9 +830,8 @@ static void ath9k_hif_usb_dealloc_rx_urbs(struct hif_device_usb *hif_dev)
static int ath9k_hif_usb_alloc_rx_urbs ( struct hif_device_usb * hif_dev )
{
struct rx_buf * rx_buf = NULL ;
struct sk_buff * skb = NULL ;
struct urb * urb = NULL ;
struct sk_buff * skb = NULL ;
int i , ret ;
init_usb_anchor ( & hif_dev - > rx_submitted ) ;
@ -842,12 +839,6 @@ static int ath9k_hif_usb_alloc_rx_urbs(struct hif_device_usb *hif_dev)
for ( i = 0 ; i < MAX_RX_URB_NUM ; i + + ) {
rx_buf = kzalloc ( sizeof ( * rx_buf ) , GFP_KERNEL ) ;
if ( ! rx_buf ) {
ret = - ENOMEM ;
goto err_rxb ;
}
/* Allocate URB */
urb = usb_alloc_urb ( 0 , GFP_KERNEL ) ;
if ( urb = = NULL ) {
@ -862,14 +853,11 @@ static int ath9k_hif_usb_alloc_rx_urbs(struct hif_device_usb *hif_dev)
goto err_skb ;
}
rx_buf - > hif_dev = hif_dev ;
rx_buf - > skb = skb ;
usb_fill_bulk_urb ( urb , hif_dev - > udev ,
usb_rcvbulkpipe ( hif_dev - > udev ,
USB_WLAN_RX_PIPE ) ,
skb - > data , MAX_RX_BUF_SIZE ,
ath9k_hif_usb_rx_cb , rx_buf ) ;
ath9k_hif_usb_rx_cb , skb ) ;
/* Anchor URB */
usb_anchor_urb ( urb , & hif_dev - > rx_submitted ) ;
@ -895,8 +883,6 @@ err_submit:
err_skb :
usb_free_urb ( urb ) ;
err_urb :
kfree ( rx_buf ) ;
err_rxb :
ath9k_hif_usb_dealloc_rx_urbs ( hif_dev ) ;
return ret ;
}
@ -908,21 +894,14 @@ static void ath9k_hif_usb_dealloc_reg_in_urbs(struct hif_device_usb *hif_dev)
static int ath9k_hif_usb_alloc_reg_in_urbs ( struct hif_device_usb * hif_dev )
{
struct rx_buf * rx_buf = NULL ;
struct sk_buff * skb = NULL ;
struct urb * urb = NULL ;
struct sk_buff * skb = NULL ;
int i , ret ;
init_usb_anchor ( & hif_dev - > reg_in_submitted ) ;
for ( i = 0 ; i < MAX_REG_IN_URB_NUM ; i + + ) {
rx_buf = kzalloc ( sizeof ( * rx_buf ) , GFP_KERNEL ) ;
if ( ! rx_buf ) {
ret = - ENOMEM ;
goto err_rxb ;
}
/* Allocate URB */
urb = usb_alloc_urb ( 0 , GFP_KERNEL ) ;
if ( urb = = NULL ) {
@ -937,14 +916,11 @@ static int ath9k_hif_usb_alloc_reg_in_urbs(struct hif_device_usb *hif_dev)
goto err_skb ;
}
rx_buf - > hif_dev = hif_dev ;
rx_buf - > skb = skb ;
usb_fill_int_urb ( urb , hif_dev - > udev ,
usb_rcvintpipe ( hif_dev - > udev ,
USB_REG_IN_PIPE ) ,
skb - > data , MAX_REG_IN_BUF_SIZE ,
ath9k_hif_usb_reg_in_cb , rx_buf , 1 ) ;
ath9k_hif_usb_reg_in_cb , skb , 1 ) ;
/* Anchor URB */
usb_anchor_urb ( urb , & hif_dev - > reg_in_submitted ) ;
@ -970,8 +946,6 @@ err_submit:
err_skb :
usb_free_urb ( urb ) ;
err_urb :
kfree ( rx_buf ) ;
err_rxb :
ath9k_hif_usb_dealloc_reg_in_urbs ( hif_dev ) ;
return ret ;
}