staging/wilc1000: unify device pointer
authorArnd Bergmann <arnd@arndb.de>
Mon, 16 Nov 2015 14:05:01 +0000 (15:05 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 18 Dec 2015 22:19:20 +0000 (14:19 -0800)
struct wilc has two pointers to store the device, one for sdio_func
and one for spi_device. By changing the pointer to a 'struct device',
we can simplify the logic and avoid a few #ifdefs.

Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/wilc1000/linux_wlan.c
drivers/staging/wilc1000/linux_wlan_sdio.c
drivers/staging/wilc1000/linux_wlan_spi.c
drivers/staging/wilc1000/wilc_wfi_netdevice.h

index 876bcfb3b5462a7911032847b9256333db6bb7f0..faad01f6f2d115f94ac8bf720d85c92c21eec33d 100644 (file)
@@ -453,19 +453,11 @@ int wilc_wlan_get_firmware(struct net_device *dev)
                goto _fail_;
        }
 
-#ifdef WILC_SDIO
-       if (request_firmware(&wilc_firmware, firmware, &wilc->wilc_sdio_func->dev) != 0) {
-               PRINT_ER("%s - firmare not available\n", firmware);
-               ret = -1;
-               goto _fail_;
-       }
-#else
-       if (request_firmware(&wilc_firmware, firmware, &wilc->wilc_spidev->dev) != 0) {
+       if (request_firmware(&wilc_firmware, firmware, wilc->dev) != 0) {
                PRINT_ER("%s - firmare not available\n", firmware);
                ret = -1;
                goto _fail_;
        }
-#endif
        wilc->firmware = wilc_firmware;
 
 _fail_:
@@ -1015,12 +1007,11 @@ int wilc_mac_open(struct net_device *ndev)
        nic = netdev_priv(ndev);
        wl = nic->wilc;
 
-#ifdef WILC_SPI
-       if (!wl || !wl->wilc_spidev) {
+       if (!wl|| !wl->dev) {
                netdev_err(ndev, "wilc1000: SPI device not ready\n");
                return -ENODEV;
        }
-#endif
+
        nic = netdev_priv(ndev);
        priv = wiphy_priv(nic->wilc_netdev->ieee80211_ptr->wiphy);
        PRINT_D(INIT_DBG, "MAC OPEN[%p]\n", ndev);
@@ -1505,15 +1496,5 @@ int wilc_netdev_init(struct wilc **wilc)
                nic->mac_opened = 0;
        }
 
-       #ifndef WILC_SDIO
-       if (!wilc_spi_init()) {
-               PRINT_ER("Can't initialize SPI\n");
-               return -1;
-       }
-       wilc_dev->wilc_spidev = wilc_spi_dev;
-       #else
-       wilc_dev->wilc_sdio_func = wilc_sdio_func;
-       #endif
-
        return 0;
 }
index 06fd0e600c2a99053ca229492a4ede5af9222c54..8df69b2aff2d65b4009cc00f27c431e1c3bc9145 100644 (file)
  #define MAX_SPEED (6 * 1000000) /* Max 50M */
 #endif
 
-struct wilc_sdio {
-       struct sdio_func *func;
-       struct wilc *wilc;
-};
-
 struct sdio_func *wilc_sdio_func;
-
 static unsigned int sdio_default_speed;
 
 #define SDIO_VENDOR_ID_WILC 0x0296
@@ -42,12 +36,8 @@ static const struct sdio_device_id wilc_sdio_ids[] = {
 #ifndef WILC_SDIO_IRQ_GPIO
 static void wilc_sdio_interrupt(struct sdio_func *func)
 {
-       struct wilc_sdio *wl_sdio;
-
-       wl_sdio = sdio_get_drvdata(func);
-
        sdio_release_host(func);
-       wilc_handle_isr(wl_sdio->wilc);
+       wilc_handle_isr(sdio_get_drvdata(func));
        sdio_claim_host(func);
 }
 #endif
@@ -55,7 +45,7 @@ static void wilc_sdio_interrupt(struct sdio_func *func)
 
 int wilc_sdio_cmd52(sdio_cmd52_t *cmd)
 {
-       struct sdio_func *func = wilc_dev->wilc_sdio_func;
+       struct sdio_func *func = container_of(wilc_dev->dev, struct sdio_func, dev);
        int ret;
        u8 data;
 
@@ -87,7 +77,7 @@ int wilc_sdio_cmd52(sdio_cmd52_t *cmd)
 
 int wilc_sdio_cmd53(sdio_cmd53_t *cmd)
 {
-       struct sdio_func *func = wilc_dev->wilc_sdio_func;
+       struct sdio_func *func = container_of(wilc_dev->dev, struct sdio_func, dev);
        int size, ret;
 
        sdio_claim_host(func);
@@ -118,24 +108,17 @@ int wilc_sdio_cmd53(sdio_cmd53_t *cmd)
 
 static int linux_sdio_probe(struct sdio_func *func, const struct sdio_device_id *id)
 {
-       struct wilc_sdio *wl_sdio;
        struct wilc *wilc;
 
-       PRINT_D(INIT_DBG, "probe function\n");
-       wl_sdio = kzalloc(sizeof(struct wilc_sdio), GFP_KERNEL);
-       if (!wl_sdio)
-               return -ENOMEM;
 
        PRINT_D(INIT_DBG, "Initializing netdev\n");
        wilc_sdio_func = func;
        if (wilc_netdev_init(&wilc)) {
                PRINT_ER("Couldn't initialize netdev\n");
-               kfree(wl_sdio);
                return -1;
        }
-       wl_sdio->func = func;
-       wl_sdio->wilc = wilc;
-       sdio_set_drvdata(func, wl_sdio);
+       sdio_set_drvdata(func, wilc);
+       wilc->dev = &func->dev;
 
        printk("Driver Initializing success\n");
        return 0;
@@ -143,11 +126,7 @@ static int linux_sdio_probe(struct sdio_func *func, const struct sdio_device_id
 
 static void linux_sdio_remove(struct sdio_func *func)
 {
-       struct wilc_sdio *wl_sdio;
-
-       wl_sdio = sdio_get_drvdata(func);
-       wilc_netdev_cleanup(wl_sdio->wilc);
-       kfree(wl_sdio);
+       wilc_netdev_cleanup(sdio_get_drvdata(func));
 }
 
 static struct sdio_driver wilc_bus = {
index f279a434c4c2d268fdfacbcbe544d48d41b53ed5..29dd9d4e5ff0201a97a6ed05ae5d74535b0730f0 100644 (file)
@@ -9,9 +9,10 @@
 #include <linux/device.h>
 #include <linux/spi/spi.h>
 
+#include "wilc_wfi_netdevice.h"
 #include "linux_wlan_common.h"
 #include "linux_wlan_spi.h"
-#include "wilc_wfi_netdevice.h"
+#include "wilc_wlan_if.h"
 
 #define USE_SPI_DMA     0       /* johnny add */
 
@@ -399,8 +400,25 @@ static struct wilc *wilc;
 
 static int __init init_wilc_spi_driver(void)
 {
+       int ret;
+
        wilc_debugfs_init();
-       return wilc_netdev_init(&wilc);
+
+       ret = wilc_netdev_init(&wilc);
+       if (ret) {
+               wilc_debugfs_remove();
+               return ret;
+       }
+
+       if (!wilc_spi_init() || !wilc_spi_dev) {
+               PRINT_ER("Can't initialize SPI\n");
+               wilc_netdev_cleanup(wilc);
+               wilc_debugfs_remove();
+               return -ENXIO;
+       }
+       wilc_dev->dev = &wilc_spi_dev->dev;
+
+       return ret;
 }
 late_initcall(init_wilc_spi_driver);
 
index 9adac5c781eec2858fe573bcb843450b05c54440..a099f2877b6ed267b56ab5eb17e46d5b691e6dbb 100644 (file)
@@ -185,11 +185,7 @@ struct wilc {
 
        const struct firmware *firmware;
 
-#ifdef WILC_SDIO
-       struct sdio_func *wilc_sdio_func;
-#else
-       struct spi_device *wilc_spidev;
-#endif
+       struct device *dev;
 };
 
 typedef struct {