diff options
Diffstat (limited to 'drivers/net/wireless/rt2x00/rt2500usb.c')
-rw-r--r-- | drivers/net/wireless/rt2x00/rt2500usb.c | 30 |
1 files changed, 21 insertions, 9 deletions
diff --git a/drivers/net/wireless/rt2x00/rt2500usb.c b/drivers/net/wireless/rt2x00/rt2500usb.c index 15ab4b20d067..2a38388a79e1 100644 --- a/drivers/net/wireless/rt2x00/rt2500usb.c +++ b/drivers/net/wireless/rt2x00/rt2500usb.c | |||
@@ -1686,8 +1686,8 @@ static int rt2500usb_beacon_update(struct ieee80211_hw *hw, | |||
1686 | struct rt2x00_dev *rt2x00dev = hw->priv; | 1686 | struct rt2x00_dev *rt2x00dev = hw->priv; |
1687 | struct usb_device *usb_dev = | 1687 | struct usb_device *usb_dev = |
1688 | interface_to_usbdev(rt2x00dev_usb(rt2x00dev)); | 1688 | interface_to_usbdev(rt2x00dev_usb(rt2x00dev)); |
1689 | struct data_ring *ring = | 1689 | struct skb_desc *desc; |
1690 | rt2x00lib_get_ring(rt2x00dev, IEEE80211_TX_QUEUE_BEACON); | 1690 | struct data_ring *ring; |
1691 | struct data_entry *beacon; | 1691 | struct data_entry *beacon; |
1692 | struct data_entry *guardian; | 1692 | struct data_entry *guardian; |
1693 | int pipe = usb_sndbulkpipe(usb_dev, 1); | 1693 | int pipe = usb_sndbulkpipe(usb_dev, 1); |
@@ -1699,6 +1699,7 @@ static int rt2500usb_beacon_update(struct ieee80211_hw *hw, | |||
1699 | * initialization. | 1699 | * initialization. |
1700 | */ | 1700 | */ |
1701 | control->queue = IEEE80211_TX_QUEUE_BEACON; | 1701 | control->queue = IEEE80211_TX_QUEUE_BEACON; |
1702 | ring = rt2x00lib_get_ring(rt2x00dev, control->queue); | ||
1702 | 1703 | ||
1703 | /* | 1704 | /* |
1704 | * Obtain 2 entries, one for the guardian byte, | 1705 | * Obtain 2 entries, one for the guardian byte, |
@@ -1709,23 +1710,34 @@ static int rt2500usb_beacon_update(struct ieee80211_hw *hw, | |||
1709 | beacon = rt2x00_get_data_entry(ring); | 1710 | beacon = rt2x00_get_data_entry(ring); |
1710 | 1711 | ||
1711 | /* | 1712 | /* |
1712 | * First we create the beacon. | 1713 | * Add the descriptor in front of the skb. |
1713 | */ | 1714 | */ |
1714 | skb_push(skb, ring->desc_size); | 1715 | skb_push(skb, ring->desc_size); |
1715 | memset(skb->data, 0, ring->desc_size); | 1716 | memset(skb->data, 0, ring->desc_size); |
1716 | 1717 | ||
1717 | rt2x00lib_write_tx_desc(rt2x00dev, (__le32 *)skb->data, | 1718 | /* |
1718 | (struct ieee80211_hdr *)(skb->data + | 1719 | * Fill in skb descriptor |
1719 | ring->desc_size), | 1720 | */ |
1720 | skb->len - ring->desc_size, control); | 1721 | desc = get_skb_desc(skb); |
1722 | desc->desc_len = ring->desc_size; | ||
1723 | desc->data_len = skb->len - ring->desc_size; | ||
1724 | desc->desc = skb->data; | ||
1725 | desc->data = skb->data + ring->desc_size; | ||
1726 | desc->ring = ring; | ||
1727 | desc->entry = beacon; | ||
1728 | |||
1729 | rt2x00lib_write_tx_desc(rt2x00dev, skb, control); | ||
1721 | 1730 | ||
1731 | /* | ||
1732 | * USB devices cannot blindly pass the skb->len as the | ||
1733 | * length of the data to usb_fill_bulk_urb. Pass the skb | ||
1734 | * to the driver to determine what the length should be. | ||
1735 | */ | ||
1722 | length = rt2500usb_get_tx_data_len(rt2x00dev, skb); | 1736 | length = rt2500usb_get_tx_data_len(rt2x00dev, skb); |
1723 | 1737 | ||
1724 | usb_fill_bulk_urb(beacon->priv, usb_dev, pipe, | 1738 | usb_fill_bulk_urb(beacon->priv, usb_dev, pipe, |
1725 | skb->data, length, rt2500usb_beacondone, beacon); | 1739 | skb->data, length, rt2500usb_beacondone, beacon); |
1726 | 1740 | ||
1727 | beacon->skb = skb; | ||
1728 | |||
1729 | /* | 1741 | /* |
1730 | * Second we need to create the guardian byte. | 1742 | * Second we need to create the guardian byte. |
1731 | * We only need a single byte, so lets recycle | 1743 | * We only need a single byte, so lets recycle |