On Mon,  9 Mar 2015 12:20:13 +0100
Philipp Zabel <p.za...@pengutronix.de> wrote:

Sorry for the late repy, I just noticed this email.

> diff --git a/include/trace/events/regmap.h b/include/trace/events/regmap.h
> index 23d5615..22317d2 100644
> --- a/include/trace/events/regmap.h
> +++ b/include/trace/events/regmap.h
> @@ -7,27 +7,26 @@
>  #include <linux/ktime.h>
>  #include <linux/tracepoint.h>
>  
> -struct device;
> -struct regmap;
> +#include "../../../drivers/base/regmap/internal.h"

Ouch, that is nasty!

Can we move this regmap.h file into drivers/base/regmap/ directory.
The trace_event sample code in samples/trace_events/ explains how to do
that, but for those that are too lazy to read that, I'll explain it here
too ;-)

In drivers/base/regmap/Makefile, add:

CFLAGS_regmap.o = -I$(src)

Then in this header file add at the bottom just before the include of
trace/define_trace.h:

#undef TRACE_INCLUDE_PATH
#define TRACE_INCLUDE_PATH .

Note, if you want to rename this file to something like regmap_trace.h,
then you also need to add:

#undef TRACE_INCLUDE_FILE
#define TRACE_INCLUDE_FILE regmap_trace

And it should all work out. Then you don't need that ugly include and
you can just add:

#include "internal.h"

-- Steve



>  
>  /*
>   * Log register events
>   */
>  DECLARE_EVENT_CLASS(regmap_reg,
>  
> -     TP_PROTO(struct device *dev, unsigned int reg,
> +     TP_PROTO(struct regmap *map, unsigned int reg,
>                unsigned int val),
>  
> -     TP_ARGS(dev, reg, val),
> +     TP_ARGS(map, reg, val),
>  
>       TP_STRUCT__entry(
> -             __string(       name,           dev_name(dev)   )
> -             __field(        unsigned int,   reg             )
> -             __field(        unsigned int,   val             )
> +             __string(       name,           regmap_name(map)        )
> +             __field(        unsigned int,   reg                     )
> +             __field(        unsigned int,   val                     )
>       ),
>  
>       TP_fast_assign(
> -             __assign_str(name, dev_name(dev));
> +             __assign_str(name, regmap_name(map));
>               __entry->reg = reg;
>               __entry->val = val;
>       ),
> @@ -39,45 +38,45 @@ DECLARE_EVENT_CLASS(regmap_reg,
>  
>  DEFINE_EVENT(regmap_reg, regmap_reg_write,
>  
> -     TP_PROTO(struct device *dev, unsigned int reg,
> +     TP_PROTO(struct regmap *map, unsigned int reg,
>                unsigned int val),
>  
> -     TP_ARGS(dev, reg, val)
> +     TP_ARGS(map, reg, val)
>  
>  );
>  
>  DEFINE_EVENT(regmap_reg, regmap_reg_read,
>  
> -     TP_PROTO(struct device *dev, unsigned int reg,
> +     TP_PROTO(struct regmap *map, unsigned int reg,
>                unsigned int val),
>  
> -     TP_ARGS(dev, reg, val)
> +     TP_ARGS(map, reg, val)
>  
>  );
>  
>  DEFINE_EVENT(regmap_reg, regmap_reg_read_cache,
>  
> -     TP_PROTO(struct device *dev, unsigned int reg,
> +     TP_PROTO(struct regmap *map, unsigned int reg,
>                unsigned int val),
>  
> -     TP_ARGS(dev, reg, val)
> +     TP_ARGS(map, reg, val)
>  
>  );
>  
>  DECLARE_EVENT_CLASS(regmap_block,
>  
> -     TP_PROTO(struct device *dev, unsigned int reg, int count),
> +     TP_PROTO(struct regmap *map, unsigned int reg, int count),
>  
> -     TP_ARGS(dev, reg, count),
> +     TP_ARGS(map, reg, count),
>  
>       TP_STRUCT__entry(
> -             __string(       name,           dev_name(dev)   )
> -             __field(        unsigned int,   reg             )
> -             __field(        int,            count           )
> +             __string(       name,           regmap_name(map)        )
> +             __field(        unsigned int,   reg                     )
> +             __field(        int,            count                   )
>       ),
>  
>       TP_fast_assign(
> -             __assign_str(name, dev_name(dev));
> +             __assign_str(name, regmap_name(map));
>               __entry->reg = reg;
>               __entry->count = count;
>       ),
> @@ -89,48 +88,48 @@ DECLARE_EVENT_CLASS(regmap_block,
>  
>  DEFINE_EVENT(regmap_block, regmap_hw_read_start,
>  
> -     TP_PROTO(struct device *dev, unsigned int reg, int count),
> +     TP_PROTO(struct regmap *map, unsigned int reg, int count),
>  
> -     TP_ARGS(dev, reg, count)
> +     TP_ARGS(map, reg, count)
>  );
>  
>  DEFINE_EVENT(regmap_block, regmap_hw_read_done,
>  
> -     TP_PROTO(struct device *dev, unsigned int reg, int count),
> +     TP_PROTO(struct regmap *map, unsigned int reg, int count),
>  
> -     TP_ARGS(dev, reg, count)
> +     TP_ARGS(map, reg, count)
>  );
>  
>  DEFINE_EVENT(regmap_block, regmap_hw_write_start,
>  
> -     TP_PROTO(struct device *dev, unsigned int reg, int count),
> +     TP_PROTO(struct regmap *map, unsigned int reg, int count),
>  
> -     TP_ARGS(dev, reg, count)
> +     TP_ARGS(map, reg, count)
>  );
>  
>  DEFINE_EVENT(regmap_block, regmap_hw_write_done,
>  
> -     TP_PROTO(struct device *dev, unsigned int reg, int count),
> +     TP_PROTO(struct regmap *map, unsigned int reg, int count),
>  
> -     TP_ARGS(dev, reg, count)
> +     TP_ARGS(map, reg, count)
>  );
>  
>  TRACE_EVENT(regcache_sync,
>  
> -     TP_PROTO(struct device *dev, const char *type,
> +     TP_PROTO(struct regmap *map, const char *type,
>                const char *status),
>  
> -     TP_ARGS(dev, type, status),
> +     TP_ARGS(map, type, status),
>  
>       TP_STRUCT__entry(
> -             __string(       name,           dev_name(dev)   )
> -             __string(       status,         status          )
> -             __string(       type,           type            )
> -             __field(        int,            type            )
> +             __string(       name,           regmap_name(map)        )
> +             __string(       status,         status                  )
> +             __string(       type,           type                    )
> +             __field(        int,            type                    )
>       ),
>  
>       TP_fast_assign(
> -             __assign_str(name, dev_name(dev));
> +             __assign_str(name, regmap_name(map));
>               __assign_str(status, status);
>               __assign_str(type, type);
>       ),
> @@ -141,17 +140,17 @@ TRACE_EVENT(regcache_sync,
>  
>  DECLARE_EVENT_CLASS(regmap_bool,
>  
> -     TP_PROTO(struct device *dev, bool flag),
> +     TP_PROTO(struct regmap *map, bool flag),
>  
> -     TP_ARGS(dev, flag),
> +     TP_ARGS(map, flag),
>  
>       TP_STRUCT__entry(
> -             __string(       name,           dev_name(dev)   )
> -             __field(        int,            flag            )
> +             __string(       name,           regmap_name(map)        )
> +             __field(        int,            flag                    )
>       ),
>  
>       TP_fast_assign(
> -             __assign_str(name, dev_name(dev));
> +             __assign_str(name, regmap_name(map));
>               __entry->flag = flag;
>       ),
>  
> @@ -161,32 +160,32 @@ DECLARE_EVENT_CLASS(regmap_bool,
>  
>  DEFINE_EVENT(regmap_bool, regmap_cache_only,
>  
> -     TP_PROTO(struct device *dev, bool flag),
> +     TP_PROTO(struct regmap *map, bool flag),
>  
> -     TP_ARGS(dev, flag)
> +     TP_ARGS(map, flag)
>  
>  );
>  
>  DEFINE_EVENT(regmap_bool, regmap_cache_bypass,
>  
> -     TP_PROTO(struct device *dev, bool flag),
> +     TP_PROTO(struct regmap *map, bool flag),
>  
> -     TP_ARGS(dev, flag)
> +     TP_ARGS(map, flag)
>  
>  );
>  
>  DECLARE_EVENT_CLASS(regmap_async,
>  
> -     TP_PROTO(struct device *dev),
> +     TP_PROTO(struct regmap *map),
>  
> -     TP_ARGS(dev),
> +     TP_ARGS(map),
>  
>       TP_STRUCT__entry(
> -             __string(       name,           dev_name(dev)   )
> +             __string(       name,           regmap_name(map)        )
>       ),
>  
>       TP_fast_assign(
> -             __assign_str(name, dev_name(dev));
> +             __assign_str(name, regmap_name(map));
>       ),
>  
>       TP_printk("%s", __get_str(name))
> @@ -194,50 +193,50 @@ DECLARE_EVENT_CLASS(regmap_async,
>  
>  DEFINE_EVENT(regmap_block, regmap_async_write_start,
>  
> -     TP_PROTO(struct device *dev, unsigned int reg, int count),
> +     TP_PROTO(struct regmap *map, unsigned int reg, int count),
>  
> -     TP_ARGS(dev, reg, count)
> +     TP_ARGS(map, reg, count)
>  );
>  
>  DEFINE_EVENT(regmap_async, regmap_async_io_complete,
>  
> -     TP_PROTO(struct device *dev),
> +     TP_PROTO(struct regmap *map),
>  
> -     TP_ARGS(dev)
> +     TP_ARGS(map)
>  
>  );
>  
>  DEFINE_EVENT(regmap_async, regmap_async_complete_start,
>  
> -     TP_PROTO(struct device *dev),
> +     TP_PROTO(struct regmap *map),
>  
> -     TP_ARGS(dev)
> +     TP_ARGS(map)
>  
>  );
>  
>  DEFINE_EVENT(regmap_async, regmap_async_complete_done,
>  
> -     TP_PROTO(struct device *dev),
> +     TP_PROTO(struct regmap *map),
>  
> -     TP_ARGS(dev)
> +     TP_ARGS(map)
>  
>  );
>  
>  TRACE_EVENT(regcache_drop_region,
>  
> -     TP_PROTO(struct device *dev, unsigned int from,
> +     TP_PROTO(struct regmap *map, unsigned int from,
>                unsigned int to),
>  
> -     TP_ARGS(dev, from, to),
> +     TP_ARGS(map, from, to),
>  
>       TP_STRUCT__entry(
> -             __string(       name,           dev_name(dev)   )
> -             __field(        unsigned int,   from            )
> -             __field(        unsigned int,   to              )
> +             __string(       name,           regmap_name(map)        )
> +             __field(        unsigned int,   from                    )
> +             __field(        unsigned int,   to                      )
>       ),
>  
>       TP_fast_assign(
> -             __assign_str(name, dev_name(dev));
> +             __assign_str(name, regmap_name(map));
>               __entry->from = from;
>               __entry->to = to;
>       ),

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to