Commit 90533980 authored by Rafael J. Wysocki's avatar Rafael J. Wysocki

ARM / SA1100: Use struct syscore_ops for "core" power management

Replace the sysdev class and struct sys_device used for power
management by the SA1100 interrupt-handling code with a
struct syscore_ops object which is simpler.
Signed-off-by: default avatarRafael J. Wysocki <rjw@sisk.pl>
Acked-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent b7808056
...@@ -14,7 +14,7 @@ ...@@ -14,7 +14,7 @@
#include <linux/interrupt.h> #include <linux/interrupt.h>
#include <linux/irq.h> #include <linux/irq.h>
#include <linux/ioport.h> #include <linux/ioport.h>
#include <linux/sysdev.h> #include <linux/syscore_ops.h>
#include <mach/hardware.h> #include <mach/hardware.h>
#include <asm/mach/irq.h> #include <asm/mach/irq.h>
...@@ -234,7 +234,7 @@ static struct sa1100irq_state { ...@@ -234,7 +234,7 @@ static struct sa1100irq_state {
unsigned int iccr; unsigned int iccr;
} sa1100irq_state; } sa1100irq_state;
static int sa1100irq_suspend(struct sys_device *dev, pm_message_t state) static int sa1100irq_suspend(void)
{ {
struct sa1100irq_state *st = &sa1100irq_state; struct sa1100irq_state *st = &sa1100irq_state;
...@@ -264,7 +264,7 @@ static int sa1100irq_suspend(struct sys_device *dev, pm_message_t state) ...@@ -264,7 +264,7 @@ static int sa1100irq_suspend(struct sys_device *dev, pm_message_t state)
return 0; return 0;
} }
static int sa1100irq_resume(struct sys_device *dev) static void sa1100irq_resume(void)
{ {
struct sa1100irq_state *st = &sa1100irq_state; struct sa1100irq_state *st = &sa1100irq_state;
...@@ -277,24 +277,17 @@ static int sa1100irq_resume(struct sys_device *dev) ...@@ -277,24 +277,17 @@ static int sa1100irq_resume(struct sys_device *dev)
ICMR = st->icmr; ICMR = st->icmr;
} }
return 0;
} }
static struct sysdev_class sa1100irq_sysclass = { static struct syscore_ops sa1100irq_syscore_ops = {
.name = "sa11x0-irq",
.suspend = sa1100irq_suspend, .suspend = sa1100irq_suspend,
.resume = sa1100irq_resume, .resume = sa1100irq_resume,
}; };
static struct sys_device sa1100irq_device = {
.id = 0,
.cls = &sa1100irq_sysclass,
};
static int __init sa1100irq_init_devicefs(void) static int __init sa1100irq_init_devicefs(void)
{ {
sysdev_class_register(&sa1100irq_sysclass); register_syscore_ops(&sa1100irq_syscore_ops);
return sysdev_register(&sa1100irq_device); return 0;
} }
device_initcall(sa1100irq_init_devicefs); device_initcall(sa1100irq_init_devicefs);
......
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