OSDN Git Service

b43legacy: fix unitialized reads of ret by initializing the array to zero
authorColin Ian King <colin.king@canonical.com>
Tue, 5 Sep 2017 18:16:58 +0000 (19:16 +0100)
committerKalle Valo <kvalo@codeaurora.org>
Wed, 20 Sep 2017 12:41:08 +0000 (15:41 +0300)
The u8 char array ret is not being initialized and elements outside
the range start to end contain just garbage values from the stack.
This results in a later scan of the array to read potentially
uninitialized values.  Fix this by initializing the array to zero.
This seems to have been an issue since the very first commit.

Detected by CoverityScan CID#139653 ("Uninitialized scalar variable")

Signed-off-by: Colin Ian King <colin.king@canonical.com>
Reviewed-by: Michael Buesch <m@bues.ch>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
drivers/net/wireless/broadcom/b43legacy/radio.c

index 9501420..eab1c93 100644 (file)
@@ -280,7 +280,7 @@ u8 b43legacy_radio_aci_detect(struct b43legacy_wldev *dev, u8 channel)
 u8 b43legacy_radio_aci_scan(struct b43legacy_wldev *dev)
 {
        struct b43legacy_phy *phy = &dev->phy;
-       u8 ret[13];
+       u8 ret[13] = { 0 };
        unsigned int channel = phy->channel;
        unsigned int i;
        unsigned int j;