gpio: add trace events for setting direction and value
This patch allows to trace gpio operations using ftrace Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de> Signed-off-by: Grant Likely <grant.likely@secretlab.ca>
This commit is contained in:
parent
cc300d9ead
commit
3f397c2144
2 changed files with 72 additions and 2 deletions
|
@ -12,6 +12,8 @@
|
||||||
#include <linux/idr.h>
|
#include <linux/idr.h>
|
||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
|
|
||||||
|
#define CREATE_TRACE_POINTS
|
||||||
|
#include <trace/events/gpio.h>
|
||||||
|
|
||||||
/* Optional implementation infrastructure for GPIO interfaces.
|
/* Optional implementation infrastructure for GPIO interfaces.
|
||||||
*
|
*
|
||||||
|
@ -1405,6 +1407,8 @@ int gpio_direction_input(unsigned gpio)
|
||||||
status = chip->direction_input(chip, gpio);
|
status = chip->direction_input(chip, gpio);
|
||||||
if (status == 0)
|
if (status == 0)
|
||||||
clear_bit(FLAG_IS_OUT, &desc->flags);
|
clear_bit(FLAG_IS_OUT, &desc->flags);
|
||||||
|
|
||||||
|
trace_gpio_direction(chip->base + gpio, 1, status);
|
||||||
lose:
|
lose:
|
||||||
return status;
|
return status;
|
||||||
fail:
|
fail:
|
||||||
|
@ -1458,6 +1462,8 @@ int gpio_direction_output(unsigned gpio, int value)
|
||||||
status = chip->direction_output(chip, gpio, value);
|
status = chip->direction_output(chip, gpio, value);
|
||||||
if (status == 0)
|
if (status == 0)
|
||||||
set_bit(FLAG_IS_OUT, &desc->flags);
|
set_bit(FLAG_IS_OUT, &desc->flags);
|
||||||
|
trace_gpio_value(chip->base + gpio, 0, value);
|
||||||
|
trace_gpio_direction(chip->base + gpio, 0, status);
|
||||||
lose:
|
lose:
|
||||||
return status;
|
return status;
|
||||||
fail:
|
fail:
|
||||||
|
@ -1547,10 +1553,13 @@ EXPORT_SYMBOL_GPL(gpio_set_debounce);
|
||||||
int __gpio_get_value(unsigned gpio)
|
int __gpio_get_value(unsigned gpio)
|
||||||
{
|
{
|
||||||
struct gpio_chip *chip;
|
struct gpio_chip *chip;
|
||||||
|
int value;
|
||||||
|
|
||||||
chip = gpio_to_chip(gpio);
|
chip = gpio_to_chip(gpio);
|
||||||
WARN_ON(chip->can_sleep);
|
WARN_ON(chip->can_sleep);
|
||||||
return chip->get ? chip->get(chip, gpio - chip->base) : 0;
|
value = chip->get ? chip->get(chip, gpio - chip->base) : 0;
|
||||||
|
trace_gpio_value(gpio, 1, value);
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(__gpio_get_value);
|
EXPORT_SYMBOL_GPL(__gpio_get_value);
|
||||||
|
|
||||||
|
@ -1569,6 +1578,7 @@ void __gpio_set_value(unsigned gpio, int value)
|
||||||
|
|
||||||
chip = gpio_to_chip(gpio);
|
chip = gpio_to_chip(gpio);
|
||||||
WARN_ON(chip->can_sleep);
|
WARN_ON(chip->can_sleep);
|
||||||
|
trace_gpio_value(gpio, 0, value);
|
||||||
chip->set(chip, gpio - chip->base, value);
|
chip->set(chip, gpio - chip->base, value);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(__gpio_set_value);
|
EXPORT_SYMBOL_GPL(__gpio_set_value);
|
||||||
|
@ -1619,10 +1629,13 @@ EXPORT_SYMBOL_GPL(__gpio_to_irq);
|
||||||
int gpio_get_value_cansleep(unsigned gpio)
|
int gpio_get_value_cansleep(unsigned gpio)
|
||||||
{
|
{
|
||||||
struct gpio_chip *chip;
|
struct gpio_chip *chip;
|
||||||
|
int value;
|
||||||
|
|
||||||
might_sleep_if(extra_checks);
|
might_sleep_if(extra_checks);
|
||||||
chip = gpio_to_chip(gpio);
|
chip = gpio_to_chip(gpio);
|
||||||
return chip->get ? chip->get(chip, gpio - chip->base) : 0;
|
value = chip->get ? chip->get(chip, gpio - chip->base) : 0;
|
||||||
|
trace_gpio_value(gpio, 1, value);
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(gpio_get_value_cansleep);
|
EXPORT_SYMBOL_GPL(gpio_get_value_cansleep);
|
||||||
|
|
||||||
|
@ -1632,6 +1645,7 @@ void gpio_set_value_cansleep(unsigned gpio, int value)
|
||||||
|
|
||||||
might_sleep_if(extra_checks);
|
might_sleep_if(extra_checks);
|
||||||
chip = gpio_to_chip(gpio);
|
chip = gpio_to_chip(gpio);
|
||||||
|
trace_gpio_value(gpio, 0, value);
|
||||||
chip->set(chip, gpio - chip->base, value);
|
chip->set(chip, gpio - chip->base, value);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(gpio_set_value_cansleep);
|
EXPORT_SYMBOL_GPL(gpio_set_value_cansleep);
|
||||||
|
|
56
include/trace/events/gpio.h
Normal file
56
include/trace/events/gpio.h
Normal file
|
@ -0,0 +1,56 @@
|
||||||
|
#undef TRACE_SYSTEM
|
||||||
|
#define TRACE_SYSTEM gpio
|
||||||
|
|
||||||
|
#if !defined(_TRACE_GPIO_H) || defined(TRACE_HEADER_MULTI_READ)
|
||||||
|
#define _TRACE_GPIO_H
|
||||||
|
|
||||||
|
#include <linux/tracepoint.h>
|
||||||
|
|
||||||
|
TRACE_EVENT(gpio_direction,
|
||||||
|
|
||||||
|
TP_PROTO(unsigned gpio, int in, int err),
|
||||||
|
|
||||||
|
TP_ARGS(gpio, in, err),
|
||||||
|
|
||||||
|
TP_STRUCT__entry(
|
||||||
|
__field(unsigned, gpio)
|
||||||
|
__field(int, in)
|
||||||
|
__field(int, err)
|
||||||
|
),
|
||||||
|
|
||||||
|
TP_fast_assign(
|
||||||
|
__entry->gpio = gpio;
|
||||||
|
__entry->in = in;
|
||||||
|
__entry->err = err;
|
||||||
|
),
|
||||||
|
|
||||||
|
TP_printk("%u %3s (%d)", __entry->gpio,
|
||||||
|
__entry->in ? "in" : "out", __entry->err)
|
||||||
|
);
|
||||||
|
|
||||||
|
TRACE_EVENT(gpio_value,
|
||||||
|
|
||||||
|
TP_PROTO(unsigned gpio, int get, int value),
|
||||||
|
|
||||||
|
TP_ARGS(gpio, get, value),
|
||||||
|
|
||||||
|
TP_STRUCT__entry(
|
||||||
|
__field(unsigned, gpio)
|
||||||
|
__field(int, get)
|
||||||
|
__field(int, value)
|
||||||
|
),
|
||||||
|
|
||||||
|
TP_fast_assign(
|
||||||
|
__entry->gpio = gpio;
|
||||||
|
__entry->get = get;
|
||||||
|
__entry->value = value;
|
||||||
|
),
|
||||||
|
|
||||||
|
TP_printk("%u %3s %d", __entry->gpio,
|
||||||
|
__entry->get ? "get" : "set", __entry->value)
|
||||||
|
);
|
||||||
|
|
||||||
|
#endif /* if !defined(_TRACE_GPIO_H) || defined(TRACE_HEADER_MULTI_READ) */
|
||||||
|
|
||||||
|
/* This part must be outside protection */
|
||||||
|
#include <trace/define_trace.h>
|
Loading…
Reference in a new issue