brcmfmac: return error when getting invalid max_flowrings from dongle
authorWright Feng <wright.feng@cypress.com>
Thu, 29 Sep 2022 03:10:00 +0000 (22:10 -0500)
committerKalle Valo <kvalo@kernel.org>
Tue, 4 Oct 2022 08:28:28 +0000 (11:28 +0300)
When firmware hit trap at initialization, host will read abnormal
max_flowrings number from dongle, and it will cause kernel panic when
doing iowrite to initialize dongle ring.
To detect this error at early stage, we directly return error when getting
invalid max_flowrings(>256).

Signed-off-by: Wright Feng <wright.feng@cypress.com>
Signed-off-by: Chi-hsien Lin <chi-hsien.lin@cypress.com>
Signed-off-by: Ian Lin <ian.lin@infineon.com>
Signed-off-by: Kalle Valo <kvalo@kernel.org>
Link: https://lore.kernel.org/r/20220929031001.9962-3-ian.lin@infineon.com
drivers/net/wireless/broadcom/brcm80211/brcmfmac/pcie.c

index 2b7ebbd..1becd50 100644 (file)
@@ -1228,6 +1228,10 @@ static int brcmf_pcie_init_ringbuffers(struct brcmf_pciedev_info *devinfo)
                                BRCMF_NROF_H2D_COMMON_MSGRINGS;
                max_completionrings = BRCMF_NROF_D2H_COMMON_MSGRINGS;
        }
+       if (max_flowrings > 256) {
+               brcmf_err(bus, "invalid max_flowrings(%d)\n", max_flowrings);
+               return -EIO;
+       }
 
        if (devinfo->dma_idx_sz != 0) {
                bufsz = (max_submissionrings + max_completionrings) *