aboutsummaryrefslogtreecommitdiffstats
path: root/package/kernel/mac80211/patches/318-v4.11-0001-brcmfmac-check-brcmf_bus_get_memdump-result-for-erro.patch
diff options
context:
space:
mode:
authorRafał Miłecki <rafal@milecki.pl>2018-08-16 09:15:12 +0200
committerRafał Miłecki <rafal@milecki.pl>2018-08-16 09:48:24 +0200
commit85e6ac468efc980ef89149dcbab23e492ece8e97 (patch)
treea4b6c0c5452d1eed5e6001ccc4bf9b7d34dd6e31 /package/kernel/mac80211/patches/318-v4.11-0001-brcmfmac-check-brcmf_bus_get_memdump-result-for-erro.patch
parentd3b8b5be3455d734e5681f98f22e5705dfe02ba4 (diff)
downloadupstream-85e6ac468efc980ef89149dcbab23e492ece8e97.tar.gz
upstream-85e6ac468efc980ef89149dcbab23e492ece8e97.tar.bz2
upstream-85e6ac468efc980ef89149dcbab23e492ece8e97.zip
mac80211: brcmfmac: group 4.11 backport patches
Signed-off-by: Rafał Miłecki <rafal@milecki.pl>
Diffstat (limited to 'package/kernel/mac80211/patches/318-v4.11-0001-brcmfmac-check-brcmf_bus_get_memdump-result-for-erro.patch')
-rw-r--r--package/kernel/mac80211/patches/318-v4.11-0001-brcmfmac-check-brcmf_bus_get_memdump-result-for-erro.patch52
1 files changed, 52 insertions, 0 deletions
diff --git a/package/kernel/mac80211/patches/318-v4.11-0001-brcmfmac-check-brcmf_bus_get_memdump-result-for-erro.patch b/package/kernel/mac80211/patches/318-v4.11-0001-brcmfmac-check-brcmf_bus_get_memdump-result-for-erro.patch
new file mode 100644
index 0000000000..4ae4c606c5
--- /dev/null
+++ b/package/kernel/mac80211/patches/318-v4.11-0001-brcmfmac-check-brcmf_bus_get_memdump-result-for-erro.patch
@@ -0,0 +1,52 @@
+From: =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= <rafal@milecki.pl>
+Date: Mon, 30 Jan 2017 16:09:51 +0100
+Subject: [PATCH] brcmfmac: check brcmf_bus_get_memdump result for error
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+This method may be unsupported (see: USB bus) or may just fail (see:
+SDIO bus).
+While at it rework logic in brcmf_sdio_bus_get_memdump function to avoid
+too many conditional code nesting levels.
+
+Signed-off-by: Rafał Miłecki <rafal@milecki.pl>
+Acked-by: Arend van Spriel <arend.vanspriel@broadcom.com>
+Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
+---
+
+--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/debug.c
++++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/debug.c
+@@ -32,16 +32,25 @@ static int brcmf_debug_create_memdump(st
+ {
+ void *dump;
+ size_t ramsize;
++ int err;
+
+ ramsize = brcmf_bus_get_ramsize(bus);
+- if (ramsize) {
+- dump = vzalloc(len + ramsize);
+- if (!dump)
+- return -ENOMEM;
+- memcpy(dump, data, len);
+- brcmf_bus_get_memdump(bus, dump + len, ramsize);
+- dev_coredumpv(bus->dev, dump, len + ramsize, GFP_KERNEL);
++ if (!ramsize)
++ return -ENOTSUPP;
++
++ dump = vzalloc(len + ramsize);
++ if (!dump)
++ return -ENOMEM;
++
++ memcpy(dump, data, len);
++ err = brcmf_bus_get_memdump(bus, dump + len, ramsize);
++ if (err) {
++ vfree(dump);
++ return err;
+ }
++
++ dev_coredumpv(bus->dev, dump, len + ramsize, GFP_KERNEL);
++
+ return 0;
+ }
+