Commit 2c6cbdd0 authored by Marc Dietrich's avatar Marc Dietrich Committed by Greg Kroah-Hartman

staging: nvec: remove instantiating via platform device

Tegra has been converted to support device tree only. Remove support
for instantiating via platform device.
Signed-off-by: default avatarLeon Romanovsky <leon@leon.nu>
Signed-off-by: default avatarMarc Dietrich <marvin24@gmx.de>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 2b8d5e5b
...@@ -33,7 +33,6 @@ ...@@ -33,7 +33,6 @@
#include <linux/mfd/core.h> #include <linux/mfd/core.h>
#include <linux/mutex.h> #include <linux/mutex.h>
#include <linux/notifier.h> #include <linux/notifier.h>
#include <linux/platform_device.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/workqueue.h> #include <linux/workqueue.h>
...@@ -776,7 +775,6 @@ static int tegra_nvec_probe(struct platform_device *pdev) ...@@ -776,7 +775,6 @@ static int tegra_nvec_probe(struct platform_device *pdev)
{ {
int err, ret; int err, ret;
struct clk *i2c_clk; struct clk *i2c_clk;
struct nvec_platform_data *pdata = pdev->dev.platform_data;
struct nvec_chip *nvec; struct nvec_chip *nvec;
struct nvec_msg *msg; struct nvec_msg *msg;
struct resource *res; struct resource *res;
...@@ -785,6 +783,11 @@ static int tegra_nvec_probe(struct platform_device *pdev) ...@@ -785,6 +783,11 @@ static int tegra_nvec_probe(struct platform_device *pdev)
unmute_speakers[] = { NVEC_OEM0, 0x10, 0x59, 0x95 }, unmute_speakers[] = { NVEC_OEM0, 0x10, 0x59, 0x95 },
enable_event[7] = { NVEC_SYS, CNF_EVENT_REPORTING, true }; 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); nvec = devm_kzalloc(&pdev->dev, sizeof(struct nvec_chip), GFP_KERNEL);
if (nvec == NULL) { if (nvec == NULL) {
dev_err(&pdev->dev, "failed to reserve memory\n"); dev_err(&pdev->dev, "failed to reserve memory\n");
...@@ -793,25 +796,17 @@ static int tegra_nvec_probe(struct platform_device *pdev) ...@@ -793,25 +796,17 @@ static int tegra_nvec_probe(struct platform_device *pdev)
platform_set_drvdata(pdev, nvec); platform_set_drvdata(pdev, nvec);
nvec->dev = &pdev->dev; nvec->dev = &pdev->dev;
if (pdata) { nvec->gpio = of_get_named_gpio(nvec->dev->of_node, "request-gpios", 0);
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) { if (nvec->gpio < 0) {
dev_err(&pdev->dev, "no gpio specified"); dev_err(&pdev->dev, "no gpio specified");
return -ENODEV; return -ENODEV;
} }
if (of_property_read_u32(nvec->dev->of_node,
"slave-addr", &nvec->i2c_addr)) { if (of_property_read_u32(nvec->dev->of_node, "slave-addr",
&nvec->i2c_addr)) {
dev_err(&pdev->dev, "no i2c address specified"); dev_err(&pdev->dev, "no i2c address specified");
return -ENODEV; return -ENODEV;
} }
} else {
dev_err(&pdev->dev, "no platform data\n");
return -ENODEV;
}
res = platform_get_resource(pdev, IORESOURCE_MEM, 0); res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
base = devm_ioremap_resource(&pdev->dev, res); base = devm_ioremap_resource(&pdev->dev, res);
......
...@@ -102,31 +102,6 @@ struct nvec_msg { ...@@ -102,31 +102,6 @@ struct nvec_msg {
atomic_t used; atomic_t used;
}; };
/**
* struct nvec_subdev - A subdevice of nvec, such as nvec_kbd
* @name: The name of the sub device
* @platform_data: Platform data
* @id: Identifier of the sub device
*/
struct nvec_subdev {
const char *name;
void *platform_data;
int id;
};
/**
* struct nvec_platform_data - platform data for a tegra slave controller
* @i2c_addr: number of i2c slave adapter the ec is connected to
* @gpio: gpio number for the ec request line
*
* Platform data, to be used in board definitions. For an example, take a
* look at the paz00 board in arch/arm/mach-tegra/board-paz00.c
*/
struct nvec_platform_data {
int i2c_addr;
int gpio;
};
/** /**
* struct nvec_chip - A single connection to an NVIDIA Embedded controller * struct nvec_chip - A single connection to an NVIDIA Embedded controller
* @dev: The device * @dev: The device
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment