diff options
author | Ben Dooks <ben-linux@fluff.org> | 2010-05-17 14:28:44 +0900 |
---|---|---|
committer | Ben Dooks <ben-linux@fluff.org> | 2010-05-18 19:06:33 +0900 |
commit | 7987bd7a7051c979f7b9b572898f92dbef6aaeb1 (patch) | |
tree | 71f6aceb2ee3b0a1b00e64f9763b6ee01cb81c55 /arch/arm/mach-s3c2412/gpio.c | |
parent | 2c8fcfbf735e2d3b139e4247eb3e73edf64bb23f (diff) | |
download | kernel_samsung_tuna-7987bd7a7051c979f7b9b572898f92dbef6aaeb1.zip kernel_samsung_tuna-7987bd7a7051c979f7b9b572898f92dbef6aaeb1.tar.gz kernel_samsung_tuna-7987bd7a7051c979f7b9b572898f92dbef6aaeb1.tar.bz2 |
ARM: S3C24XX: Update missed gpio calls to use gpiolib
Update a couple of S3C24XX and S3C2412 files that are still
using the GPIO number to register mapping calls to get the
s3c_gpio_chip and use the base field from that.
Signed-off-by: Ben Dooks <ben-linux@fluff.org>
Diffstat (limited to 'arch/arm/mach-s3c2412/gpio.c')
-rw-r--r-- | arch/arm/mach-s3c2412/gpio.c | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/arch/arm/mach-s3c2412/gpio.c b/arch/arm/mach-s3c2412/gpio.c index 71c5793..3404a87 100644 --- a/arch/arm/mach-s3c2412/gpio.c +++ b/arch/arm/mach-s3c2412/gpio.c @@ -16,18 +16,20 @@ #include <linux/types.h> #include <linux/module.h> #include <linux/interrupt.h> +#include <linux/gpio.h> #include <asm/mach/arch.h> #include <asm/mach/map.h> #include <mach/regs-gpio.h> - #include <mach/hardware.h> +#include <plat/gpio-core.h> + int s3c2412_gpio_set_sleepcfg(unsigned int pin, unsigned int state) { - void __iomem *base = S3C24XX_GPIO_BASE(pin); - unsigned long offs = S3C2410_GPIO_OFFSET(pin); + struct s3c_gpio_chip *chip = s3c_gpiolib_getchip(pin); + unsigned long offs = pin - chip->chip.base; unsigned long flags; unsigned long slpcon; @@ -45,12 +47,12 @@ int s3c2412_gpio_set_sleepcfg(unsigned int pin, unsigned int state) local_irq_save(flags); - slpcon = __raw_readl(base + 0x0C); + slpcon = __raw_readl(chip->base + 0x0C); slpcon &= ~(3 << offs); slpcon |= state << offs; - __raw_writel(slpcon, base + 0x0C); + __raw_writel(slpcon, chip->base + 0x0C); local_irq_restore(flags); |