Search Linux Wireless

Re: [PATCH 4/4] compat: add some tracing backport work

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, Mar 26, 2012 at 10:49:28AM +0200, Johannes Berg wrote:
> On Wed, 2012-03-21 at 21:29 -0700, Luis R. Rodriguez wrote:
> 
> > But no dice. I then figured it may be my kernel with
> > CONFIG_TRACEPOINTS=y and indeed that is the case -- so we have to
> > consider the case where the target kernel may have tracing enabled and
> > we have to disable it somehow. Undef'ing CONFIG_TRACEPOINTS and
> > DECLARE_TRACE doesn't really do it.
> 
> Oh, ok, yuck. So I guess we can't easily disable tracing if it's enabled
> in the base kernel ...

Its a  bit tough.

> > We may need to redefine each macro to some COMPAT_TRACE_ macro, not sure yet.
> 
> That would require patches again though, no fun either.

Agreed.

I've gotten a bit farther:

This is not yet complete. At least for mac80211 we fail with:

  CC [M]  /home/mcgrof/devel/compat-wireless/net/mac80211/driver-trace.o
In file included from include/trace/ftrace.h:554:0,
                 from include/trace/define_trace.h:96,
                 from /home/mcgrof/devel/compat-wireless/include/trace/define_trace.h:4,
                 from /home/mcgrof/devel/compat-wireless/net/mac80211/driver-trace.h:1559,
                 from /home/mcgrof/devel/compat-wireless/net/mac80211/driver-trace.c:8:
/home/mcgrof/devel/compat-wireless/net/mac80211/./driver-trace.h: In function ‘ftrace_test_probe_drv_return_void’:
/home/mcgrof/devel/compat-wireless/net/mac80211/./driver-trace.h:111:2: error: implicit declaration of function ‘check_trace_callback_type_drv_return_void’

This is against v2.6.33

And ckmake log:

mcgrof@tux ~/compat (git::master)$ ckmake 
Trying kernel                  3.3.0-030300rc2-generic	[OK]
Trying kernel                     3.2.2-030202-generic	[OK]
Trying kernel                    3.1.10-030110-generic	[OK]
Trying kernel                    3.0.18-030018-generic	[OK]
Trying kernel                  2.6.39-02063904-generic	[OK]
Trying kernel                        2.6.38-13-generic	[OK]
Trying kernel                  2.6.38-02063808-generic	[OK]
Trying kernel                  2.6.37-02063706-generic	[FAILED]
Trying kernel                  2.6.36-02063604-generic	[FAILED]
Trying kernel                  2.6.35-02063512-generic	[FAILED]
Trying kernel                  2.6.34-02063410-generic	[OK]
Trying kernel                  2.6.33-02063305-generic	[OK]
Trying kernel                  2.6.32-02063255-generic	[OK]
Trying kernel                        2.6.31-22-generic	[OK]
Trying kernel                  2.6.31-02063113-generic	[OK]
Trying kernel                  2.6.30-02063010-generic	[OK]
Trying kernel                  2.6.29-02062906-generic	[OK]
Trying kernel                  2.6.28-02062810-generic	[OK]
Trying kernel                    2.6.27-020627-generic	[OK]
Trying kernel                    2.6.26-020626-generic	[OK]
Trying kernel                    2.6.25-020625-generic	[OK]
Trying kernel                    2.6.24-020624-generic	[OK]


---
 include/linux/tracepoint.h |   57 ++++++++++++++++++++++++++++++++++++++++----
 1 file changed, 53 insertions(+), 4 deletions(-)

diff --git a/include/linux/tracepoint.h b/include/linux/tracepoint.h
index a5bd743..4930600 100644
--- a/include/linux/tracepoint.h
+++ b/include/linux/tracepoint.h
@@ -10,13 +10,16 @@
 /* Backports f42c85e7 */
 #if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,30))
 #undef TP_STRUCT__entry
+/* XXX: Is this right when CONFIG_TRACEPOINTS is enabled ? */
 #define TP_STRUCT__entry(args...) args
 #endif
 
-#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,33))
 /* Backports 091ad365, a rename */
+#if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,33))
 #define DECLARE_EVENT_CLASS TRACE_EVENT_TEMPLATE
+#endif
 
+/* Backpports 2939b0469 */
 #if (LINUX_VERSION_CODE < KERNEL_VERSION(2,6,30))
 #define TP_PROTO TPPROTO
 #define TP_ARGS TPARGS
@@ -24,7 +27,53 @@
 #define TP_RAW_FMT TPRAWFMT
 #endif
 
-#endif
+/* Force disabling tracing */
+#undef TRACE_EVENT
+#define TRACE_EVENT(name, proto, ...) \
+static inline void trace_ ## name(proto) {}
+#undef DECLARE_EVENT_CLASS
+#define DECLARE_EVENT_CLASS(...)
+#undef DEFINE_EVENT
+#define DEFINE_EVENT(evt_class, name, proto, ...) \
+static inline void trace_ ## name(proto) {}
+
+#undef __DECLARE_TRACE
+#define __DECLARE_TRACE(name, proto, args, cond, data_proto, data_args) \
+	static inline void trace_##name(proto)				\
+	{ }								\
+	static inline void trace_##name##_rcuidle(proto)		\
+	{ }								\
+	static inline int						\
+	register_trace_##name(void (*probe)(data_proto),		\
+			      void *data)				\
+	{								\
+		return -ENOSYS;						\
+	}								\
+	static inline int						\
+	unregister_trace_##name(void (*probe)(data_proto),		\
+				void *data)				\
+	{								\
+		return -ENOSYS;						\
+	}								\
+	static inline void check_trace_callback_type_##name(void (*cb)(data_proto)) \
+	{								\
+	}
+
+#undef DEFINE_TRACE_FN
+#define DEFINE_TRACE_FN(name, reg, unreg)
+
+#undef DEFINE_TRACE
+#define DEFINE_TRACE(name)
+
+#undef EXPORT_TRACEPOINT_SYMBOL_GPL
+#define EXPORT_TRACEPOINT_SYMBOL_GPL(name)
+
+#undef EXPORT_TRACEPOINT_SYMBOL
+#define EXPORT_TRACEPOINT_SYMBOL(name)
+
+#ifdef CONFIG_TRACEPOINTS
+#else /* CONFIG_TRACEPOINTS */
+#endif /* CONFIG_TRACEPOINTS */
 
 #else /* just disable tracing */
 
@@ -42,8 +91,8 @@ static inline void trace_ ## name(proto) {}
 #define TP_ARGS(args...)   args
 #define TP_CONDITION(args...)      args
 
-struct tracepoint_iter {
-};
+//struct tracepoint_iter {
+//};
 
 #endif /* (LINUX_VERSION_CODE > KERNEL_VERSION(2,6,27)) */
 
-- 
1.7.10.rc1.22.gf5241

--
To unsubscribe from this list: send the line "unsubscribe linux-wireless" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Host AP]     [ATH6KL]     [Linux Wireless Personal Area Network]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [Linux Kernel]     [IDE]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite Hiking]     [MIPS Linux]     [ARM Linux]     [Linux RAID]

  Powered by Linux