diff options
author | Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com> | 2011-10-17 02:28:38 -0400 |
---|---|---|
committer | Arnd Bergmann <arnd@arndb.de> | 2011-11-29 10:46:13 -0500 |
commit | 1a2d9156b5fc92b40aa2ffbc2fdf6d88bbf74f3a (patch) | |
tree | 3765189b74f999ca980279dc797412193d6b50ec /arch/arm/mach-at91/gpio.c | |
parent | 619d4a4b40f44c1b45263a0e0c9598e3139a1fec (diff) |
ARM: at91: gpio make struct at91_gpio_bank an initdata
this will simplify the switch to the DT and later to the platform_device
Signed-off-by: Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
Diffstat (limited to 'arch/arm/mach-at91/gpio.c')
-rw-r--r-- | arch/arm/mach-at91/gpio.c | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/arch/arm/mach-at91/gpio.c b/arch/arm/mach-at91/gpio.c index 4059f07eb955..163c724882c2 100644 --- a/arch/arm/mach-at91/gpio.c +++ b/arch/arm/mach-at91/gpio.c | |||
@@ -29,7 +29,7 @@ | |||
29 | struct at91_gpio_chip { | 29 | struct at91_gpio_chip { |
30 | struct gpio_chip chip; | 30 | struct gpio_chip chip; |
31 | struct at91_gpio_chip *next; /* Bank sharing same clock */ | 31 | struct at91_gpio_chip *next; /* Bank sharing same clock */ |
32 | struct at91_gpio_bank *bank; /* Bank definition */ | 32 | int id; /* ID of register bank */ |
33 | void __iomem *regbase; /* Base of register bank */ | 33 | void __iomem *regbase; /* Base of register bank */ |
34 | struct clk *clock; /* associated clock */ | 34 | struct clk *clock; /* associated clock */ |
35 | }; | 35 | }; |
@@ -286,7 +286,7 @@ static int gpio_irq_set_wake(struct irq_data *d, unsigned state) | |||
286 | else | 286 | else |
287 | wakeups[bank] &= ~mask; | 287 | wakeups[bank] &= ~mask; |
288 | 288 | ||
289 | irq_set_irq_wake(gpio_chip[bank].bank->id, state); | 289 | irq_set_irq_wake(gpio_chip[bank].id, state); |
290 | 290 | ||
291 | return 0; | 291 | return 0; |
292 | } | 292 | } |
@@ -498,7 +498,7 @@ void __init at91_gpio_irq_setup(void) | |||
498 | for (pioc = 0, pin = PIN_BASE, this = gpio_chip, prev = NULL; | 498 | for (pioc = 0, pin = PIN_BASE, this = gpio_chip, prev = NULL; |
499 | pioc++ < gpio_banks; | 499 | pioc++ < gpio_banks; |
500 | prev = this, this++) { | 500 | prev = this, this++) { |
501 | unsigned id = this->bank->id; | 501 | unsigned id = this->id; |
502 | unsigned i; | 502 | unsigned i; |
503 | 503 | ||
504 | __raw_writel(~0, this->regbase + PIO_IDR); | 504 | __raw_writel(~0, this->regbase + PIO_IDR); |
@@ -613,10 +613,10 @@ void __init at91_gpio_init(struct at91_gpio_bank *data, int nr_banks) | |||
613 | for (i = 0; i < nr_banks; i++) { | 613 | for (i = 0; i < nr_banks; i++) { |
614 | at91_gpio = &gpio_chip[i]; | 614 | at91_gpio = &gpio_chip[i]; |
615 | 615 | ||
616 | at91_gpio->bank = &data[i]; | 616 | at91_gpio->id = data[i].id; |
617 | at91_gpio->chip.base = PIN_BASE + i * 32; | 617 | at91_gpio->chip.base = PIN_BASE + i * 32; |
618 | 618 | ||
619 | at91_gpio->regbase = ioremap(at91_gpio->bank->regbase, 512); | 619 | at91_gpio->regbase = ioremap(data[i].regbase, 512); |
620 | if (!at91_gpio->regbase) { | 620 | if (!at91_gpio->regbase) { |
621 | pr_err("at91_gpio.%d, failed to map registers, ignoring.\n", i); | 621 | pr_err("at91_gpio.%d, failed to map registers, ignoring.\n", i); |
622 | continue; | 622 | continue; |
@@ -632,7 +632,7 @@ void __init at91_gpio_init(struct at91_gpio_bank *data, int nr_banks) | |||
632 | clk_enable(at91_gpio->clock); | 632 | clk_enable(at91_gpio->clock); |
633 | 633 | ||
634 | /* AT91SAM9263_ID_PIOCDE groups PIOC, PIOD, PIOE */ | 634 | /* AT91SAM9263_ID_PIOCDE groups PIOC, PIOD, PIOE */ |
635 | if (last && last->bank->id == at91_gpio->bank->id) | 635 | if (last && last->id == at91_gpio->id) |
636 | last->next = at91_gpio; | 636 | last->next = at91_gpio; |
637 | last = at91_gpio; | 637 | last = at91_gpio; |
638 | 638 | ||