Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src-draft/trunk]: src/sys/net80211 Do not use malloc(9) directly, abstract v...
details:   https://anonhg.NetBSD.org/src-all/rev/444a3e858177
branches:  trunk
changeset: 375639:444a3e858177
user:      Martin Husemann <martin%NetBSD.org@localhost>
date:      Thu Dec 10 18:26:08 2020 +0100
description:
Do not use malloc(9) directly, abstract various uses.
In the process of removing all malloc(9) calls, separate the various
different uses and map them via macros to different functions depending
on context.
Move a few more calls to thread context by changing timeout processing
from a callout to a taskqueue.
diffstat:
 sys/net80211/ieee80211.c              |   7 +--
 sys/net80211/ieee80211_acl.c          |  19 ++++----
 sys/net80211/ieee80211_action.c       |   1 -
 sys/net80211/ieee80211_adhoc.c        |   1 -
 sys/net80211/ieee80211_ageq.c         |   1 -
 sys/net80211/ieee80211_alq.c          |   1 -
 sys/net80211/ieee80211_amrr.c         |  16 ++++---
 sys/net80211/ieee80211_crypto.c       |   6 ++-
 sys/net80211/ieee80211_crypto.h       |   6 ++
 sys/net80211/ieee80211_crypto_ccmp.c  |  35 +++++++++++++-
 sys/net80211/ieee80211_crypto_none.c  |   1 -
 sys/net80211/ieee80211_crypto_tkip.c  |  35 +++++++++++++-
 sys/net80211/ieee80211_crypto_wep.c   |  35 +++++++++++++-
 sys/net80211/ieee80211_ddb.c          |   1 -
 sys/net80211/ieee80211_dfs.c          |   1 -
 sys/net80211/ieee80211_hostap.c       |   7 +-
 sys/net80211/ieee80211_ht.c           |   1 -
 sys/net80211/ieee80211_hwmp.c         |  35 ++++++++------
 sys/net80211/ieee80211_input.c        |   3 +-
 sys/net80211/ieee80211_ioctl.c        |  78 ++++++++++++++++++----------------
 sys/net80211/ieee80211_mesh.c         |  29 ++++++------
 sys/net80211/ieee80211_monitor.c      |   1 -
 sys/net80211/ieee80211_netbsd.c       |   6 +--
 sys/net80211/ieee80211_netbsd.h       |  57 +++++++++++++++++++++----
 sys/net80211/ieee80211_node.c         |  61 ++++++++++++++-------------
 sys/net80211/ieee80211_node.h         |   2 +-
 sys/net80211/ieee80211_output.c       |   4 +-
 sys/net80211/ieee80211_phy.c          |   1 -
 sys/net80211/ieee80211_power.c        |   8 +-
 sys/net80211/ieee80211_proto.c        |   4 +-
 sys/net80211/ieee80211_radiotap.c     |   1 -
 sys/net80211/ieee80211_ratectl.c      |   1 -
 sys/net80211/ieee80211_ratectl_none.c |   5 +-
 sys/net80211/ieee80211_regdomain.c    |  11 ++--
 sys/net80211/ieee80211_rssadapt.c     |  15 +++---
 sys/net80211/ieee80211_scan.c         |   1 -
 sys/net80211/ieee80211_scan_sta.c     |  47 +++++++++++++++++----
 sys/net80211/ieee80211_scan_sw.c      |  20 +++-----
 sys/net80211/ieee80211_sta.c          |   4 +-
 sys/net80211/ieee80211_superg.c       |   6 +-
 sys/net80211/ieee80211_tdma.c         |   7 +-
 sys/net80211/ieee80211_var.h          |   4 +-
 sys/net80211/ieee80211_vht.c          |   1 -
 sys/net80211/ieee80211_wds.c          |   1 -
 sys/net80211/ieee80211_xauth.c        |   1 -
 45 files changed, 369 insertions(+), 219 deletions(-)
diffs (truncated from 1960 to 300 lines):
diff -r 5aebcf00e915 -r 444a3e858177 sys/net80211/ieee80211.c
--- a/sys/net80211/ieee80211.c  Thu Dec 10 18:22:42 2020 +0100
+++ b/sys/net80211/ieee80211.c  Thu Dec 10 18:26:08 2020 +0100
@@ -45,7 +45,6 @@
 #include <sys/param.h>
 #include <sys/systm.h>
 #include <sys/kernel.h>
-#include <sys/malloc.h>
 #include <sys/socket.h>
 #include <sys/sbuf.h>
 #include <sys/cprng.h>
@@ -488,9 +487,7 @@ ieee80211_ifdetach(struct ieee80211com *
        LIST_REMOVE(ic, ic_next);
        mtx_unlock(&ic_list_mtx);
 
-#if __FreeBSD__        
-       taskqueue_drain(taskqueue_thread, &ic->ic_restart_task);
-#endif
+       taskqueue_drain(ic->ic_tq, &ic->ic_restart_task);
 
        /*
         * The VAP is responsible for setting and clearing
@@ -517,7 +514,7 @@ ieee80211_ifdetach(struct ieee80211com *
        ieee80211_power_detach(ic);
        ieee80211_node_detach(ic);
 
-#if __FreeBSD__        
+#if __FreeBSD__
        counter_u64_free(ic->ic_ierrors);
        counter_u64_free(ic->ic_oerrors);
 #endif
diff -r 5aebcf00e915 -r 444a3e858177 sys/net80211/ieee80211_acl.c
--- a/sys/net80211/ieee80211_acl.c      Thu Dec 10 18:22:42 2020 +0100
+++ b/sys/net80211/ieee80211_acl.c      Thu Dec 10 18:26:08 2020 +0100
@@ -53,7 +53,6 @@
 #include <sys/param.h>
 #include <sys/kernel.h>
 #include <sys/systm.h> 
-#include <sys/malloc.h>   
 #include <sys/mbuf.h>   
 #include <sys/module.h>
 #include <sys/queue.h>
@@ -117,8 +116,8 @@ acl_attach(struct ieee80211vap *vap)
 {
        struct aclstate *as;
 
-       as = (struct aclstate *) IEEE80211_MALLOC(sizeof(struct aclstate),
-               M_80211_ACL, IEEE80211_M_NOWAIT | IEEE80211_M_ZERO);
+       as = (struct aclstate *) IEEE80211_ZALLOC(sizeof(struct aclstate),
+               M_80211_ACL, IEEE80211_M_NOWAIT);
        if (as == NULL)
                return 0;
        ACL_LOCK_INIT(as, "acl");
@@ -141,7 +140,7 @@ acl_detach(struct ieee80211vap *vap)
        acl_free_all(vap);
        vap->iv_as = NULL;
        ACL_LOCK_DESTROY(as);
-       IEEE80211_FREE(as, M_80211_ACL);
+       IEEE80211_FREE(as, M_80211_ACL, sizeof(*as));
 }
 
 static __inline struct acl *
@@ -165,7 +164,7 @@ static void
 
        TAILQ_REMOVE(&as->as_list, acl, acl_list);
        LIST_REMOVE(acl, acl_hash);
-       IEEE80211_FREE(acl, M_80211_ACL);
+       IEEE80211_FREE(acl, M_80211_ACL, sizeof(*acl));
        as->as_nacls--;
 }
 
@@ -193,8 +192,8 @@ acl_add(struct ieee80211vap *vap, const 
        struct acl *acl, *new;
        int hash;
 
-       new = (struct acl *) IEEE80211_MALLOC(sizeof(struct acl),
-           M_80211_ACL, IEEE80211_M_NOWAIT | IEEE80211_M_ZERO);
+       new = (struct acl *) IEEE80211_ZALLOC(sizeof(struct acl),
+           M_80211_ACL, IEEE80211_M_NOWAIT);
        if (new == NULL) {
                IEEE80211_DPRINTF(vap, IEEE80211_MSG_ACL,
                        "ACL: add %s failed, no memory\n", ether_sprintf(mac));
@@ -207,7 +206,7 @@ acl_add(struct ieee80211vap *vap, const 
        LIST_FOREACH(acl, &as->as_hash[hash], acl_hash) {
                if (IEEE80211_ADDR_EQ(acl->acl_macaddr, mac)) {
                        ACL_UNLOCK(as);
-                       IEEE80211_FREE(new, M_80211_ACL);
+                       IEEE80211_FREE(new, M_80211_ACL, sizeof(*new));
                        IEEE80211_DPRINTF(vap, IEEE80211_MSG_ACL,
                                "ACL: add %s failed, already present\n",
                                ether_sprintf(mac));
@@ -321,7 +320,7 @@ acl_getioctl(struct ieee80211vap *vap, s
                        ireq->i_len = space;    /* return required space */
                        return 0;               /* NB: must not error */
                }
-               ap = (struct ieee80211req_maclist *) IEEE80211_MALLOC(space,
+               ap = (struct ieee80211req_maclist *) IEEE80211_ALLOC(space,
                    M_TEMP, IEEE80211_M_NOWAIT);
                if (ap == NULL)
                        return ENOMEM;
@@ -337,7 +336,7 @@ acl_getioctl(struct ieee80211vap *vap, s
                        ireq->i_len = space;
                } else
                        error = copyout(ap, ireq->i_data, ireq->i_len);
-               IEEE80211_FREE(ap, M_TEMP);
+               IEEE80211_FREE(ap, M_TEMP, space);
                return error;
        }
        return EINVAL;
diff -r 5aebcf00e915 -r 444a3e858177 sys/net80211/ieee80211_action.c
--- a/sys/net80211/ieee80211_action.c   Thu Dec 10 18:22:42 2020 +0100
+++ b/sys/net80211/ieee80211_action.c   Thu Dec 10 18:26:08 2020 +0100
@@ -46,7 +46,6 @@
 
 #include <sys/param.h>
 #include <sys/kernel.h>
-#include <sys/malloc.h>
 #include <sys/systm.h> 
  
 #include <sys/socket.h>
diff -r 5aebcf00e915 -r 444a3e858177 sys/net80211/ieee80211_adhoc.c
--- a/sys/net80211/ieee80211_adhoc.c    Thu Dec 10 18:22:42 2020 +0100
+++ b/sys/net80211/ieee80211_adhoc.c    Thu Dec 10 18:26:08 2020 +0100
@@ -46,7 +46,6 @@
 #include <sys/param.h>
 #include <sys/systm.h> 
 #include <sys/mbuf.h>   
-#include <sys/malloc.h>
 #include <sys/kernel.h>
 
 #include <sys/socket.h>
diff -r 5aebcf00e915 -r 444a3e858177 sys/net80211/ieee80211_ageq.c
--- a/sys/net80211/ieee80211_ageq.c     Thu Dec 10 18:22:42 2020 +0100
+++ b/sys/net80211/ieee80211_ageq.c     Thu Dec 10 18:26:08 2020 +0100
@@ -45,7 +45,6 @@
 #include <sys/param.h>
 #include <sys/systm.h> 
 #include <sys/kernel.h>
-#include <sys/malloc.h>
 #ifdef __NetBSD__
 #include <sys/mbuf.h>
 #endif
diff -r 5aebcf00e915 -r 444a3e858177 sys/net80211/ieee80211_alq.c
--- a/sys/net80211/ieee80211_alq.c      Thu Dec 10 18:22:42 2020 +0100
+++ b/sys/net80211/ieee80211_alq.c      Thu Dec 10 18:26:08 2020 +0100
@@ -49,7 +49,6 @@
 #include <sys/param.h>
 #include <sys/systm.h>
 #include <sys/mbuf.h>
-#include <sys/malloc.h>
 #include <sys/endian.h>
 #include <sys/kernel.h>
 #include <sys/sysctl.h>
diff -r 5aebcf00e915 -r 444a3e858177 sys/net80211/ieee80211_amrr.c
--- a/sys/net80211/ieee80211_amrr.c     Thu Dec 10 18:22:42 2020 +0100
+++ b/sys/net80211/ieee80211_amrr.c     Thu Dec 10 18:26:08 2020 +0100
@@ -43,7 +43,6 @@
 
 #include <sys/param.h>
 #include <sys/kernel.h>
-#include <sys/malloc.h>
 #include <sys/module.h>
 #include <sys/sbuf.h>
 #include <sys/socket.h>
@@ -147,8 +146,8 @@ amrr_init(struct ieee80211vap *vap)
        KASSERTMSG(vap->iv_rs == NULL, "%s called multiple times", __func__);
 
        nrefs++;                /* XXX locking */
-       amrr = vap->iv_rs = IEEE80211_MALLOC(sizeof(struct ieee80211_amrr),
-           M_80211_RATECTL, IEEE80211_M_NOWAIT | IEEE80211_M_ZERO);
+       amrr = vap->iv_rs = IEEE80211_ZALLOC(sizeof(struct ieee80211_amrr),
+           M_80211_RATECTL, IEEE80211_M_NOWAIT);
        if (amrr == NULL) {
                if_printf(vap->iv_ifp, "couldn't alloc ratectl structure\n");
                return;
@@ -164,7 +163,8 @@ amrr_init(struct ieee80211vap *vap)
 static void
 amrr_deinit(struct ieee80211vap *vap)
 {
-       IEEE80211_FREE(vap->iv_rs, M_80211_RATECTL);
+       IEEE80211_FREE(vap->iv_rs, M_80211_RATECTL,
+           sizeof(struct ieee80211_amrr));
        KASSERTMSG(nrefs > 0, "imbalanced attach/detach");
        nrefs--;                /* XXX locking */
 }
@@ -204,8 +204,9 @@ amrr_node_init(struct ieee80211_node *ni
        }
 
        if (ni->ni_rctls == NULL) {
-               ni->ni_rctls = amn = IEEE80211_MALLOC(sizeof(struct ieee80211_amrr_node),
-                   M_80211_RATECTL, IEEE80211_M_NOWAIT | IEEE80211_M_ZERO);
+               ni->ni_rctls = amn = IEEE80211_ZALLOC(
+                   sizeof(struct ieee80211_amrr_node),
+                   M_80211_RATECTL, IEEE80211_M_NOWAIT);
                if (amn == NULL) {
                        if_printf(vap->iv_ifp, "couldn't alloc per-node ratectl "
                            "structure\n");
@@ -272,7 +273,8 @@ amrr_node_init(struct ieee80211_node *ni
 static void
 amrr_node_deinit(struct ieee80211_node *ni)
 {
-       IEEE80211_FREE(ni->ni_rctls, M_80211_RATECTL);
+       IEEE80211_FREE(ni->ni_rctls, M_80211_RATECTL,
+           sizeof(struct ieee80211_amrr_node));
 }
 
 static int
diff -r 5aebcf00e915 -r 444a3e858177 sys/net80211/ieee80211_crypto.c
--- a/sys/net80211/ieee80211_crypto.c   Thu Dec 10 18:22:42 2020 +0100
+++ b/sys/net80211/ieee80211_crypto.c   Thu Dec 10 18:26:08 2020 +0100
@@ -46,7 +46,6 @@
  */
 #include <sys/param.h>
 #include <sys/kernel.h>
-#include <sys/malloc.h>
 #include <sys/mbuf.h>
 
 #include <sys/socket.h>
@@ -63,7 +62,9 @@
 
 #include <net80211/ieee80211_var.h>
 
+#if __FreeBSD__
 MALLOC_DEFINE(M_80211_CRYPTO, "80211crypto", "802.11 crypto state");
+#endif
 
 static int _ieee80211_crypto_delkey(struct ieee80211vap *,
                struct ieee80211_key *);
@@ -122,11 +123,13 @@ cipher_detach(struct ieee80211_key *key)
        key->wk_cipher->ic_detach(key);
 }
 
+#if 0
 static __inline void *
 cipher_attach(struct ieee80211vap *vap, struct ieee80211_key *key)
 {
        return key->wk_cipher->ic_attach(vap, key);
 }
+#endif
 
 /* 
  * Wrappers for driver key management methods.
@@ -291,6 +294,7 @@ ieee80211_crypto_newkey(struct ieee80211
        void *keyctx;
        int oflags;
 
+       KASSERT(!cpu_intr_p());
        IEEE80211_DPRINTF(vap, IEEE80211_MSG_CRYPTO,
            "%s: cipher %u flags 0x%x keyix %u\n",
            __func__, cipher, flags, key->wk_keyix);
diff -r 5aebcf00e915 -r 444a3e858177 sys/net80211/ieee80211_crypto.h
--- a/sys/net80211/ieee80211_crypto.h   Thu Dec 10 18:22:42 2020 +0100
+++ b/sys/net80211/ieee80211_crypto.h   Thu Dec 10 18:26:08 2020 +0100
@@ -162,7 +162,13 @@ struct ieee80211vap;
 struct ieee80211_node;
 struct mbuf;
 
+#if __FreeBSD__
+#include <net80211/ieee80211_freebsd.h>
 MALLOC_DECLARE(M_80211_CRYPTO);
+#define        M_80211_CRYPTO_CCMP     M_80211_CRYPTO
+#define        M_80211_CRYPTO_TKIP     M_80211_CRYPTO
+#define        M_80211_CRYPTO_WEP      M_80211_CRYPTO
+#endif
 
 void   ieee80211_crypto_attach(struct ieee80211com *);
 void   ieee80211_crypto_detach(struct ieee80211com *);
diff -r 5aebcf00e915 -r 444a3e858177 sys/net80211/ieee80211_crypto_ccmp.c
--- a/sys/net80211/ieee80211_crypto_ccmp.c      Thu Dec 10 18:22:42 2020 +0100
+++ b/sys/net80211/ieee80211_crypto_ccmp.c      Thu Dec 10 18:26:08 2020 +0100
@@ -49,7 +49,6 @@
 #include <sys/param.h>
 #include <sys/systm.h> 
 #include <sys/mbuf.h>   
-#include <sys/malloc.h>
 #include <sys/kernel.h>
 #include <sys/module.h>
 
@@ -63,6 +62,8 @@
 #ifdef __NetBSD__
 #include <net/route.h>
 #include <net/if_ether.h>
+#include <sys/once.h>
+#include <sys/cpu.h>
 #endif
 
 #include <net80211/ieee80211_var.h>
@@ -73,6 +74,11 @@
 
 #define AES_BLOCK_LEN 16
 
+#if 0 // __NetBSD__
+static pool_cache_t ieee80211_ccmp_ctx_pool;
+#define M_80211_CRYPTO_CCMP    ieee80211_ccmp_ctx_pool
+#endif
+
 struct ccmp_ctx {
        struct aesenc        cc_aes;
        struct ieee80211vap *cc_vap;    /* for diagnostics+statistics */
@@ -112,13 +118,34 @@ static    int ccmp_decrypt(struct ieee80211
Home |
Main Index |
Thread Index |
Old Index