Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/phil-wifi]: src/sys/dev/usb Initial 11n support for urtwn.



details:   https://anonhg.NetBSD.org/src/rev/7f45b0f90e61
branches:  phil-wifi
changeset: 930984:7f45b0f90e61
user:      nat <nat%NetBSD.org@localhost>
date:      Sun Apr 19 13:57:23 2020 +0000

description:
Initial 11n support for urtwn.

Compile tested only... More to come.

diffstat:

 sys/dev/usb/if_urtwn.c |  27 ++++++++++++++++++---------
 1 files changed, 18 insertions(+), 9 deletions(-)

diffs (89 lines):

diff -r 4d630c48d4f1 -r 7f45b0f90e61 sys/dev/usb/if_urtwn.c
--- a/sys/dev/usb/if_urtwn.c    Fri Apr 17 16:18:09 2020 +0000
+++ b/sys/dev/usb/if_urtwn.c    Sun Apr 19 13:57:23 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_urtwn.c,v 1.59.2.12 2020/04/17 13:44:37 martin Exp $        */
+/*     $NetBSD: if_urtwn.c,v 1.59.2.13 2020/04/19 13:57:23 nat Exp $   */
 /*     $OpenBSD: if_urtwn.c,v 1.42 2015/02/10 23:25:46 mpi Exp $       */
 
 /*-
@@ -42,7 +42,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_urtwn.c,v 1.59.2.12 2020/04/17 13:44:37 martin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_urtwn.c,v 1.59.2.13 2020/04/19 13:57:23 nat Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -1651,9 +1651,10 @@
        }
        if (ic->ic_curmode == IEEE80211_MODE_11B) {
                mode = R92C_RAID_11B;
-       } else {
+       } else if (ic->ic_curmode == IEEE80211_MODE_11G) {
                mode = R92C_RAID_11BG;
-       }
+       } else /* mode = IEEE80211_MODE_11NG */
+               mode = R92C_RAID_11GN;
        DPRINTFN(DBG_INIT, ("%s: %s: mode=%#x rates=%#x, basicrates=%#x, "
            "maxrate=%zx, maxbasicrate=%zx\n",
            device_xname(sc->sc_dev), __func__, mode, rates, basicrates,
@@ -2153,10 +2154,11 @@
 
                if (ic->ic_curmode == IEEE80211_MODE_11B) {
                        urtwn_write_1(sc, R92C_INIRTS_RATE_SEL, 0);
-               } else {
+               } else if (ic->ic_curmode == IEEE80211_MODE_11G) {
                        /* 802.11b/g */
                        urtwn_write_1(sc, R92C_INIRTS_RATE_SEL, 3);
-               }
+               } else /* IEEE_MODE_11NG */
+                       urtwn_write_1(sc, R92C_INIRTS_RATE_SEL, 12); /* MCS 0 */
 
                /* Enable Rx of data frames. */
                urtwn_write_2(sc, R92C_RXFLTMAP2, 0xffff);
@@ -2464,10 +2466,11 @@
 
                if (ic->ic_curmode == IEEE80211_MODE_11B) {
                        urtwn_write_1(sc, R92C_INIRTS_RATE_SEL, 0);
-               } else {
+               } else if (ic->ic_curmode == IEEE80211_MODE_11G) {
                        /* 802.11b/g */
                        urtwn_write_1(sc, R92C_INIRTS_RATE_SEL, 3);
-               }
+               } else /* IEEE_MODE_11NG */
+                       urtwn_write_1(sc, R92C_INIRTS_RATE_SEL, 12); /* MCS 0 */
 
                /* Enable Rx of data frames. */
                urtwn_write_2(sc, R92C_RXFLTMAP2, 0xffff);
@@ -3090,6 +3093,9 @@
                    R92C_TXDW0_OWN | R92C_TXDW0_FSG | R92C_TXDW0_LSG);
        }
 
+       if (ic->ic_curmode == IEEE80211_MODE_11NG)
+               txd->txdw5 |= htole32(R92C_TXDW5_SGI);
+
        if (IEEE80211_IS_MULTICAST(wh->i_addr1))
                txd->txdw0 |= htole32(R92C_TXDW0_BMCAST);
 
@@ -3104,8 +3110,10 @@
            type == IEEE80211_FC0_TYPE_DATA) {
                if (ic->ic_curmode == IEEE80211_MODE_11B)
                        raid = R92C_RAID_11B;
-               else
+               else if (ic->ic_curmode == IEEE80211_MODE_11G)
                        raid = R92C_RAID_11BG;
+               else    /* IEEE80211_MODE_11NG */
+                       raid = R92C_RAID_11GN;
                DPRINTFN(DBG_TX,
                    ("%s: %s: data packet: tid=%d, raid=%d\n",
                    device_xname(sc->sc_dev), __func__, tid, raid));
@@ -3657,6 +3665,7 @@
        memset(bands, 0, sizeof(bands));
        setbit(bands, IEEE80211_MODE_11B);
        setbit(bands, IEEE80211_MODE_11G);
+       setbit(bands, IEEE80211_MODE_11NG);
        ieee80211_add_channel_list_2ghz(chans, maxchans, nchans,
            urtwn_chan_2ghz, nitems(urtwn_chan_2ghz), bands, 0);
 }



Home | Main Index | Thread Index | Old Index