Commit 6f4350a6 authored by Linus Walleij's avatar Linus Walleij

pinctrl/nomadik: break out single GPIO debug function

Break out the code displaying the status of a single pin so we
can use the same code in the pinctrl debug function.
Acked-by: default avatarStephen Warren <swarren@wwwdotorg.org>
Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent e98ea774
...@@ -943,14 +943,16 @@ static int nmk_gpio_to_irq(struct gpio_chip *chip, unsigned offset) ...@@ -943,14 +943,16 @@ static int nmk_gpio_to_irq(struct gpio_chip *chip, unsigned offset)
#include <linux/seq_file.h> #include <linux/seq_file.h>
static void nmk_gpio_dbg_show(struct seq_file *s, struct gpio_chip *chip) static void nmk_gpio_dbg_show_one(struct seq_file *s, struct gpio_chip *chip,
unsigned offset, unsigned gpio)
{ {
int mode; const char *label = gpiochip_is_requested(chip, offset);
unsigned i;
unsigned gpio = chip->base;
int is_out;
struct nmk_gpio_chip *nmk_chip = struct nmk_gpio_chip *nmk_chip =
container_of(chip, struct nmk_gpio_chip, chip); container_of(chip, struct nmk_gpio_chip, chip);
int mode;
bool is_out;
bool pull;
u32 bit = 1 << offset;
const char *modes[] = { const char *modes[] = {
[NMK_GPIO_ALT_GPIO] = "gpio", [NMK_GPIO_ALT_GPIO] = "gpio",
[NMK_GPIO_ALT_A] = "altA", [NMK_GPIO_ALT_A] = "altA",
...@@ -959,56 +961,63 @@ static void nmk_gpio_dbg_show(struct seq_file *s, struct gpio_chip *chip) ...@@ -959,56 +961,63 @@ static void nmk_gpio_dbg_show(struct seq_file *s, struct gpio_chip *chip)
}; };
clk_enable(nmk_chip->clk); clk_enable(nmk_chip->clk);
is_out = !!(readl(nmk_chip->addr + NMK_GPIO_DIR) & bit);
for (i = 0; i < chip->ngpio; i++, gpio++) { pull = !(readl(nmk_chip->addr + NMK_GPIO_PDIS) & bit);
const char *label = gpiochip_is_requested(chip, i); mode = nmk_gpio_get_mode(gpio);
bool pull;
u32 bit = 1 << i; seq_printf(s, " gpio-%-3d (%-20.20s) %s %s %s %s",
gpio, label ?: "(none)",
is_out = readl(nmk_chip->addr + NMK_GPIO_DIR) & bit; is_out ? "out" : "in ",
pull = !(readl(nmk_chip->addr + NMK_GPIO_PDIS) & bit); chip->get
mode = nmk_gpio_get_mode(gpio); ? (chip->get(chip, offset) ? "hi" : "lo")
seq_printf(s, " gpio-%-3d (%-20.20s) %s %s %s %s", : "? ",
gpio, label ?: "(none)", (mode < 0) ? "unknown" : modes[mode],
is_out ? "out" : "in ", pull ? "pull" : "none");
chip->get
? (chip->get(chip, i) ? "hi" : "lo") if (label && !is_out) {
: "? ", int irq = gpio_to_irq(gpio);
(mode < 0) ? "unknown" : modes[mode], struct irq_desc *desc = irq_to_desc(irq);
pull ? "pull" : "none");
/* This races with request_irq(), set_irq_type(),
if (label && !is_out) { * and set_irq_wake() ... but those are "rare".
int irq = gpio_to_irq(gpio); */
struct irq_desc *desc = irq_to_desc(irq); if (irq >= 0 && desc->action) {
char *trigger;
/* This races with request_irq(), set_irq_type(), u32 bitmask = nmk_gpio_get_bitmask(gpio);
* and set_irq_wake() ... but those are "rare".
*/ if (nmk_chip->edge_rising & bitmask)
if (irq >= 0 && desc->action) { trigger = "edge-rising";
char *trigger; else if (nmk_chip->edge_falling & bitmask)
u32 bitmask = nmk_gpio_get_bitmask(gpio); trigger = "edge-falling";
else
if (nmk_chip->edge_rising & bitmask) trigger = "edge-undefined";
trigger = "edge-rising";
else if (nmk_chip->edge_falling & bitmask) seq_printf(s, " irq-%d %s%s",
trigger = "edge-falling"; irq, trigger,
else irqd_is_wakeup_set(&desc->irq_data)
trigger = "edge-undefined"; ? " wakeup" : "");
seq_printf(s, " irq-%d %s%s",
irq, trigger,
irqd_is_wakeup_set(&desc->irq_data)
? " wakeup" : "");
}
} }
}
clk_disable(nmk_chip->clk);
}
static void nmk_gpio_dbg_show(struct seq_file *s, struct gpio_chip *chip)
{
unsigned i;
unsigned gpio = chip->base;
for (i = 0; i < chip->ngpio; i++, gpio++) {
nmk_gpio_dbg_show_one(s, chip, i, gpio);
seq_printf(s, "\n"); seq_printf(s, "\n");
} }
clk_disable(nmk_chip->clk);
} }
#else #else
static inline void nmk_gpio_dbg_show_one(struct seq_file *s,
struct gpio_chip *chip,
unsigned offset, unsigned gpio)
{
}
#define nmk_gpio_dbg_show NULL #define nmk_gpio_dbg_show NULL
#endif #endif
......
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