Commit bd710009 authored by Rafael J. Wysocki's avatar Rafael J. Wysocki Committed by Ralf Baechle

MIPS: PM: Use struct syscore_ops instead of sysdevs for PM (v2)

Convert some MIPS architecture's code to using struct syscore_ops
objects for power management instead of sysdev classes and sysdevs.

This simplifies the code and reduces the kernel's memory footprint.
It also is necessary for removing sysdevs from the kernel entirely in
the future.
Signed-off-by: default avatarRafael J. Wysocki <rjw@sisk.pl>
Acked-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
Acked-and-tested-by: default avatarLars-Peter Clausen <lars@metafoo.de>
Signed-off-by: default avatarLars-Peter Clausen <lars@metafoo.de>
Cc: linux-kernel@vger.kernel.org
Cc: "Rafael J.  Wysocki" <rjw@sisk.pl>
Patchwork: http://patchwork.linux-mips.org/patch/2431/Signed-off-by: default avatarRalf Baechle <ralf@linux-mips.org>
parent 1eec6cd0
...@@ -18,7 +18,7 @@ ...@@ -18,7 +18,7 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/sysdev.h> #include <linux/syscore_ops.h>
#include <linux/io.h> #include <linux/io.h>
#include <linux/gpio.h> #include <linux/gpio.h>
#include <linux/delay.h> #include <linux/delay.h>
...@@ -86,7 +86,6 @@ struct jz_gpio_chip { ...@@ -86,7 +86,6 @@ struct jz_gpio_chip {
spinlock_t lock; spinlock_t lock;
struct gpio_chip gpio_chip; struct gpio_chip gpio_chip;
struct sys_device sysdev;
}; };
static struct jz_gpio_chip jz4740_gpio_chips[]; static struct jz_gpio_chip jz4740_gpio_chips[];
...@@ -459,49 +458,47 @@ static struct jz_gpio_chip jz4740_gpio_chips[] = { ...@@ -459,49 +458,47 @@ static struct jz_gpio_chip jz4740_gpio_chips[] = {
JZ4740_GPIO_CHIP(D), JZ4740_GPIO_CHIP(D),
}; };
static inline struct jz_gpio_chip *sysdev_to_chip(struct sys_device *dev) static void jz4740_gpio_suspend_chip(struct jz_gpio_chip *chip)
{ {
return container_of(dev, struct jz_gpio_chip, sysdev); chip->suspend_mask = readl(chip->base + JZ_REG_GPIO_MASK);
writel(~(chip->wakeup), chip->base + JZ_REG_GPIO_MASK_SET);
writel(chip->wakeup, chip->base + JZ_REG_GPIO_MASK_CLEAR);
} }
static int jz4740_gpio_suspend(struct sys_device *dev, pm_message_t state) static int jz4740_gpio_suspend(void)
{ {
struct jz_gpio_chip *chip = sysdev_to_chip(dev); int i;
chip->suspend_mask = readl(chip->base + JZ_REG_GPIO_MASK); for (i = 0; i < ARRAY_SIZE(jz4740_gpio_chips); i++)
writel(~(chip->wakeup), chip->base + JZ_REG_GPIO_MASK_SET); jz4740_gpio_suspend_chip(&jz4740_gpio_chips[i]);
writel(chip->wakeup, chip->base + JZ_REG_GPIO_MASK_CLEAR);
return 0; return 0;
} }
static int jz4740_gpio_resume(struct sys_device *dev) static void jz4740_gpio_resume_chip(struct jz_gpio_chip *chip)
{ {
struct jz_gpio_chip *chip = sysdev_to_chip(dev);
uint32_t mask = chip->suspend_mask; uint32_t mask = chip->suspend_mask;
writel(~mask, chip->base + JZ_REG_GPIO_MASK_CLEAR); writel(~mask, chip->base + JZ_REG_GPIO_MASK_CLEAR);
writel(mask, chip->base + JZ_REG_GPIO_MASK_SET); writel(mask, chip->base + JZ_REG_GPIO_MASK_SET);
}
return 0; static void jz4740_gpio_resume(void)
{
int i;
for (i = ARRAY_SIZE(jz4740_gpio_chips) - 1; i >= 0 ; i--)
jz4740_gpio_resume_chip(&jz4740_gpio_chips[i]);
} }
static struct sysdev_class jz4740_gpio_sysdev_class = { static struct syscore_ops jz4740_gpio_syscore_ops = {
.name = "gpio",
.suspend = jz4740_gpio_suspend, .suspend = jz4740_gpio_suspend,
.resume = jz4740_gpio_resume, .resume = jz4740_gpio_resume,
}; };
static int jz4740_gpio_chip_init(struct jz_gpio_chip *chip, unsigned int id) static void jz4740_gpio_chip_init(struct jz_gpio_chip *chip, unsigned int id)
{ {
int ret, irq; int irq;
chip->sysdev.id = id;
chip->sysdev.cls = &jz4740_gpio_sysdev_class;
ret = sysdev_register(&chip->sysdev);
if (ret)
return ret;
spin_lock_init(&chip->lock); spin_lock_init(&chip->lock);
...@@ -519,22 +516,17 @@ static int jz4740_gpio_chip_init(struct jz_gpio_chip *chip, unsigned int id) ...@@ -519,22 +516,17 @@ static int jz4740_gpio_chip_init(struct jz_gpio_chip *chip, unsigned int id)
irq_set_chip_and_handler(irq, &jz_gpio_irq_chip, irq_set_chip_and_handler(irq, &jz_gpio_irq_chip,
handle_level_irq); handle_level_irq);
} }
return 0;
} }
static int __init jz4740_gpio_init(void) static int __init jz4740_gpio_init(void)
{ {
unsigned int i; unsigned int i;
int ret;
ret = sysdev_class_register(&jz4740_gpio_sysdev_class);
if (ret)
return ret;
for (i = 0; i < ARRAY_SIZE(jz4740_gpio_chips); ++i) for (i = 0; i < ARRAY_SIZE(jz4740_gpio_chips); ++i)
jz4740_gpio_chip_init(&jz4740_gpio_chips[i], i); jz4740_gpio_chip_init(&jz4740_gpio_chips[i], i);
register_syscore_ops(&jz4740_gpio_syscore_ops);
printk(KERN_INFO "JZ4740 GPIO initialized\n"); printk(KERN_INFO "JZ4740 GPIO initialized\n");
return 0; return 0;
......
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