提交 99e9e52d 编写于 作者: C Cyril Chemparathy 提交者: Kevin Hilman

Davinci: gpio - structs and functions renamed

Renamed gpio types to something more sensible:
	struct gpio_controller	--> struct davinci_gpio_regs
	struct davinci_gpio	--> struct davinci_gpio_controller
	gpio2controller()	--> gpio2regs()
	irq2controller()	--> irq2regs()

This change also moves davinci_gpio_controller definition to gpio.h.
Eventually, the gpio registers structure will be moved to gpio.c and no longer
a common cross-soc definition.
Signed-off-by: NCyril Chemparathy <cyril@ti.com>
Tested-by: NSandeep Paulraj <s-paulraj@ti.com>
Signed-off-by: NKevin Hilman <khilman@deeprootsystems.com>
上级 ba4a984e
...@@ -22,28 +22,22 @@ ...@@ -22,28 +22,22 @@
static DEFINE_SPINLOCK(gpio_lock); static DEFINE_SPINLOCK(gpio_lock);
struct davinci_gpio {
struct gpio_chip chip;
struct gpio_controller __iomem *regs;
int irq_base;
};
#define chip2controller(chip) \ #define chip2controller(chip) \
container_of(chip, struct davinci_gpio, chip) container_of(chip, struct davinci_gpio_controller, chip)
static struct davinci_gpio chips[DIV_ROUND_UP(DAVINCI_N_GPIO, 32)]; static struct davinci_gpio_controller chips[DIV_ROUND_UP(DAVINCI_N_GPIO, 32)];
/* create a non-inlined version */ /* create a non-inlined version */
static struct gpio_controller __iomem __init *gpio2controller(unsigned gpio) static struct davinci_gpio_regs __iomem __init *gpio2regs(unsigned gpio)
{ {
return __gpio_to_controller(gpio); return __gpio_to_controller(gpio);
} }
static inline struct gpio_controller __iomem *irq2controller(int irq) static inline struct davinci_gpio_regs __iomem *irq2regs(int irq)
{ {
struct gpio_controller __iomem *g; struct davinci_gpio_regs __iomem *g;
g = (__force struct gpio_controller __iomem *)get_irq_chip_data(irq); g = (__force struct davinci_gpio_regs __iomem *)get_irq_chip_data(irq);
return g; return g;
} }
...@@ -60,8 +54,8 @@ static int __init davinci_gpio_irq_setup(void); ...@@ -60,8 +54,8 @@ static int __init davinci_gpio_irq_setup(void);
static inline int __davinci_direction(struct gpio_chip *chip, static inline int __davinci_direction(struct gpio_chip *chip,
unsigned offset, bool out, int value) unsigned offset, bool out, int value)
{ {
struct davinci_gpio *d = chip2controller(chip); struct davinci_gpio_controller *d = chip2controller(chip);
struct gpio_controller __iomem *g = d->regs; struct davinci_gpio_regs __iomem *g = d->regs;
u32 temp; u32 temp;
u32 mask = 1 << offset; u32 mask = 1 << offset;
...@@ -99,8 +93,8 @@ davinci_direction_out(struct gpio_chip *chip, unsigned offset, int value) ...@@ -99,8 +93,8 @@ davinci_direction_out(struct gpio_chip *chip, unsigned offset, int value)
*/ */
static int davinci_gpio_get(struct gpio_chip *chip, unsigned offset) static int davinci_gpio_get(struct gpio_chip *chip, unsigned offset)
{ {
struct davinci_gpio *d = chip2controller(chip); struct davinci_gpio_controller *d = chip2controller(chip);
struct gpio_controller __iomem *g = d->regs; struct davinci_gpio_regs __iomem *g = d->regs;
return (1 << offset) & __raw_readl(&g->in_data); return (1 << offset) & __raw_readl(&g->in_data);
} }
...@@ -111,8 +105,8 @@ static int davinci_gpio_get(struct gpio_chip *chip, unsigned offset) ...@@ -111,8 +105,8 @@ static int davinci_gpio_get(struct gpio_chip *chip, unsigned offset)
static void static void
davinci_gpio_set(struct gpio_chip *chip, unsigned offset, int value) davinci_gpio_set(struct gpio_chip *chip, unsigned offset, int value)
{ {
struct davinci_gpio *d = chip2controller(chip); struct davinci_gpio_controller *d = chip2controller(chip);
struct gpio_controller __iomem *g = d->regs; struct davinci_gpio_regs __iomem *g = d->regs;
__raw_writel((1 << offset), value ? &g->set_data : &g->clr_data); __raw_writel((1 << offset), value ? &g->set_data : &g->clr_data);
} }
...@@ -150,7 +144,7 @@ static int __init davinci_gpio_setup(void) ...@@ -150,7 +144,7 @@ static int __init davinci_gpio_setup(void)
if (chips[i].chip.ngpio > 32) if (chips[i].chip.ngpio > 32)
chips[i].chip.ngpio = 32; chips[i].chip.ngpio = 32;
chips[i].regs = gpio2controller(base); chips[i].regs = gpio2regs(base);
gpiochip_add(&chips[i].chip); gpiochip_add(&chips[i].chip);
} }
...@@ -174,7 +168,7 @@ pure_initcall(davinci_gpio_setup); ...@@ -174,7 +168,7 @@ pure_initcall(davinci_gpio_setup);
static void gpio_irq_disable(unsigned irq) static void gpio_irq_disable(unsigned irq)
{ {
struct gpio_controller __iomem *g = irq2controller(irq); struct davinci_gpio_regs __iomem *g = irq2regs(irq);
u32 mask = (u32) get_irq_data(irq); u32 mask = (u32) get_irq_data(irq);
__raw_writel(mask, &g->clr_falling); __raw_writel(mask, &g->clr_falling);
...@@ -183,7 +177,7 @@ static void gpio_irq_disable(unsigned irq) ...@@ -183,7 +177,7 @@ static void gpio_irq_disable(unsigned irq)
static void gpio_irq_enable(unsigned irq) static void gpio_irq_enable(unsigned irq)
{ {
struct gpio_controller __iomem *g = irq2controller(irq); struct davinci_gpio_regs __iomem *g = irq2regs(irq);
u32 mask = (u32) get_irq_data(irq); u32 mask = (u32) get_irq_data(irq);
unsigned status = irq_desc[irq].status; unsigned status = irq_desc[irq].status;
...@@ -199,7 +193,7 @@ static void gpio_irq_enable(unsigned irq) ...@@ -199,7 +193,7 @@ static void gpio_irq_enable(unsigned irq)
static int gpio_irq_type(unsigned irq, unsigned trigger) static int gpio_irq_type(unsigned irq, unsigned trigger)
{ {
struct gpio_controller __iomem *g = irq2controller(irq); struct davinci_gpio_regs __iomem *g = irq2regs(irq);
u32 mask = (u32) get_irq_data(irq); u32 mask = (u32) get_irq_data(irq);
if (trigger & ~(IRQ_TYPE_EDGE_FALLING | IRQ_TYPE_EDGE_RISING)) if (trigger & ~(IRQ_TYPE_EDGE_FALLING | IRQ_TYPE_EDGE_RISING))
...@@ -228,7 +222,7 @@ static struct irq_chip gpio_irqchip = { ...@@ -228,7 +222,7 @@ static struct irq_chip gpio_irqchip = {
static void static void
gpio_irq_handler(unsigned irq, struct irq_desc *desc) gpio_irq_handler(unsigned irq, struct irq_desc *desc)
{ {
struct gpio_controller __iomem *g = irq2controller(irq); struct davinci_gpio_regs __iomem *g = irq2regs(irq);
u32 mask = 0xffff; u32 mask = 0xffff;
/* we only care about one bank */ /* we only care about one bank */
...@@ -266,7 +260,7 @@ gpio_irq_handler(unsigned irq, struct irq_desc *desc) ...@@ -266,7 +260,7 @@ gpio_irq_handler(unsigned irq, struct irq_desc *desc)
static int gpio_to_irq_banked(struct gpio_chip *chip, unsigned offset) static int gpio_to_irq_banked(struct gpio_chip *chip, unsigned offset)
{ {
struct davinci_gpio *d = chip2controller(chip); struct davinci_gpio_controller *d = chip2controller(chip);
if (d->irq_base >= 0) if (d->irq_base >= 0)
return d->irq_base + offset; return d->irq_base + offset;
...@@ -289,7 +283,7 @@ static int gpio_to_irq_unbanked(struct gpio_chip *chip, unsigned offset) ...@@ -289,7 +283,7 @@ static int gpio_to_irq_unbanked(struct gpio_chip *chip, unsigned offset)
static int gpio_irq_type_unbanked(unsigned irq, unsigned trigger) static int gpio_irq_type_unbanked(unsigned irq, unsigned trigger)
{ {
struct gpio_controller __iomem *g = irq2controller(irq); struct davinci_gpio_regs __iomem *g = irq2regs(irq);
u32 mask = (u32) get_irq_data(irq); u32 mask = (u32) get_irq_data(irq);
if (trigger & ~(IRQ_TYPE_EDGE_FALLING | IRQ_TYPE_EDGE_RISING)) if (trigger & ~(IRQ_TYPE_EDGE_FALLING | IRQ_TYPE_EDGE_RISING))
...@@ -318,7 +312,7 @@ static int __init davinci_gpio_irq_setup(void) ...@@ -318,7 +312,7 @@ static int __init davinci_gpio_irq_setup(void)
u32 binten = 0; u32 binten = 0;
unsigned ngpio, bank_irq; unsigned ngpio, bank_irq;
struct davinci_soc_info *soc_info = &davinci_soc_info; struct davinci_soc_info *soc_info = &davinci_soc_info;
struct gpio_controller __iomem *g; struct davinci_gpio_regs __iomem *g;
ngpio = soc_info->gpio_num; ngpio = soc_info->gpio_num;
...@@ -367,7 +361,7 @@ static int __init davinci_gpio_irq_setup(void) ...@@ -367,7 +361,7 @@ static int __init davinci_gpio_irq_setup(void)
gpio_irqchip_unbanked.set_type = gpio_irq_type_unbanked; gpio_irqchip_unbanked.set_type = gpio_irq_type_unbanked;
/* default trigger: both edges */ /* default trigger: both edges */
g = gpio2controller(0); g = gpio2regs(0);
__raw_writel(~0, &g->set_falling); __raw_writel(~0, &g->set_falling);
__raw_writel(~0, &g->set_rising); __raw_writel(~0, &g->set_rising);
...@@ -392,7 +386,7 @@ static int __init davinci_gpio_irq_setup(void) ...@@ -392,7 +386,7 @@ static int __init davinci_gpio_irq_setup(void)
unsigned i; unsigned i;
/* disabled by default, enabled only as needed */ /* disabled by default, enabled only as needed */
g = gpio2controller(gpio); g = gpio2regs(gpio);
__raw_writel(~0, &g->clr_falling); __raw_writel(~0, &g->clr_falling);
__raw_writel(~0, &g->clr_rising); __raw_writel(~0, &g->clr_rising);
......
...@@ -45,7 +45,7 @@ ...@@ -45,7 +45,7 @@
/* Convert GPIO signal to GPIO pin number */ /* Convert GPIO signal to GPIO pin number */
#define GPIO_TO_PIN(bank, gpio) (16 * (bank) + (gpio)) #define GPIO_TO_PIN(bank, gpio) (16 * (bank) + (gpio))
struct gpio_controller { struct davinci_gpio_regs {
u32 dir; u32 dir;
u32 out_data; u32 out_data;
u32 set_data; u32 set_data;
...@@ -58,6 +58,12 @@ struct gpio_controller { ...@@ -58,6 +58,12 @@ struct gpio_controller {
u32 intstat; u32 intstat;
}; };
struct davinci_gpio_controller {
struct davinci_gpio_regs __iomem *regs;
struct gpio_chip chip;
int irq_base;
};
/* The __gpio_to_controller() and __gpio_mask() functions inline to constants /* The __gpio_to_controller() and __gpio_mask() functions inline to constants
* with constant parameters; or in outlined code they execute at runtime. * with constant parameters; or in outlined code they execute at runtime.
* *
...@@ -67,7 +73,7 @@ struct gpio_controller { ...@@ -67,7 +73,7 @@ struct gpio_controller {
* *
* These are NOT part of the cross-platform GPIO interface * These are NOT part of the cross-platform GPIO interface
*/ */
static inline struct gpio_controller __iomem * static inline struct davinci_gpio_regs __iomem *
__gpio_to_controller(unsigned gpio) __gpio_to_controller(unsigned gpio)
{ {
void __iomem *ptr; void __iomem *ptr;
...@@ -102,7 +108,7 @@ static inline u32 __gpio_mask(unsigned gpio) ...@@ -102,7 +108,7 @@ static inline u32 __gpio_mask(unsigned gpio)
static inline void gpio_set_value(unsigned gpio, int value) static inline void gpio_set_value(unsigned gpio, int value)
{ {
if (__builtin_constant_p(value) && gpio < DAVINCI_N_GPIO) { if (__builtin_constant_p(value) && gpio < DAVINCI_N_GPIO) {
struct gpio_controller __iomem *g; struct davinci_gpio_regs __iomem *g;
u32 mask; u32 mask;
g = __gpio_to_controller(gpio); g = __gpio_to_controller(gpio);
...@@ -128,7 +134,7 @@ static inline void gpio_set_value(unsigned gpio, int value) ...@@ -128,7 +134,7 @@ static inline void gpio_set_value(unsigned gpio, int value)
*/ */
static inline int gpio_get_value(unsigned gpio) static inline int gpio_get_value(unsigned gpio)
{ {
struct gpio_controller __iomem *g; struct davinci_gpio_regs __iomem *g;
if (!__builtin_constant_p(gpio) || gpio >= DAVINCI_N_GPIO) if (!__builtin_constant_p(gpio) || gpio >= DAVINCI_N_GPIO)
return __gpio_get_value(gpio); return __gpio_get_value(gpio);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册