> From: Ben Greear <greearb@xxxxxxxxxxxxxxx> > > These counters are clear-on-read, so we need to accumulate > them in the update_stats poll logic, and read the accumulated > values instead of directly doing register reads when reporting > to debugfs and ethtool stats. > > Signed-off-by: Ben Greear <greearb@xxxxxxxxxxxxxxx> > --- > .../net/wireless/mediatek/mt76/mt7915/debugfs.c | 17 ++++++++--------- > drivers/net/wireless/mediatek/mt76/mt7915/mac.c | 13 ++++++++++++- > .../net/wireless/mediatek/mt76/mt7915/main.c | 16 +++++----------- > .../net/wireless/mediatek/mt76/mt7915/mt7915.h | 4 ++++ > 4 files changed, 29 insertions(+), 21 deletions(-) > > diff --git a/drivers/net/wireless/mediatek/mt76/mt7915/debugfs.c b/drivers/net/wireless/mediatek/mt76/mt7915/debugfs.c > index 1a48b09d0cb7..35248d182728 100644 > --- a/drivers/net/wireless/mediatek/mt76/mt7915/debugfs.c > +++ b/drivers/net/wireless/mediatek/mt76/mt7915/debugfs.c > @@ -152,6 +152,7 @@ mt7915_txbf_stat_read_phy(struct mt7915_phy *phy, struct seq_file *s) > "BW20", "BW40", "BW80", "BW160" > }; > int cnt; > + struct mib_stats *mib = &phy->mib; according to the check below this can be a NULL pointer dereference > > if (!phy) > return; > @@ -187,15 +188,13 @@ mt7915_txbf_stat_read_phy(struct mt7915_phy *phy, struct seq_file *s) > FIELD_GET(MT_ETBF_TX_FB_TRI, cnt)); > > /* Tx SU & MU counters */ > - cnt = mt76_rr(dev, MT_MIB_SDR34(ext_phy)); > - seq_printf(s, "Tx multi-user Beamforming counts: %ld\n", > - FIELD_GET(MT_MIB_MU_BF_TX_CNT, cnt)); > - cnt = mt76_rr(dev, MT_MIB_DR8(ext_phy)); > - seq_printf(s, "Tx multi-user MPDU counts: %d\n", cnt); > - cnt = mt76_rr(dev, MT_MIB_DR9(ext_phy)); > - seq_printf(s, "Tx multi-user successful MPDU counts: %d\n", cnt); > - cnt = mt76_rr(dev, MT_MIB_DR11(ext_phy)); > - seq_printf(s, "Tx single-user successful MPDU counts: %d\n", cnt); > + seq_printf(s, "Tx multi-user Beamforming counts: %d\n", > + mib->tx_bf_cnt); > + seq_printf(s, "Tx multi-user MPDU counts: %d\n", mib->tx_mu_mpdu_cnt); > + seq_printf(s, "Tx multi-user successful MPDU counts: %d\n", > + mib->tx_mu_acked_mpdu_cnt); > + seq_printf(s, "Tx single-user successful MPDU counts: %d\n", > + mib->tx_su_acked_mpdu_cnt); > > seq_puts(s, "\n"); > } > diff --git a/drivers/net/wireless/mediatek/mt76/mt7915/mac.c b/drivers/net/wireless/mediatek/mt76/mt7915/mac.c > index 6f445999e516..064d754e0565 100644 > --- a/drivers/net/wireless/mediatek/mt76/mt7915/mac.c > +++ b/drivers/net/wireless/mediatek/mt76/mt7915/mac.c > @@ -1890,10 +1890,21 @@ mt7915_mac_update_stats(struct mt7915_phy *phy) > struct mt7915_dev *dev = phy->dev; > struct mib_stats *mib = &phy->mib; > bool ext_phy = phy != &dev->phy; > - int i, aggr0, aggr1; > + int i, aggr0, aggr1, cnt; > > mib->fcs_err_cnt += mt76_get_field(dev, MT_MIB_SDR3(ext_phy), > MT_MIB_SDR3_FCS_ERR_MASK); > + cnt = mt76_rr(dev, MT_MIB_SDR34(ext_phy)); > + mib->tx_bf_cnt += FIELD_GET(MT_MIB_MU_BF_TX_CNT, cnt); > + > + cnt = mt76_rr(dev, MT_MIB_DR8(ext_phy)); > + mib->tx_mu_mpdu_cnt += cnt; > + > + cnt = mt76_rr(dev, MT_MIB_DR9(ext_phy)); > + mib->tx_mu_acked_mpdu_cnt += cnt; > + > + cnt = mt76_rr(dev, MT_MIB_DR11(ext_phy)); > + mib->tx_su_acked_mpdu_cnt += cnt; > > aggr0 = ext_phy ? ARRAY_SIZE(dev->mt76.aggr_stats) / 2 : 0; > for (i = 0, aggr1 = aggr0 + 4; i < 4; i++) { > diff --git a/drivers/net/wireless/mediatek/mt76/mt7915/main.c b/drivers/net/wireless/mediatek/mt76/mt7915/main.c > index de083008663e..be6444650afe 100644 > --- a/drivers/net/wireless/mediatek/mt76/mt7915/main.c > +++ b/drivers/net/wireless/mediatek/mt76/mt7915/main.c > @@ -1131,6 +1131,7 @@ void mt7915_get_et_stats(struct ieee80211_hw *hw, > struct mt7915_sta *msta; > struct mt7915_sta_stats *mstats; > bool found_sta = false; > + struct mib_stats *mib = &phy->mib; > > /* See mt7915_ampdu_stat_read_phy, etc */ > bool ext_phy = phy != &dev->phy; > @@ -1170,17 +1171,10 @@ void mt7915_get_et_stats(struct ieee80211_hw *hw, > data[ei++] = FIELD_GET(MT_ETBF_TX_FB_TRI, cnt); > > /* Tx SU & MU counters */ > - cnt = mt76_rr(dev, MT_MIB_SDR34(ext_phy)); > - data[ei++] = FIELD_GET(MT_MIB_MU_BF_TX_CNT, cnt); > - > - cnt = mt76_rr(dev, MT_MIB_DR8(ext_phy)); > - data[ei++] = cnt; > - > - cnt = mt76_rr(dev, MT_MIB_DR9(ext_phy)); > - data[ei++] = cnt; /* MU MPDU SUccessful */ > - > - cnt = mt76_rr(dev, MT_MIB_DR11(ext_phy)); > - data[ei++] = cnt; /* SU MPDU successful */ > + data[ei++] = mib->tx_bf_cnt; > + data[ei++] = mib->tx_mu_mpdu_cnt; > + data[ei++] = mib->tx_mu_acked_mpdu_cnt; > + data[ei++] = mib->tx_su_acked_mpdu_cnt; > > /* TODO: External phy too?? */ > > diff --git a/drivers/net/wireless/mediatek/mt76/mt7915/mt7915.h b/drivers/net/wireless/mediatek/mt76/mt7915/mt7915.h > index a8617ba69a21..26f2befc46dd 100644 > --- a/drivers/net/wireless/mediatek/mt76/mt7915/mt7915.h > +++ b/drivers/net/wireless/mediatek/mt76/mt7915/mt7915.h > @@ -116,6 +116,10 @@ struct mib_stats { > u32 rts_cnt; > u32 rts_retries_cnt; > u32 ba_miss_cnt; > + u32 tx_bf_cnt; > + u32 tx_mu_mpdu_cnt; > + u32 tx_mu_acked_mpdu_cnt; > + u32 tx_su_acked_mpdu_cnt; > /* Add more stats here, updated from mac_update_stats */ > }; > > -- > 2.20.1 >
Attachment:
signature.asc
Description: PGP signature