Commit 6d974d32 authored by Bartosz Golaszewski's avatar Bartosz Golaszewski Committed by Linus Walleij

gpio: mockup: merge gpio_mockup_add() into gpio_mockup_probe()

Now that the probe() function only does what is should, there's no
need to split the chip adding logic into a separate routine. Merge
gpio_mockup_add() into gpio_mockup_probe().
Signed-off-by: default avatarBartosz Golaszewski <brgl@bgdev.pl>
Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent b9576d03
...@@ -231,13 +231,30 @@ static void gpio_mockup_debugfs_setup(struct device *dev, ...@@ -231,13 +231,30 @@ static void gpio_mockup_debugfs_setup(struct device *dev,
dev_err(dev, "error creating debugfs directory\n"); dev_err(dev, "error creating debugfs directory\n");
} }
static int gpio_mockup_add(struct device *dev, static int gpio_mockup_probe(struct platform_device *pdev)
struct gpio_mockup_chip *chip,
const char *name, int base, int ngpio)
{ {
struct gpio_chip *gc = &chip->gc; struct gpio_mockup_platform_data *pdata;
int ret; struct gpio_mockup_chip *chip;
struct gpio_chip *gc;
int rv, base, ngpio;
struct device *dev;
char *name;
dev = &pdev->dev;
pdata = dev_get_platdata(dev);
base = pdata->base;
ngpio = pdata->ngpio;
chip = devm_kzalloc(dev, sizeof(*chip), GFP_KERNEL);
if (!chip)
return -ENOMEM;
name = devm_kasprintf(dev, GFP_KERNEL, "%s-%c",
pdev->name, pdata->index);
if (!name)
return -ENOMEM;
gc = &chip->gc;
gc->base = base; gc->base = base;
gc->ngpio = ngpio; gc->ngpio = ngpio;
gc->label = name; gc->label = name;
...@@ -256,18 +273,18 @@ static int gpio_mockup_add(struct device *dev, ...@@ -256,18 +273,18 @@ static int gpio_mockup_add(struct device *dev,
return -ENOMEM; return -ENOMEM;
if (gpio_mockup_named_lines) { if (gpio_mockup_named_lines) {
ret = gpio_mockup_name_lines(dev, chip); rv = gpio_mockup_name_lines(dev, chip);
if (ret) if (rv)
return ret; return rv;
} }
ret = devm_irq_sim_init(dev, &chip->irqsim, gc->ngpio); rv = devm_irq_sim_init(dev, &chip->irqsim, gc->ngpio);
if (ret) if (rv)
return ret; return rv;
ret = devm_gpiochip_add_data(dev, &chip->gc, chip); rv = devm_gpiochip_add_data(dev, &chip->gc, chip);
if (ret) if (rv)
return ret; return rv;
if (gpio_mockup_dbg_dir) if (gpio_mockup_dbg_dir)
gpio_mockup_debugfs_setup(dev, chip); gpio_mockup_debugfs_setup(dev, chip);
...@@ -275,39 +292,6 @@ static int gpio_mockup_add(struct device *dev, ...@@ -275,39 +292,6 @@ static int gpio_mockup_add(struct device *dev,
return 0; return 0;
} }
static int gpio_mockup_probe(struct platform_device *pdev)
{
struct gpio_mockup_platform_data *pdata;
struct gpio_mockup_chip *chip;
int rv, base, ngpio;
struct device *dev;
char *name;
dev = &pdev->dev;
pdata = dev_get_platdata(dev);
base = pdata->base;
ngpio = pdata->ngpio;
chip = devm_kzalloc(dev, sizeof(*chip), GFP_KERNEL);
if (!chip)
return -ENOMEM;
name = devm_kasprintf(dev, GFP_KERNEL, "%s-%c",
pdev->name, pdata->index);
if (!name)
return -ENOMEM;
rv = gpio_mockup_add(dev, chip, name, base, ngpio);
if (rv) {
dev_err(dev,
"adding gpiochip failed (base: %d, ngpio: %d)\n",
base, base < 0 ? ngpio : base + ngpio);
return rv;
}
return 0;
}
static struct platform_driver gpio_mockup_driver = { static struct platform_driver gpio_mockup_driver = {
.driver = { .driver = {
.name = GPIO_MOCKUP_NAME, .name = GPIO_MOCKUP_NAME,
......
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