svn commit: r302103 - head/sys/dev/iwm
Adrian Chadd
adrian at FreeBSD.org
Thu Jun 23 01:11:54 UTC 2016
Author: adrian
Date: Thu Jun 23 01:11:52 2016
New Revision: 302103
URL: https://svnweb.freebsd.org/changeset/base/302103
Log:
[iwm] Add and use iwm_phy_db_free(), to plug phy_db memory leak.
(Together with other iwm(4) memory leak fixes) Memory leakage in M_DEVBUF
is now at ca. 2KB for each iwm(4) module load/unload cycle.
Submitted by: Imre Vadasz <imre at vdsz.com>
Approved by: re (gjb)
Obtained from: DragonflyBSD git eaf551a1d464c643e98ce5781971dd32124e9af1
Differential Revision: https://reviews.freebsd.org/D6819
Modified:
head/sys/dev/iwm/if_iwm.c
head/sys/dev/iwm/if_iwm_phy_db.c
head/sys/dev/iwm/if_iwm_phy_db.h
Modified: head/sys/dev/iwm/if_iwm.c
==============================================================================
--- head/sys/dev/iwm/if_iwm.c Thu Jun 23 01:00:13 2016 (r302102)
+++ head/sys/dev/iwm/if_iwm.c Thu Jun 23 01:11:52 2016 (r302103)
@@ -5014,6 +5014,8 @@ iwm_detach_local(struct iwm_softc *sc, i
if (do_net80211)
ieee80211_ifdetach(&sc->sc_ic);
+ iwm_phy_db_free(sc);
+
/* Free descriptor rings */
iwm_free_rx_ring(sc, &sc->rxq);
for (i = 0; i < nitems(sc->txq); i++)
Modified: head/sys/dev/iwm/if_iwm_phy_db.c
==============================================================================
--- head/sys/dev/iwm/if_iwm_phy_db.c Thu Jun 23 01:00:13 2016 (r302102)
+++ head/sys/dev/iwm/if_iwm_phy_db.c Thu Jun 23 01:11:52 2016 (r302103)
@@ -451,3 +451,33 @@ iwm_send_phy_db_data(struct iwm_softc *s
__func__);
return 0;
}
+
+static void
+iwm_phy_db_free_section(struct iwm_softc *sc,
+ enum iwm_phy_db_section_type type, uint16_t chg_id)
+{
+ struct iwm_phy_db_entry *entry =
+ iwm_phy_db_get_section(sc, type, chg_id);
+ if (!entry)
+ return;
+
+ if (entry->data != NULL)
+ free(entry->data, M_DEVBUF);
+ entry->data = NULL;
+ entry->size = 0;
+}
+
+void
+iwm_phy_db_free(struct iwm_softc *sc)
+{
+ int i;
+
+ iwm_phy_db_free_section(sc, IWM_PHY_DB_CFG, 0);
+ iwm_phy_db_free_section(sc, IWM_PHY_DB_CALIB_NCH, 0);
+
+ for (i = 0; i < IWM_NUM_PAPD_CH_GROUPS; i++)
+ iwm_phy_db_free_section(sc, IWM_PHY_DB_CALIB_CHG_PAPD, i);
+
+ for (i = 0; i < IWM_NUM_TXP_CH_GROUPS; i++)
+ iwm_phy_db_free_section(sc, IWM_PHY_DB_CALIB_CHG_TXP, i);
+}
Modified: head/sys/dev/iwm/if_iwm_phy_db.h
==============================================================================
--- head/sys/dev/iwm/if_iwm_phy_db.h Thu Jun 23 01:00:13 2016 (r302102)
+++ head/sys/dev/iwm/if_iwm_phy_db.h Thu Jun 23 01:11:52 2016 (r302103)
@@ -109,4 +109,5 @@
extern int iwm_phy_db_set_section(struct iwm_softc *sc,
struct iwm_calib_res_notif_phy_db *phy_db_notif);
extern int iwm_send_phy_db_data(struct iwm_softc *sc);
+extern void iwm_phy_db_free(struct iwm_softc *sc);
#endif /* __IF_IWM_PHY_DB_H__ */
More information about the svn-src-head
mailing list