Source-Changes-HG archive

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

[src/trunk]: src/sys/dev discussed with thorpej@, and it seems it's better to...



details:   https://anonhg.NetBSD.org/src/rev/74b47c42cc17
branches:  trunk
changeset: 1010605:74b47c42cc17
user:      jdolecek <jdolecek%NetBSD.org@localhost>
date:      Sat May 30 15:55:47 2020 +0000

description:
discussed with thorpej@, and it seems it's better to allocate the bss
alignment buffer statically (as part of softc) just to be sure to not
affect performance

diffstat:

 sys/dev/ic/bwfm.c            |  18 ++++++------------
 sys/dev/ic/bwfmvar.h         |   7 ++++++-
 sys/dev/pci/if_bwfm_pci.c    |   4 ++--
 sys/dev/sdmmc/if_bwfm_sdio.c |   4 ++--
 4 files changed, 16 insertions(+), 17 deletions(-)

diffs (101 lines):

diff -r 892d0570fd88 -r 74b47c42cc17 sys/dev/ic/bwfm.c
--- a/sys/dev/ic/bwfm.c Sat May 30 14:16:56 2020 +0000
+++ b/sys/dev/ic/bwfm.c Sat May 30 15:55:47 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: bwfm.c,v 1.24 2020/05/30 14:03:08 jdolecek Exp $ */
+/* $NetBSD: bwfm.c,v 1.25 2020/05/30 15:55:47 jdolecek Exp $ */
 /* $OpenBSD: bwfm.c,v 1.5 2017/10/16 22:27:16 patrick Exp $ */
 /*
  * Copyright (c) 2010-2016 Broadcom Corporation
@@ -38,8 +38,8 @@
 
 #include <net80211/ieee80211_var.h>
 
+#include <dev/ic/bwfmreg.h>
 #include <dev/ic/bwfmvar.h>
-#include <dev/ic/bwfmreg.h>
 
 /* #define BWFM_DEBUG */
 #ifdef BWFM_DEBUG
@@ -2140,18 +2140,12 @@
                bss = &res->bss_info[0];
                for (i = 0; i < le16toh(res->bss_count); i++) {
                        /* Fix alignment of bss_info */
-                       union {
-                               struct bwfm_bss_info bss_info;
-                               uint8_t padding[BWFM_BSS_INFO_BUFLEN];
-                       } *bss_buf;
-                       if (len > sizeof(*bss_buf)) {
+                       if (len > sizeof(sc->sc_bss_buf)) {
                                printf("%s: bss_info buffer too big\n", DEVNAME(sc));
                        } else {
-                               bss_buf = kmem_alloc(sizeof(*bss_buf),
-                                   KM_SLEEP);
-                               memcpy(bss_buf, &res->bss_info[i], len);
-                               bwfm_scan_node(sc, &bss_buf->bss_info, len);
-                               kmem_free(bss_buf, sizeof(*bss_buf));
+                               memcpy(&sc->sc_bss_buf, &res->bss_info[i], len);
+                               bwfm_scan_node(sc, &sc->sc_bss_buf.bss_info,
+                                   len);
                        }
                        len -= sizeof(*bss) + le32toh(bss->length);
                        bss = (void *)(((uintptr_t)bss) + le32toh(bss->length));
diff -r 892d0570fd88 -r 74b47c42cc17 sys/dev/ic/bwfmvar.h
--- a/sys/dev/ic/bwfmvar.h      Sat May 30 14:16:56 2020 +0000
+++ b/sys/dev/ic/bwfmvar.h      Sat May 30 15:55:47 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: bwfmvar.h,v 1.9 2020/05/30 13:41:58 jdolecek Exp $ */
+/* $NetBSD: bwfmvar.h,v 1.10 2020/05/30 15:55:47 jdolecek Exp $ */
 /* $OpenBSD: bwfmvar.h,v 1.1 2017/10/11 17:19:50 patrick Exp $ */
 /*
  * Copyright (c) 2010-2016 Broadcom Corporation
@@ -214,6 +214,11 @@
                                    enum ieee80211_state, int);
 
        int                      sc_bcdc_reqid;
+
+       union {
+               struct bwfm_bss_info bss_info;
+               uint8_t padding[BWFM_BSS_INFO_BUFLEN];
+       }                       sc_bss_buf;
 };
 
 void bwfm_attach(struct bwfm_softc *);
diff -r 892d0570fd88 -r 74b47c42cc17 sys/dev/pci/if_bwfm_pci.c
--- a/sys/dev/pci/if_bwfm_pci.c Sat May 30 14:16:56 2020 +0000
+++ b/sys/dev/pci/if_bwfm_pci.c Sat May 30 15:55:47 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_bwfm_pci.c,v 1.8 2020/05/30 13:41:58 jdolecek Exp $ */
+/*     $NetBSD: if_bwfm_pci.c,v 1.9 2020/05/30 15:55:47 jdolecek Exp $ */
 /*     $OpenBSD: if_bwfm_pci.c,v 1.18 2018/02/08 05:00:38 patrick Exp $        */
 /*
  * Copyright (c) 2010-2016 Broadcom Corporation
@@ -41,8 +41,8 @@
 #include <dev/pci/pcivar.h>
 #include <dev/pci/pcidevs.h>
 
+#include <dev/ic/bwfmreg.h>
 #include <dev/ic/bwfmvar.h>
-#include <dev/ic/bwfmreg.h>
 #include <dev/pci/if_bwfm_pci.h>
 
 #define BWFM_DMA_D2H_SCRATCH_BUF_LEN           8
diff -r 892d0570fd88 -r 74b47c42cc17 sys/dev/sdmmc/if_bwfm_sdio.c
--- a/sys/dev/sdmmc/if_bwfm_sdio.c      Sat May 30 14:16:56 2020 +0000
+++ b/sys/dev/sdmmc/if_bwfm_sdio.c      Sat May 30 15:55:47 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_bwfm_sdio.c,v 1.17 2020/05/30 13:41:58 jdolecek Exp $ */
+/* $NetBSD: if_bwfm_sdio.c,v 1.18 2020/05/30 15:55:47 jdolecek Exp $ */
 /* $OpenBSD: if_bwfm_sdio.c,v 1.1 2017/10/11 17:19:50 patrick Exp $ */
 /*
  * Copyright (c) 2010-2016 Broadcom Corporation
@@ -44,8 +44,8 @@
 #include <dev/sdmmc/sdmmcdevs.h>
 #include <dev/sdmmc/sdmmcvar.h>
 
+#include <dev/ic/bwfmreg.h>
 #include <dev/ic/bwfmvar.h>
-#include <dev/ic/bwfmreg.h>
 #include <dev/sdmmc/if_bwfm_sdio.h>
 
 #ifdef BWFM_DEBUG



Home | Main Index | Thread Index | Old Index