Merge tag 'gpio-v4.5-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux...
[linux-2.6-block.git] / drivers / pinctrl / sirf / pinctrl-sirf.c
index edf40df05ec05b59b73a52c616d4b05472b4becf..762c0c9c127827cad31dd7387f262cd914f76e17 100644 (file)
@@ -403,11 +403,6 @@ static int __init sirfsoc_pinmux_init(void)
 }
 arch_initcall(sirfsoc_pinmux_init);
 
-static inline struct sirfsoc_gpio_chip *to_sirfsoc_gpio(struct gpio_chip *gc)
-{
-       return container_of(gc, struct sirfsoc_gpio_chip, chip.gc);
-}
-
 static inline struct sirfsoc_gpio_bank *
 sirfsoc_gpio_to_bank(struct sirfsoc_gpio_chip *sgpio, unsigned int offset)
 {
@@ -422,7 +417,7 @@ static inline int sirfsoc_gpio_to_bankoff(unsigned int offset)
 static void sirfsoc_gpio_irq_ack(struct irq_data *d)
 {
        struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
-       struct sirfsoc_gpio_chip *sgpio = to_sirfsoc_gpio(gc);
+       struct sirfsoc_gpio_chip *sgpio = gpiochip_get_data(gc);
        struct sirfsoc_gpio_bank *bank = sirfsoc_gpio_to_bank(sgpio, d->hwirq);
        int idx = sirfsoc_gpio_to_bankoff(d->hwirq);
        u32 val, offset;
@@ -461,7 +456,7 @@ static void __sirfsoc_gpio_irq_mask(struct sirfsoc_gpio_chip *sgpio,
 static void sirfsoc_gpio_irq_mask(struct irq_data *d)
 {
        struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
-       struct sirfsoc_gpio_chip *sgpio = to_sirfsoc_gpio(gc);
+       struct sirfsoc_gpio_chip *sgpio = gpiochip_get_data(gc);
        struct sirfsoc_gpio_bank *bank = sirfsoc_gpio_to_bank(sgpio, d->hwirq);
 
        __sirfsoc_gpio_irq_mask(sgpio, bank, d->hwirq % SIRFSOC_GPIO_BANK_SIZE);
@@ -470,7 +465,7 @@ static void sirfsoc_gpio_irq_mask(struct irq_data *d)
 static void sirfsoc_gpio_irq_unmask(struct irq_data *d)
 {
        struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
-       struct sirfsoc_gpio_chip *sgpio = to_sirfsoc_gpio(gc);
+       struct sirfsoc_gpio_chip *sgpio = gpiochip_get_data(gc);
        struct sirfsoc_gpio_bank *bank = sirfsoc_gpio_to_bank(sgpio, d->hwirq);
        int idx = sirfsoc_gpio_to_bankoff(d->hwirq);
        u32 val, offset;
@@ -491,7 +486,7 @@ static void sirfsoc_gpio_irq_unmask(struct irq_data *d)
 static int sirfsoc_gpio_irq_type(struct irq_data *d, unsigned type)
 {
        struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
-       struct sirfsoc_gpio_chip *sgpio = to_sirfsoc_gpio(gc);
+       struct sirfsoc_gpio_chip *sgpio = gpiochip_get_data(gc);
        struct sirfsoc_gpio_bank *bank = sirfsoc_gpio_to_bank(sgpio, d->hwirq);
        int idx = sirfsoc_gpio_to_bankoff(d->hwirq);
        u32 val, offset;
@@ -553,7 +548,7 @@ static void sirfsoc_gpio_handle_irq(struct irq_desc *desc)
 {
        unsigned int irq = irq_desc_get_irq(desc);
        struct gpio_chip *gc = irq_desc_get_handler_data(desc);
-       struct sirfsoc_gpio_chip *sgpio = to_sirfsoc_gpio(gc);
+       struct sirfsoc_gpio_chip *sgpio = gpiochip_get_data(gc);
        struct sirfsoc_gpio_bank *bank;
        u32 status, ctrl;
        int idx = 0;
@@ -611,7 +606,7 @@ static inline void sirfsoc_gpio_set_input(struct sirfsoc_gpio_chip *sgpio,
 
 static int sirfsoc_gpio_request(struct gpio_chip *chip, unsigned offset)
 {
-       struct sirfsoc_gpio_chip *sgpio = to_sirfsoc_gpio(chip);
+       struct sirfsoc_gpio_chip *sgpio = gpiochip_get_data(chip);
        struct sirfsoc_gpio_bank *bank = sirfsoc_gpio_to_bank(sgpio, offset);
        unsigned long flags;
 
@@ -634,7 +629,7 @@ static int sirfsoc_gpio_request(struct gpio_chip *chip, unsigned offset)
 
 static void sirfsoc_gpio_free(struct gpio_chip *chip, unsigned offset)
 {
-       struct sirfsoc_gpio_chip *sgpio = to_sirfsoc_gpio(chip);
+       struct sirfsoc_gpio_chip *sgpio = gpiochip_get_data(chip);
        struct sirfsoc_gpio_bank *bank = sirfsoc_gpio_to_bank(sgpio, offset);
        unsigned long flags;
 
@@ -650,7 +645,7 @@ static void sirfsoc_gpio_free(struct gpio_chip *chip, unsigned offset)
 
 static int sirfsoc_gpio_direction_input(struct gpio_chip *chip, unsigned gpio)
 {
-       struct sirfsoc_gpio_chip *sgpio = to_sirfsoc_gpio(chip);
+       struct sirfsoc_gpio_chip *sgpio = gpiochip_get_data(chip);
        struct sirfsoc_gpio_bank *bank = sirfsoc_gpio_to_bank(sgpio, gpio);
        int idx = sirfsoc_gpio_to_bankoff(gpio);
        unsigned long flags;
@@ -693,7 +688,7 @@ static inline void sirfsoc_gpio_set_output(struct sirfsoc_gpio_chip *sgpio,
 static int sirfsoc_gpio_direction_output(struct gpio_chip *chip,
        unsigned gpio, int value)
 {
-       struct sirfsoc_gpio_chip *sgpio = to_sirfsoc_gpio(chip);
+       struct sirfsoc_gpio_chip *sgpio = gpiochip_get_data(chip);
        struct sirfsoc_gpio_bank *bank = sirfsoc_gpio_to_bank(sgpio, gpio);
        int idx = sirfsoc_gpio_to_bankoff(gpio);
        u32 offset;
@@ -712,7 +707,7 @@ static int sirfsoc_gpio_direction_output(struct gpio_chip *chip,
 
 static int sirfsoc_gpio_get_value(struct gpio_chip *chip, unsigned offset)
 {
-       struct sirfsoc_gpio_chip *sgpio = to_sirfsoc_gpio(chip);
+       struct sirfsoc_gpio_chip *sgpio = gpiochip_get_data(chip);
        struct sirfsoc_gpio_bank *bank = sirfsoc_gpio_to_bank(sgpio, offset);
        u32 val;
        unsigned long flags;
@@ -729,7 +724,7 @@ static int sirfsoc_gpio_get_value(struct gpio_chip *chip, unsigned offset)
 static void sirfsoc_gpio_set_value(struct gpio_chip *chip, unsigned offset,
        int value)
 {
-       struct sirfsoc_gpio_chip *sgpio = to_sirfsoc_gpio(chip);
+       struct sirfsoc_gpio_chip *sgpio = gpiochip_get_data(chip);
        struct sirfsoc_gpio_bank *bank = sirfsoc_gpio_to_bank(sgpio, offset);
        u32 ctrl;
        unsigned long flags;
@@ -815,10 +810,10 @@ static int sirfsoc_gpio_probe(struct device_node *np)
        sgpio->chip.gc.of_node = np;
        sgpio->chip.gc.of_xlate = sirfsoc_gpio_of_xlate;
        sgpio->chip.gc.of_gpio_n_cells = 2;
-       sgpio->chip.gc.dev = &pdev->dev;
+       sgpio->chip.gc.parent = &pdev->dev;
        sgpio->chip.regs = regs;
 
-       err = gpiochip_add(&sgpio->chip.gc);
+       err = gpiochip_add_data(&sgpio->chip.gc, sgpio);
        if (err) {
                dev_err(&pdev->dev, "%s: error in probe function with status %d\n",
                        np->full_name, err);