]> git.kernelconcepts.de Git - karo-tx-linux.git/blobdiff - drivers/staging/nvec/nvec.c
staging: nvec: remove instantiating via platform device
[karo-tx-linux.git] / drivers / staging / nvec / nvec.c
index 197c393c4ca752a9f50062e2852afd2bb8be89a3..8e935a4aafe2188baf3fba1aaf18ee0b51c25626 100644 (file)
@@ -33,7 +33,6 @@
 #include <linux/mfd/core.h>
 #include <linux/mutex.h>
 #include <linux/notifier.h>
-#include <linux/platform_device.h>
 #include <linux/slab.h>
 #include <linux/spinlock.h>
 #include <linux/workqueue.h>
@@ -776,7 +775,6 @@ static int tegra_nvec_probe(struct platform_device *pdev)
 {
        int err, ret;
        struct clk *i2c_clk;
-       struct nvec_platform_data *pdata = pdev->dev.platform_data;
        struct nvec_chip *nvec;
        struct nvec_msg *msg;
        struct resource *res;
@@ -785,6 +783,11 @@ static int tegra_nvec_probe(struct platform_device *pdev)
                unmute_speakers[] = { NVEC_OEM0, 0x10, 0x59, 0x95 },
                enable_event[7] = { NVEC_SYS, CNF_EVENT_REPORTING, true };
 
+       if(!pdev->dev.of_node) {
+               dev_err(&pdev->dev, "must be instantiated using device tree\n");
+               return -ENODEV;
+       }
+
        nvec = devm_kzalloc(&pdev->dev, sizeof(struct nvec_chip), GFP_KERNEL);
        if (nvec == NULL) {
                dev_err(&pdev->dev, "failed to reserve memory\n");
@@ -793,23 +796,15 @@ static int tegra_nvec_probe(struct platform_device *pdev)
        platform_set_drvdata(pdev, nvec);
        nvec->dev = &pdev->dev;
 
-       if (pdata) {
-               nvec->gpio = pdata->gpio;
-               nvec->i2c_addr = pdata->i2c_addr;
-       } else if (nvec->dev->of_node) {
-               nvec->gpio = of_get_named_gpio(nvec->dev->of_node,
-                                       "request-gpios", 0);
-               if (nvec->gpio < 0) {
-                       dev_err(&pdev->dev, "no gpio specified");
-                       return -ENODEV;
-               }
-               if (of_property_read_u32(nvec->dev->of_node,
-                                       "slave-addr", &nvec->i2c_addr)) {
-                       dev_err(&pdev->dev, "no i2c address specified");
-                       return -ENODEV;
-               }
-       } else {
-               dev_err(&pdev->dev, "no platform data\n");
+       nvec->gpio = of_get_named_gpio(nvec->dev->of_node, "request-gpios", 0);
+       if (nvec->gpio < 0) {
+               dev_err(&pdev->dev, "no gpio specified");
+               return -ENODEV;
+       }
+
+       if (of_property_read_u32(nvec->dev->of_node, "slave-addr",
+                                &nvec->i2c_addr)) {
+               dev_err(&pdev->dev, "no i2c address specified");
                return -ENODEV;
        }