Commit d74be6df authored by Alexandre Courbot's avatar Alexandre Courbot Committed by Linus Walleij

gpio: remove gpiod_lock/unlock_as_irq()

gpio_lock/unlock_as_irq() are working with (chip, offset) arguments and
are thus not using the old integer namespace. Therefore, there is no
reason to have gpiod variants of these functions working with
descriptors, especially since the (chip, offset) tuple is more suitable
to the users of these functions (GPIO drivers, whereas GPIO descriptors
are targeted at GPIO consumers).
Signed-off-by: default avatarAlexandre Courbot <acourbot@nvidia.com>
Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent 1bd6b601
...@@ -157,12 +157,12 @@ Locking IRQ usage ...@@ -157,12 +157,12 @@ Locking IRQ usage
Input GPIOs can be used as IRQ signals. When this happens, a driver is requested Input GPIOs can be used as IRQ signals. When this happens, a driver is requested
to mark the GPIO as being used as an IRQ: to mark the GPIO as being used as an IRQ:
int gpiod_lock_as_irq(struct gpio_desc *desc) int gpio_lock_as_irq(struct gpio_chip *chip, unsigned int offset)
This will prevent the use of non-irq related GPIO APIs until the GPIO IRQ lock This will prevent the use of non-irq related GPIO APIs until the GPIO IRQ lock
is released: is released:
void gpiod_unlock_as_irq(struct gpio_desc *desc) void gpio_unlock_as_irq(struct gpio_chip *chip, unsigned int offset)
When implementing an irqchip inside a GPIO driver, these two functions should When implementing an irqchip inside a GPIO driver, these two functions should
typically be called in the .startup() and .shutdown() callbacks from the typically be called in the .startup() and .shutdown() callbacks from the
......
...@@ -157,7 +157,7 @@ static acpi_status acpi_gpiochip_request_interrupt(struct acpi_resource *ares, ...@@ -157,7 +157,7 @@ static acpi_status acpi_gpiochip_request_interrupt(struct acpi_resource *ares,
gpiod_direction_input(desc); gpiod_direction_input(desc);
ret = gpiod_lock_as_irq(desc); ret = gpio_lock_as_irq(chip, pin);
if (ret) { if (ret) {
dev_err(chip->dev, "Failed to lock GPIO as interrupt\n"); dev_err(chip->dev, "Failed to lock GPIO as interrupt\n");
goto fail_free_desc; goto fail_free_desc;
...@@ -212,7 +212,7 @@ static acpi_status acpi_gpiochip_request_interrupt(struct acpi_resource *ares, ...@@ -212,7 +212,7 @@ static acpi_status acpi_gpiochip_request_interrupt(struct acpi_resource *ares,
fail_free_event: fail_free_event:
kfree(event); kfree(event);
fail_unlock_irq: fail_unlock_irq:
gpiod_unlock_as_irq(desc); gpio_unlock_as_irq(chip, pin);
fail_free_desc: fail_free_desc:
gpiochip_free_own_desc(desc); gpiochip_free_own_desc(desc);
...@@ -263,7 +263,7 @@ static void acpi_gpiochip_free_interrupts(struct acpi_gpio_chip *acpi_gpio) ...@@ -263,7 +263,7 @@ static void acpi_gpiochip_free_interrupts(struct acpi_gpio_chip *acpi_gpio)
desc = gpiochip_get_desc(chip, event->pin); desc = gpiochip_get_desc(chip, event->pin);
if (WARN_ON(IS_ERR(desc))) if (WARN_ON(IS_ERR(desc)))
continue; continue;
gpiod_unlock_as_irq(desc); gpio_unlock_as_irq(chip, event->pin);
gpiochip_free_own_desc(desc); gpiochip_free_own_desc(desc);
list_del(&event->node); list_del(&event->node);
kfree(event); kfree(event);
......
...@@ -100,15 +100,3 @@ void gpio_free_array(const struct gpio *array, size_t num) ...@@ -100,15 +100,3 @@ void gpio_free_array(const struct gpio *array, size_t num)
gpio_free((array++)->gpio); gpio_free((array++)->gpio);
} }
EXPORT_SYMBOL_GPL(gpio_free_array); EXPORT_SYMBOL_GPL(gpio_free_array);
int gpio_lock_as_irq(struct gpio_chip *chip, unsigned int offset)
{
return gpiod_lock_as_irq(gpiochip_get_desc(chip, offset));
}
EXPORT_SYMBOL_GPL(gpio_lock_as_irq);
void gpio_unlock_as_irq(struct gpio_chip *chip, unsigned int offset)
{
return gpiod_unlock_as_irq(gpiochip_get_desc(chip, offset));
}
EXPORT_SYMBOL_GPL(gpio_unlock_as_irq);
...@@ -161,7 +161,7 @@ static int gpio_setup_irq(struct gpio_desc *desc, struct device *dev, ...@@ -161,7 +161,7 @@ static int gpio_setup_irq(struct gpio_desc *desc, struct device *dev,
desc->flags &= ~GPIO_TRIGGER_MASK; desc->flags &= ~GPIO_TRIGGER_MASK;
if (!gpio_flags) { if (!gpio_flags) {
gpiod_unlock_as_irq(desc); gpio_unlock_as_irq(desc->chip, gpio_chip_hwgpio(desc));
ret = 0; ret = 0;
goto free_id; goto free_id;
} }
...@@ -200,7 +200,7 @@ static int gpio_setup_irq(struct gpio_desc *desc, struct device *dev, ...@@ -200,7 +200,7 @@ static int gpio_setup_irq(struct gpio_desc *desc, struct device *dev,
if (ret < 0) if (ret < 0)
goto free_id; goto free_id;
ret = gpiod_lock_as_irq(desc); ret = gpio_lock_as_irq(desc->chip, gpio_chip_hwgpio(desc));
if (ret < 0) { if (ret < 0) {
gpiod_warn(desc, "failed to flag the GPIO for IRQ\n"); gpiod_warn(desc, "failed to flag the GPIO for IRQ\n");
goto free_id; goto free_id;
......
...@@ -1428,44 +1428,46 @@ int gpiod_to_irq(const struct gpio_desc *desc) ...@@ -1428,44 +1428,46 @@ int gpiod_to_irq(const struct gpio_desc *desc)
EXPORT_SYMBOL_GPL(gpiod_to_irq); EXPORT_SYMBOL_GPL(gpiod_to_irq);
/** /**
* gpiod_lock_as_irq() - lock a GPIO to be used as IRQ * gpio_lock_as_irq() - lock a GPIO to be used as IRQ
* @gpio: the GPIO line to lock as used for IRQ * @chip: the chip the GPIO to lock belongs to
* @offset: the offset of the GPIO to lock as IRQ
* *
* This is used directly by GPIO drivers that want to lock down * This is used directly by GPIO drivers that want to lock down
* a certain GPIO line to be used for IRQs. * a certain GPIO line to be used for IRQs.
*/ */
int gpiod_lock_as_irq(struct gpio_desc *desc) int gpio_lock_as_irq(struct gpio_chip *chip, unsigned int offset)
{ {
if (!desc) if (offset >= chip->ngpio)
return -EINVAL; return -EINVAL;
if (test_bit(FLAG_IS_OUT, &desc->flags)) { if (test_bit(FLAG_IS_OUT, &chip->desc[offset].flags)) {
gpiod_err(desc, chip_err(chip,
"%s: tried to flag a GPIO set as output for IRQ\n", "%s: tried to flag a GPIO set as output for IRQ\n",
__func__); __func__);
return -EIO; return -EIO;
} }
set_bit(FLAG_USED_AS_IRQ, &desc->flags); set_bit(FLAG_USED_AS_IRQ, &chip->desc[offset].flags);
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(gpiod_lock_as_irq); EXPORT_SYMBOL_GPL(gpio_lock_as_irq);
/** /**
* gpiod_unlock_as_irq() - unlock a GPIO used as IRQ * gpio_unlock_as_irq() - unlock a GPIO used as IRQ
* @gpio: the GPIO line to unlock from IRQ usage * @chip: the chip the GPIO to lock belongs to
* @offset: the offset of the GPIO to lock as IRQ
* *
* This is used directly by GPIO drivers that want to indicate * This is used directly by GPIO drivers that want to indicate
* that a certain GPIO is no longer used exclusively for IRQ. * that a certain GPIO is no longer used exclusively for IRQ.
*/ */
void gpiod_unlock_as_irq(struct gpio_desc *desc) void gpio_unlock_as_irq(struct gpio_chip *chip, unsigned int offset)
{ {
if (!desc) if (offset >= chip->ngpio)
return; return;
clear_bit(FLAG_USED_AS_IRQ, &desc->flags); clear_bit(FLAG_USED_AS_IRQ, &chip->desc[offset].flags);
} }
EXPORT_SYMBOL_GPL(gpiod_unlock_as_irq); EXPORT_SYMBOL_GPL(gpio_unlock_as_irq);
/** /**
* gpiod_get_raw_value_cansleep() - return a gpio's raw value * gpiod_get_raw_value_cansleep() - return a gpio's raw value
......
...@@ -110,9 +110,6 @@ static inline int __gpio_to_irq(unsigned gpio) ...@@ -110,9 +110,6 @@ static inline int __gpio_to_irq(unsigned gpio)
return gpiod_to_irq(gpio_to_desc(gpio)); return gpiod_to_irq(gpio_to_desc(gpio));
} }
extern int gpio_lock_as_irq(struct gpio_chip *chip, unsigned int offset);
extern void gpio_unlock_as_irq(struct gpio_chip *chip, unsigned int offset);
extern int gpio_request_one(unsigned gpio, unsigned long flags, const char *label); extern int gpio_request_one(unsigned gpio, unsigned long flags, const char *label);
extern int gpio_request_array(const struct gpio *array, size_t num); extern int gpio_request_array(const struct gpio *array, size_t num);
extern void gpio_free_array(const struct gpio *array, size_t num); extern void gpio_free_array(const struct gpio *array, size_t num);
......
...@@ -146,8 +146,8 @@ extern struct gpio_chip *gpiochip_find(void *data, ...@@ -146,8 +146,8 @@ extern struct gpio_chip *gpiochip_find(void *data,
int (*match)(struct gpio_chip *chip, void *data)); int (*match)(struct gpio_chip *chip, void *data));
/* lock/unlock as IRQ */ /* lock/unlock as IRQ */
int gpiod_lock_as_irq(struct gpio_desc *desc); int gpio_lock_as_irq(struct gpio_chip *chip, unsigned int offset);
void gpiod_unlock_as_irq(struct gpio_desc *desc); void gpio_unlock_as_irq(struct gpio_chip *chip, unsigned int offset);
struct gpio_chip *gpiod_to_chip(const struct gpio_desc *desc); struct gpio_chip *gpiod_to_chip(const struct gpio_desc *desc);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment