aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCyril Chemparathy <cyril@ti.com>2010-05-01 18:37:51 -0400
committerKevin Hilman <khilman@deeprootsystems.com>2010-05-06 18:02:08 -0400
commitba4a984e838dfb1c46135ff8cadeea5f8ca5fd0a (patch)
tree1650621c7dbdfe8bcb3b9d9d2198715bc0d21043
parent7a9978a1e2225507025a8b90b4289d506a416bd9 (diff)
Davinci: gpio - minor cleanup
macroized repeated container_of()s to improve readability. unified direction in/out functions. Signed-off-by: Cyril Chemparathy <cyril@ti.com> Tested-by: Sandeep Paulraj <s-paulraj@ti.com> Signed-off-by: Kevin Hilman <khilman@deeprootsystems.com>
-rw-r--r--arch/arm/mach-davinci/gpio.c50
1 files changed, 27 insertions, 23 deletions
diff --git a/arch/arm/mach-davinci/gpio.c b/arch/arm/mach-davinci/gpio.c
index 5476ad132044..93f7c686153a 100644
--- a/arch/arm/mach-davinci/gpio.c
+++ b/arch/arm/mach-davinci/gpio.c
@@ -28,6 +28,9 @@ struct davinci_gpio {
28 int irq_base; 28 int irq_base;
29}; 29};
30 30
31#define chip2controller(chip) \
32 container_of(chip, struct davinci_gpio, chip)
33
31static struct davinci_gpio chips[DIV_ROUND_UP(DAVINCI_N_GPIO, 32)]; 34static struct davinci_gpio chips[DIV_ROUND_UP(DAVINCI_N_GPIO, 32)];
32 35
33/* create a non-inlined version */ 36/* create a non-inlined version */
@@ -54,21 +57,39 @@ static int __init davinci_gpio_irq_setup(void);
54 * needed, and enable the GPIO clock. 57 * needed, and enable the GPIO clock.
55 */ 58 */
56 59
57static int davinci_direction_in(struct gpio_chip *chip, unsigned offset) 60static inline int __davinci_direction(struct gpio_chip *chip,
61 unsigned offset, bool out, int value)
58{ 62{
59 struct davinci_gpio *d = container_of(chip, struct davinci_gpio, chip); 63 struct davinci_gpio *d = chip2controller(chip);
60 struct gpio_controller __iomem *g = d->regs; 64 struct gpio_controller __iomem *g = d->regs;
61 u32 temp; 65 u32 temp;
66 u32 mask = 1 << offset;
62 67
63 spin_lock(&gpio_lock); 68 spin_lock(&gpio_lock);
64 temp = __raw_readl(&g->dir); 69 temp = __raw_readl(&g->dir);
65 temp |= (1 << offset); 70 if (out) {
71 temp &= ~mask;
72 __raw_writel(mask, value ? &g->set_data : &g->clr_data);
73 } else {
74 temp |= mask;
75 }
66 __raw_writel(temp, &g->dir); 76 __raw_writel(temp, &g->dir);
67 spin_unlock(&gpio_lock); 77 spin_unlock(&gpio_lock);
68 78
69 return 0; 79 return 0;
70} 80}
71 81
82static int davinci_direction_in(struct gpio_chip *chip, unsigned offset)
83{
84 return __davinci_direction(chip, offset, false, 0);
85}
86
87static int
88davinci_direction_out(struct gpio_chip *chip, unsigned offset, int value)
89{
90 return __davinci_direction(chip, offset, true, value);
91}
92
72/* 93/*
73 * Read the pin's value (works even if it's set up as output); 94 * Read the pin's value (works even if it's set up as output);
74 * returns zero/nonzero. 95 * returns zero/nonzero.
@@ -78,36 +99,19 @@ static int davinci_direction_in(struct gpio_chip *chip, unsigned offset)
78 */ 99 */
79static int davinci_gpio_get(struct gpio_chip *chip, unsigned offset) 100static int davinci_gpio_get(struct gpio_chip *chip, unsigned offset)
80{ 101{
81 struct davinci_gpio *d = container_of(chip, struct davinci_gpio, chip); 102 struct davinci_gpio *d = chip2controller(chip);
82 struct gpio_controller __iomem *g = d->regs; 103 struct gpio_controller __iomem *g = d->regs;
83 104
84 return (1 << offset) & __raw_readl(&g->in_data); 105 return (1 << offset) & __raw_readl(&g->in_data);
85} 106}
86 107
87static int
88davinci_direction_out(struct gpio_chip *chip, unsigned offset, int value)
89{
90 struct davinci_gpio *d = container_of(chip, struct davinci_gpio, chip);
91 struct gpio_controller __iomem *g = d->regs;
92 u32 temp;
93 u32 mask = 1 << offset;
94
95 spin_lock(&gpio_lock);
96 temp = __raw_readl(&g->dir);
97 temp &= ~mask;
98 __raw_writel(mask, value ? &g->set_data : &g->clr_data);
99 __raw_writel(temp, &g->dir);
100 spin_unlock(&gpio_lock);
101 return 0;
102}
103
104/* 108/*
105 * Assuming the pin is muxed as a gpio output, set its output value. 109 * Assuming the pin is muxed as a gpio output, set its output value.
106 */ 110 */
107static void 111static void
108davinci_gpio_set(struct gpio_chip *chip, unsigned offset, int value) 112davinci_gpio_set(struct gpio_chip *chip, unsigned offset, int value)
109{ 113{
110 struct davinci_gpio *d = container_of(chip, struct davinci_gpio, chip); 114 struct davinci_gpio *d = chip2controller(chip);
111 struct gpio_controller __iomem *g = d->regs; 115 struct gpio_controller __iomem *g = d->regs;
112 116
113 __raw_writel((1 << offset), value ? &g->set_data : &g->clr_data); 117 __raw_writel((1 << offset), value ? &g->set_data : &g->clr_data);
@@ -262,7 +266,7 @@ gpio_irq_handler(unsigned irq, struct irq_desc *desc)
262 266
263static int gpio_to_irq_banked(struct gpio_chip *chip, unsigned offset) 267static int gpio_to_irq_banked(struct gpio_chip *chip, unsigned offset)
264{ 268{
265 struct davinci_gpio *d = container_of(chip, struct davinci_gpio, chip); 269 struct davinci_gpio *d = chip2controller(chip);
266 270
267 if (d->irq_base >= 0) 271 if (d->irq_base >= 0)
268 return d->irq_base + offset; 272 return d->irq_base + offset;