Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/ic reduce stack usage in bwfm_rx_event_cb(), can use...
details: https://anonhg.NetBSD.org/src/rev/32d86294d6e8
branches: trunk
changeset: 972567:32d86294d6e8
user: jdolecek <jdolecek%NetBSD.org@localhost>
date: Sat May 30 14:03:08 2020 +0000
description:
reduce stack usage in bwfm_rx_event_cb(), can use KM_SLEEP because
this is called from workqueue handler (i.e. thread context)
diffstat:
sys/dev/ic/bwfm.c | 13 ++++++++-----
1 files changed, 8 insertions(+), 5 deletions(-)
diffs (29 lines):
diff -r e72b2ae49fe2 -r 32d86294d6e8 sys/dev/ic/bwfm.c
--- a/sys/dev/ic/bwfm.c Sat May 30 13:41:58 2020 +0000
+++ b/sys/dev/ic/bwfm.c Sat May 30 14:03:08 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: bwfm.c,v 1.23 2020/05/30 13:41:58 jdolecek Exp $ */
+/* $NetBSD: bwfm.c,v 1.24 2020/05/30 14:03:08 jdolecek Exp $ */
/* $OpenBSD: bwfm.c,v 1.5 2017/10/16 22:27:16 patrick Exp $ */
/*
* Copyright (c) 2010-2016 Broadcom Corporation
@@ -2143,12 +2143,15 @@
union {
struct bwfm_bss_info bss_info;
uint8_t padding[BWFM_BSS_INFO_BUFLEN];
- } bss_buf;
- if (len > sizeof(bss_buf)) {
+ } *bss_buf;
+ if (len > sizeof(*bss_buf)) {
printf("%s: bss_info buffer too big\n", DEVNAME(sc));
} else {
- memcpy(&bss_buf, &res->bss_info[i], len);
- bwfm_scan_node(sc, &bss_buf.bss_info, len);
+ 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));
}
len -= sizeof(*bss) + le32toh(bss->length);
bss = (void *)(((uintptr_t)bss) + le32toh(bss->length));
Home |
Main Index |
Thread Index |
Old Index