wlcore: sdio: check for valid platform device data before suspend
authorEyal Reizer <eyalreizer@gmail.com>
Mon, 28 May 2018 08:36:42 +0000 (11:36 +0300)
committerKalle Valo <kvalo@codeaurora.org>
Tue, 29 May 2018 07:20:56 +0000 (10:20 +0300)
the wl pointer can be null In case only wlcore_sdio is probed while
no WiLink module is successfully probed, as in the case of mounting a
wl12xx module while using a device tree file configured with wl18xx
related settings.
In this case the system was crashing in wl1271_suspend() as platform
device data is not set.
Make sure wl the pointer is valid before using it.

Signed-off-by: Eyal Reizer <eyalr@ti.com>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
drivers/net/wireless/ti/wlcore/sdio.c

index 15d5ac1260616812d23baf3017b7b94b964b54da..750bea3574ee4e994b01f9e49a8046e1afa33211 100644 (file)
@@ -399,6 +399,11 @@ static int wl1271_suspend(struct device *dev)
        mmc_pm_flag_t sdio_flags;
        int ret = 0;
 
+       if (!wl) {
+               dev_err(dev, "no wilink module was probed\n");
+               goto out;
+       }
+
        dev_dbg(dev, "wl1271 suspend. wow_enabled: %d\n",
                wl->wow_enabled);