-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
yaml --- r: 123878 b: refs/heads/master c: 21b2366 h: refs/heads/master v: v3
- Loading branch information
Ben Dooks
committed
Dec 15, 2008
1 parent
3968737
commit 260332a
Showing
12 changed files
with
620 additions
and
7 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,2 @@ | ||
--- | ||
refs/heads/master: 89d043c3db22c37523165905708d2fa8062fda86 | ||
refs/heads/master: 21b23664b9354c5449841e401efb9ad523fb898b |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
/* arch/arm/mach-s3c24100/include/mach/gpio-core.h | ||
* | ||
* Copyright 2008 Openmoko, Inc. | ||
* Copyright 2008 Simtec Electronics | ||
* Ben Dooks <ben@simtec.co.uk> | ||
* http://armlinux.simtec.co.uk/ | ||
* | ||
* S3C2410 - GPIO core support | ||
* | ||
* This program is free software; you can redistribute it and/or modify | ||
* it under the terms of the GNU General Public License version 2 as | ||
* published by the Free Software Foundation. | ||
*/ | ||
|
||
#ifndef __ASM_ARCH_GPIO_CORE_H | ||
#define __ASM_ARCH_GPIO_CORE_H __FILE__ | ||
|
||
#include <plat/gpio-core.h> | ||
#include <mach/regs-gpio.h> | ||
|
||
extern struct s3c_gpio_chip s3c24xx_gpios[]; | ||
|
||
static inline struct s3c_gpio_chip *s3c_gpiolib_getchip(unsigned int pin) | ||
{ | ||
struct s3c_gpio_chip *chip; | ||
|
||
if (pin > S3C2410_GPG10) | ||
return NULL; | ||
|
||
chip = &s3c24xx_gpios[pin/32]; | ||
return (S3C2410_GPIO_OFFSET(pin) > chip->chip.ngpio) ? chip : NULL; | ||
} | ||
|
||
#endif /* __ASM_ARCH_GPIO_CORE_H */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
/* arch/arm/mach-s3c6400/include/mach/gpio-core.h | ||
* | ||
* Copyright 2008 Openmoko, Inc. | ||
* Copyright 2008 Simtec Electronics | ||
* Ben Dooks <ben@simtec.co.uk> | ||
* http://armlinux.simtec.co.uk/ | ||
* | ||
* S3C64XX - GPIO core support | ||
* | ||
* This program is free software; you can redistribute it and/or modify | ||
* it under the terms of the GNU General Public License version 2 as | ||
* published by the Free Software Foundation. | ||
*/ | ||
|
||
#ifndef __ASM_ARCH_GPIO_CORE_H | ||
#define __ASM_ARCH_GPIO_CORE_H __FILE__ | ||
|
||
/* currently we just include the platform support */ | ||
#include <plat/gpio-core.h> | ||
|
||
#endif /* __ASM_ARCH_GPIO_CORE_H */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,163 @@ | ||
/* linux/arch/arm/plat-s3c/gpio-config.c | ||
* | ||
* Copyright 2008 Openmoko, Inc. | ||
* Copyright 2008 Simtec Electronics | ||
* Ben Dooks <ben@simtec.co.uk> | ||
* http://armlinux.simtec.co.uk/ | ||
* | ||
* S3C series GPIO configuration core | ||
* | ||
* This program is free software; you can redistribute it and/or modify | ||
* it under the terms of the GNU General Public License version 2 as | ||
* published by the Free Software Foundation. | ||
*/ | ||
|
||
#include <linux/kernel.h> | ||
#include <linux/gpio.h> | ||
#include <linux/io.h> | ||
|
||
#include <mach/gpio-core.h> | ||
#include <plat/gpio-cfg.h> | ||
#include <plat/gpio-cfg-helpers.h> | ||
|
||
int s3c_gpio_cfgpin(unsigned int pin, unsigned int config) | ||
{ | ||
struct s3c_gpio_chip *chip = s3c_gpiolib_getchip(pin); | ||
unsigned long flags; | ||
int offset; | ||
int ret; | ||
|
||
if (!chip) | ||
return -EINVAL; | ||
|
||
offset = pin - chip->chip.base; | ||
|
||
local_irq_save(flags); | ||
ret = s3c_gpio_do_setcfg(chip, offset, config); | ||
local_irq_restore(flags); | ||
|
||
return ret; | ||
} | ||
|
||
int s3c_gpio_setpull(unsigned int pin, s3c_gpio_pull_t pull) | ||
{ | ||
struct s3c_gpio_chip *chip = s3c_gpiolib_getchip(pin); | ||
unsigned long flags; | ||
int offset, ret; | ||
|
||
if (!chip) | ||
return -EINVAL; | ||
|
||
offset = pin - chip->chip.base; | ||
|
||
local_irq_save(flags); | ||
ret = s3c_gpio_do_setpull(chip, offset, pull); | ||
local_irq_restore(flags); | ||
|
||
return ret; | ||
} | ||
|
||
#ifdef CONFIG_S3C_GPIO_CFG_S3C24XX | ||
int s3c_gpio_setcfg_s3c24xx_banka(struct s3c_gpio_chip *chip, | ||
unsigned int off, unsigned int cfg) | ||
{ | ||
void __iomem *reg = chip->base; | ||
unsigned int shift = off; | ||
u32 con; | ||
|
||
if (s3c_gpio_is_cfg_special(cfg)) { | ||
cfg &= 0xf; | ||
|
||
/* Map output to 0, and SFN2 to 1 */ | ||
cfg -= 1; | ||
if (cfg > 1) | ||
return -EINVAL; | ||
|
||
cfg <<= shift; | ||
} | ||
|
||
con = __raw_readl(reg); | ||
con &= ~(0x1 << shift); | ||
con |= cfg; | ||
__raw_writel(con, reg); | ||
|
||
return 0; | ||
} | ||
|
||
int s3c_gpio_setcfg_s3c24xx(struct s3c_gpio_chip *chip, | ||
unsigned int off, unsigned int cfg) | ||
{ | ||
void __iomem *reg = chip->base; | ||
unsigned int shift = off * 2; | ||
u32 con; | ||
|
||
if (s3c_gpio_is_cfg_special(cfg)) { | ||
cfg &= 0xf; | ||
if (cfg > 3) | ||
return -EINVAL; | ||
|
||
cfg <<= shift; | ||
} | ||
|
||
con = __raw_readl(reg); | ||
con &= ~(0x3 << shift); | ||
con |= cfg; | ||
__raw_writel(con, reg); | ||
|
||
return 0; | ||
} | ||
#endif | ||
|
||
#ifdef CONFIG_S3C_GPIO_CFG_S3C64XX | ||
int s3c_gpio_setcfg_s3c64xx_4bit(struct s3c_gpio_chip *chip, | ||
unsigned int off, unsigned int cfg) | ||
{ | ||
void __iomem *reg = chip->base; | ||
unsigned int shift = (off & 7) * 4; | ||
u32 con; | ||
|
||
if (off < 8 && chip->chip.ngpio >= 8) | ||
reg -= 4; | ||
|
||
if (s3c_gpio_is_cfg_special(cfg)) { | ||
cfg &= 0xf; | ||
cfg <<= shift; | ||
} | ||
|
||
con = __raw_readl(reg); | ||
con &= ~(0xf << shift); | ||
con |= cfg; | ||
__raw_writel(con, reg); | ||
|
||
return 0; | ||
} | ||
#endif /* CONFIG_S3C_GPIO_CFG_S3C64XX */ | ||
|
||
#ifdef CONFIG_S3C_GPIO_PULL_UPDOWN | ||
int s3c_gpio_setpull_updown(struct s3c_gpio_chip *chip, | ||
unsigned int off, s3c_gpio_pull_t pull) | ||
{ | ||
void __iomem *reg = chip->base + 0x08; | ||
int shift = off * 2; | ||
u32 pup; | ||
|
||
pup = __raw_readl(reg); | ||
pup &= ~(3 << shift); | ||
pup |= pull << shift; | ||
__raw_writel(pup, reg); | ||
|
||
return 0; | ||
} | ||
|
||
s3c_gpio_pull_t s3c_gpio_getpull_updown(struct s3c_gpio_chip *chip, | ||
unsigned int off) | ||
{ | ||
void __iomem *reg = chip->base + 0x08; | ||
int shift = off * 2; | ||
u32 pup = __raw_readl(reg); | ||
|
||
pup >>= shift; | ||
pup &= 0x3; | ||
return (__force s3c_gpio_pull_t)pup; | ||
} | ||
#endif |
Oops, something went wrong.