Source-Changes-HG archive

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

[src-draft/trunk]: src/sys/net80211 Node managment may be called from softint...



details:   https://anonhg.NetBSD.org/src-all/rev/7a2116929de8
branches:  trunk
changeset: 986951:7a2116929de8
user:      Martin Husemann <martin%NetBSD.org@localhost>
date:      Thu Feb 11 18:20:29 2021 +0100

description:
Node managment may be called from softint context.

Adjust memory management accordingly (it was inconsistent before).

diffstat:

 sys/net80211/ieee80211_hostap.c |   4 ++--
 sys/net80211/ieee80211_input.c  |   2 +-
 sys/net80211/ieee80211_node.c   |  21 +++++++++++----------
 sys/net80211/ieee80211_sta.c    |   2 +-
 4 files changed, 15 insertions(+), 14 deletions(-)

diffs (132 lines):

diff -r 9284649b6905 -r 7a2116929de8 sys/net80211/ieee80211_hostap.c
--- a/sys/net80211/ieee80211_hostap.c   Wed Feb 03 15:20:50 2021 +0100
+++ b/sys/net80211/ieee80211_hostap.c   Thu Feb 11 18:20:29 2021 +0100
@@ -973,7 +973,7 @@
                 * open auth is attempted.
                 */
                if (ni->ni_challenge != NULL) {
-                       IEEE80211_FREE(ni->ni_challenge, M_80211_NODE,
+                       IEEE80211_MFREE(ni->ni_challenge, M_80211_NODE,
                            IEEE80211_CHALLENGE_LEN);
                        ni->ni_challenge = NULL;
                }
@@ -2170,7 +2170,7 @@
                        return;
                /* discard challenge after association */
                if (ni->ni_challenge != NULL) {
-                       IEEE80211_FREE(ni->ni_challenge, M_80211_NODE,
+                       IEEE80211_MFREE(ni->ni_challenge, M_80211_NODE,
                            IEEE80211_CHALLENGE_LEN);
                        ni->ni_challenge = NULL;
                }
diff -r 9284649b6905 -r 7a2116929de8 sys/net80211/ieee80211_input.c
--- a/sys/net80211/ieee80211_input.c    Wed Feb 03 15:20:50 2021 +0100
+++ b/sys/net80211/ieee80211_input.c    Thu Feb 11 18:20:29 2021 +0100
@@ -559,7 +559,7 @@
 {
        if (ni->ni_challenge == NULL)
                ni->ni_challenge = (uint32_t *)
-                   IEEE80211_ALLOC(IEEE80211_CHALLENGE_LEN,
+                   IEEE80211_MALLOC(IEEE80211_CHALLENGE_LEN,
                      M_80211_NODE, IEEE80211_M_NOWAIT);
        if (ni->ni_challenge == NULL) {
                IEEE80211_NOTE(ni->ni_vap,
diff -r 9284649b6905 -r 7a2116929de8 sys/net80211/ieee80211_node.c
--- a/sys/net80211/ieee80211_node.c     Wed Feb 03 15:20:50 2021 +0100
+++ b/sys/net80211/ieee80211_node.c     Thu Feb 11 18:20:29 2021 +0100
@@ -195,7 +195,7 @@
                            "WARNING: max aid too small, changed to %d\n",
                            vap->iv_max_aid);
                }
-               vap->iv_aid_bitmap = (uint32_t *) IEEE80211_ZALLOC(
+               vap->iv_aid_bitmap = (uint32_t *) IEEE80211_MZALLOC(
                        howmany(vap->iv_max_aid, 32) * sizeof(uint32_t),
                        M_80211_NODE,
                        IEEE80211_M_NOWAIT);
@@ -223,7 +223,7 @@
                vap->iv_bss = NULL;
        }
        if (vap->iv_aid_bitmap != NULL) {
-               IEEE80211_FREE(vap->iv_aid_bitmap, M_80211_NODE,
+               IEEE80211_MFREE(vap->iv_aid_bitmap, M_80211_NODE,
                    howmany(vap->iv_max_aid, 32) * sizeof(uint32_t));
                vap->iv_aid_bitmap = NULL;
        }
@@ -1119,8 +1119,9 @@
 {
        struct ieee80211_node *ni;
 
-       ni = (struct ieee80211_node *) IEEE80211_ZALLOC(sizeof(struct ieee80211_node),
-               M_80211_NODE, IEEE80211_M_NOWAIT);
+       ni = (struct ieee80211_node *) IEEE80211_MZALLOC(
+           sizeof(struct ieee80211_node),
+           M_80211_NODE, IEEE80211_M_NOWAIT);
        return ni;
 }
 
@@ -1296,7 +1297,7 @@
 
        ni->ni_associd = 0;
        if (ni->ni_challenge != NULL) {
-               IEEE80211_FREE(ni->ni_challenge, M_80211_NODE,
+               IEEE80211_MFREE(ni->ni_challenge, M_80211_NODE,
                    IEEE80211_CHALLENGE_LEN);
                ni->ni_challenge = NULL;
        }
@@ -1332,7 +1333,7 @@
        ic->ic_node_cleanup(ni);
        ieee80211_ies_cleanup(&ni->ni_ies);
        ieee80211_psq_cleanup(&ni->ni_psq);
-       IEEE80211_FREE(ni, M_80211_NODE, sizeof(*ni));
+       IEEE80211_MFREE(ni, M_80211_NODE, sizeof(*ni));
 }
 
 static void
@@ -2313,7 +2314,7 @@
        nt->nt_inact_init = inact;
        nt->nt_keyixmax = keyixmax;
        if (nt->nt_keyixmax > 0) {
-               nt->nt_keyixmap = (struct ieee80211_node **)IEEE80211_ZALLOC(
+               nt->nt_keyixmap = (struct ieee80211_node **)IEEE80211_MZALLOC(
                        keyixmax * sizeof(struct ieee80211_node *),
                        M_80211_NODE,
                        IEEE80211_M_NOWAIT);
@@ -2375,7 +2376,7 @@
                                printf("%s: %s[%u] still active\n", __func__,
                                        nt->nt_name, i);
 #endif
-               IEEE80211_FREE(nt->nt_keyixmap, M_80211_NODE,
+               IEEE80211_MFREE(nt->nt_keyixmap, M_80211_NODE,
                    nt->nt_keyixmax * sizeof(struct ieee80211_node *));
                nt->nt_keyixmap = NULL;
        }
@@ -2619,7 +2620,7 @@
                return (0);
        }
        size = count * sizeof(struct ieee80211_node *);
-       ni_arr = (struct ieee80211_node **) IEEE80211_ZALLOC(size,
+       ni_arr = (struct ieee80211_node **) IEEE80211_MZALLOC(size,
            M_80211_NODE, IEEE80211_M_NOWAIT);
        if (ni_arr == NULL) {
                IEEE80211_NODE_UNLOCK(nt);
@@ -2646,7 +2647,7 @@
                ieee80211_free_node(ni_arr[i]);
        }
 
-       IEEE80211_FREE(ni_arr, M_80211_NODE, size);
+       IEEE80211_MFREE(ni_arr, M_80211_NODE, size);
 
        return (0);
 }
diff -r 9284649b6905 -r 7a2116929de8 sys/net80211/ieee80211_sta.c
--- a/sys/net80211/ieee80211_sta.c      Wed Feb 03 15:20:50 2021 +0100
+++ b/sys/net80211/ieee80211_sta.c      Thu Feb 11 18:20:29 2021 +0100
@@ -1118,7 +1118,7 @@
        switch (seq) {
        case IEEE80211_AUTH_SHARED_PASS:
                if (ni->ni_challenge != NULL) {
-                       IEEE80211_FREE(ni->ni_challenge, M_80211_NODE,
+                       IEEE80211_MFREE(ni->ni_challenge, M_80211_NODE,
                            IEEE80211_CHALLENGE_LEN);
                        ni->ni_challenge = NULL;
                }



Home | Main Index | Thread Index | Old Index