>From Ivo van Doorn <[EMAIL PROTECTED]>

Add software sequence number counting to rt2400pci and rt2500pci,
enable hardware sequence number counting for rt2500usb, rt61pci and rt73usb.

Signed-off-by: Ivo van Doorn <[EMAIL PROTECTED]>

---

diff -rU3 wireless-dev-dev/drivers/net/wireless/d80211/rt2x00/rt2400pci.c 
wireless-dev-sequence/drivers/net/wireless/d80211/rt2x00/rt2400pci.c
--- wireless-dev-dev/drivers/net/wireless/d80211/rt2x00/rt2400pci.c     
2006-07-23 
19:36:40.000000000 +0200
+++ wireless-dev-sequence/drivers/net/wireless/d80211/rt2x00/rt2400pci.c        
2006-07-23 19:52:17.000000000 +0200
@@ -1682,6 +1682,11 @@
                return NETDEV_TX_BUSY;
        }
 
+       /*
+        * Set the software sequence number.
+        */
+       rt2x00_set_sequence(skb, &rt2x00dev->interface.sequence);
+
        memcpy(entry->data_addr, skb->data, skb->len);
        rt2400pci_write_tx_desc(rt2x00dev, txd, skb, control);
        if (WLAN_FC_GET_STYPE(frame_control) == WLAN_FC_STYPE_RTS)
@@ -2275,6 +2280,11 @@
         */
        control->queue = IEEE80211_TX_QUEUE_BEACON;
 
+       /*
+        * Set the software sequence number.
+        */
+       rt2x00_set_sequence(skb, &rt2x00dev->interface.sequence);
+
        memcpy(entry->data_addr, skb->data, skb->len);
        rt2400pci_write_tx_desc(rt2x00dev, entry->desc_addr, skb, control);
 
diff -rU3 wireless-dev-dev/drivers/net/wireless/d80211/rt2x00/rt2500pci.c 
wireless-dev-sequence/drivers/net/wireless/d80211/rt2x00/rt2500pci.c
--- wireless-dev-dev/drivers/net/wireless/d80211/rt2x00/rt2500pci.c     
2006-07-23 
19:33:46.000000000 +0200
+++ wireless-dev-sequence/drivers/net/wireless/d80211/rt2x00/rt2500pci.c        
2006-07-23 19:52:28.000000000 +0200
@@ -1817,6 +1817,11 @@
                return NETDEV_TX_BUSY;
        }
 
+       /*
+        * Set the software sequence number.
+        */
+       rt2x00_set_sequence(skb, &rt2x00dev->interface.sequence);
+
        memcpy(entry->data_addr, skb->data, skb->len);
        rt2500pci_write_tx_desc(rt2x00dev, txd, skb, control);
        if (WLAN_FC_GET_STYPE(frame_control) == WLAN_FC_STYPE_RTS)
@@ -2401,6 +2406,11 @@
         */
        control->queue = IEEE80211_TX_QUEUE_BEACON;
 
+       /*
+        * Set the software sequence number.
+        */
+       rt2x00_set_sequence(skb, &rt2x00dev->interface.sequence);
+
        memcpy(entry->data_addr, skb->data, skb->len);
        rt2500pci_write_tx_desc(rt2x00dev, entry->desc_addr, skb, control);
 
diff -rU3 wireless-dev-dev/drivers/net/wireless/d80211/rt2x00/rt2500usb.c 
wireless-dev-sequence/drivers/net/wireless/d80211/rt2x00/rt2500usb.c
--- wireless-dev-dev/drivers/net/wireless/d80211/rt2x00/rt2500usb.c     
2006-07-23 
19:36:18.000000000 +0200
+++ wireless-dev-sequence/drivers/net/wireless/d80211/rt2x00/rt2500usb.c        
2006-07-23 19:54:54.000000000 +0200
@@ -1385,7 +1385,7 @@
        rt2x00_register_write(rt2x00dev, MAC_CSR18, reg);
 
        rt2x00_register_read(rt2x00dev, TXRX_CSR1, &reg);
-       rt2x00_set_field16_nb(&reg, TXRX_CSR1_AUTO_SEQUENCE, 0x00);
+       rt2x00_set_field16_nb(&reg, TXRX_CSR1_AUTO_SEQUENCE, 1);
        rt2x00_register_write(rt2x00dev, TXRX_CSR1, reg);
 
        rt2x00_register_read(rt2x00dev, PHY_CSR4, &reg);
diff -rU3 wireless-dev-dev/drivers/net/wireless/d80211/rt2x00/rt2x00.h 
wireless-dev-sequence/drivers/net/wireless/d80211/rt2x00/rt2x00.h
--- wireless-dev-dev/drivers/net/wireless/d80211/rt2x00/rt2x00.h        
2006-07-23 
18:09:00.000000000 +0200
+++ wireless-dev-sequence/drivers/net/wireless/d80211/rt2x00/rt2x00.h   
2006-07-23 19:49:00.000000000 +0200
@@ -911,6 +911,50 @@
 }
 
 /*
+ * Sequence number handlers.
+ */
+static inline int rt2x00_require_sequence(struct ieee80211_hdr *ieee80211hdr)
+{
+       /*
+        * Check if the packet has a header
+        * that contains a seq_ctrl field.
+        */
+       if (ieee80211_get_hdrlen(
+               le16_to_cpu(ieee80211hdr->frame_control)) >= IEEE80211_HEADER)
+               return 1;
+       return 0;
+}
+
+static inline void rt2x00_set_sequence(struct sk_buff *skb, u16 *seq)
+{
+       struct ieee80211_hdr *ieee80211hdr =
+               (struct ieee80211_hdr*)skb->data;
+
+       /*
+        * Only attach the sequence number, when
+        * the buffer requires it.
+        */
+       if (!rt2x00_require_sequence(ieee80211hdr))
+               return;
+
+       /*
+        * Set the sequence number for this frame,
+        * but do not change the fragment number.
+        */
+       ieee80211hdr->seq_ctrl |= cpu_to_le16((*seq << 4) & 0xfff0);
+
+       /*
+        * Since the dscape stack sends all packets and
+        * fragments individually, we need to check if there
+        * will be new fragments following.
+        * If this is the last or only fragment, the sequence
+        * counter should be increased.
+        */
+       if (!ieee80211_get_morefrag(ieee80211hdr))
+               *seq = (*seq + 1) & 0x0fff;
+}
+
+/*
  * Duration calculations
  * The rate variable passed is: 100kbs.
  * To convert from bytes to bits we multiply size with 8,
diff -rU3 wireless-dev-dev/drivers/net/wireless/d80211/rt2x00/rt61pci.c 
wireless-dev-sequence/drivers/net/wireless/d80211/rt2x00/rt61pci.c
--- wireless-dev-dev/drivers/net/wireless/d80211/rt2x00/rt61pci.c       
2006-07-23 
19:34:27.000000000 +0200
+++ wireless-dev-sequence/drivers/net/wireless/d80211/rt2x00/rt61pci.c  
2006-07-23 19:53:45.000000000 +0200
@@ -1321,7 +1321,10 @@
                rt2x00_set_field32(&txd->word1,
                        TXD_W1_HOST_Q_ID, control->queue);
 
-       rt2x00_set_field32(&txd->word1, TXD_W1_HW_SEQUENCE, 0);
+       if (rt2x00_require_sequence(ieee80211hdr))
+               rt2x00_set_field32(&txd->word1, TXD_W1_HW_SEQUENCE, 1);
+       else
+               rt2x00_set_field32(&txd->word1, TXD_W1_HW_SEQUENCE, 0);
 
        rt2x00_set_field32(&txd->word1, TXD_W1_AIFSN, ring->tx_params.aifs);
        rt2x00_set_field32(&txd->word1, TXD_W1_CWMIN, ring->tx_params.cw_min);
@@ -2113,6 +2116,10 @@
        rt2x00_set_field32(&reg, MAC_CSR9_CW_SELECT, 0);
        rt2x00_register_write(rt2x00dev, MAC_CSR9, reg);
 
+       rt2x00_register_read(rt2x00dev, TXRX_CSR0, &reg);
+       rt2x00_set_field32(&reg, TXRX_CSR0_AUTO_TX_SEQ, 1);
+       rt2x00_register_write(rt2x00dev, TXRX_CSR0, reg);
+
        rt2x00_register_write(rt2x00dev, PHY_CSR1, cpu_to_le32(0x000023b0));
        rt2x00_register_write(rt2x00dev, PHY_CSR5, cpu_to_le32(0x060a100c));
        rt2x00_register_write(rt2x00dev, PHY_CSR6, cpu_to_le32(0x00080606));
diff -rU3 wireless-dev-dev/drivers/net/wireless/d80211/rt2x00/rt73usb.c 
wireless-dev-sequence/drivers/net/wireless/d80211/rt2x00/rt73usb.c
--- wireless-dev-dev/drivers/net/wireless/d80211/rt2x00/rt73usb.c       
2006-07-23 
19:33:08.000000000 +0200
+++ wireless-dev-sequence/drivers/net/wireless/d80211/rt2x00/rt73usb.c  
2006-07-23 19:54:16.000000000 +0200
@@ -1038,7 +1038,10 @@
                rt2x00_set_field32(&txd->word1,
                        TXD_W1_HOST_Q_ID, control->queue);
 
-       rt2x00_set_field32(&txd->word1, TXD_W1_HW_SEQUENCE, 0);
+       if (rt2x00_require_sequence(ieee80211hdr))
+               rt2x00_set_field32(&txd->word1, TXD_W1_HW_SEQUENCE, 1);
+       else
+               rt2x00_set_field32(&txd->word1, TXD_W1_HW_SEQUENCE, 0);
 
        rt2x00_set_field32(&txd->word1, TXD_W1_AIFSN, ring->tx_params.aifs);
        rt2x00_set_field32(&txd->word1, TXD_W1_CWMIN, ring->tx_params.cw_min);
@@ -1682,6 +1685,10 @@
        rt2x00_set_field32(&reg, MAC_CSR9_CW_SELECT, 0);
        rt2x00_register_write(rt2x00dev, MAC_CSR9, reg);
 
+       rt2x00_register_read(rt2x00dev, TXRX_CSR0, &reg);
+       rt2x00_set_field32(&reg, TXRX_CSR0_AUTO_TX_SEQ, 1);
+       rt2x00_register_write(rt2x00dev, TXRX_CSR0, reg);
+
        /*
         * We must clear the error counters.
         * These registers are cleared on read,
-
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to