Source-Changes-HG archive

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

[src-draft/trunk]: src/sys/dev/pci Avoid redundant (and expensive) channel setup



details:   https://anonhg.NetBSD.org/src-all/rev/7afe5f7ea61b
branches:  trunk
changeset: 377007:7afe5f7ea61b
user:      Martin Husemann <martin%NetBSD.org@localhost>
date:      Sun Jun 06 14:28:55 2021 +0200

description:
Avoid redundant (and expensive) channel setup

diffstat:

 sys/dev/pci/if_rtwn.c    |  8 ++++++++
 sys/dev/pci/if_rtwnreg.h |  1 +
 2 files changed, 9 insertions(+), 0 deletions(-)

diffs (36 lines):

diff -r f638ba758850 -r 7afe5f7ea61b sys/dev/pci/if_rtwn.c
--- a/sys/dev/pci/if_rtwn.c     Sun Jun 06 14:27:00 2021 +0200
+++ b/sys/dev/pci/if_rtwn.c     Sun Jun 06 14:28:55 2021 +0200
@@ -3147,6 +3147,11 @@ rtwn_set_chan(struct ieee80211com *ic)
 
        DPRINTFN(3, ("%s: %s\n", device_xname(sc->sc_dev), __func__));
 
+       if (sc->sc_curchan != NULL && sc->sc_curchan == ic->ic_curchan)
+               return;
+
+//     RTWN_LOCK();    // XXX
+
        chan = ieee80211_chan2ieee(ic, ic->ic_curchan);
 
        /* Set Tx power for this new channel. */
@@ -3214,6 +3219,9 @@ rtwn_set_chan(struct ieee80211com *ic)
                rtwn_rf_write(sc, 0, R92C_RF_CHNLBW,
                    (sc->rf_chnlbw[0] & ~0xfff) | R92C_RF_CHNLBW_BW20 | chan);
        }
+
+       sc->sc_curchan = ic->ic_curchan;
+//     RTWN_UNLOCK();  // XXX
 }
 
 static void
diff -r f638ba758850 -r 7afe5f7ea61b sys/dev/pci/if_rtwnreg.h
--- a/sys/dev/pci/if_rtwnreg.h  Sun Jun 06 14:27:00 2021 +0200
+++ b/sys/dev/pci/if_rtwnreg.h  Sun Jun 06 14:28:55 2021 +0200
@@ -147,6 +147,7 @@ struct rtwn_softc {
        device_t                        sc_dev;
        struct ieee80211com             sc_ic;
        struct ifqueue                  sc_sendq;
+       struct ieee80211_channel        *sc_curchan;
 
        /* PCI specific goo. */
        bus_dma_tag_t                   sc_dmat;



Home | Main Index | Thread Index | Old Index