This is an automated email from the ASF dual-hosted git repository.

acassis pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/nuttx.git


The following commit(s) were added to refs/heads/master by this push:
     new 9015f409098 trace: add mark and printf support
9015f409098 is described below

commit 9015f409098b8563a20b595c980318ccc1790e9a
Author: yinshengkai <[email protected]>
AuthorDate: Tue Oct 29 22:51:56 2024 +0800

    trace: add mark and printf support
    
    Add new trace macros: trace_mark and trace_printf.
    
    Signed-off-by: yinshengkai <[email protected]>
---
 include/nuttx/trace.h | 142 +++++++++++++++++++++++++++++++++++++++++++++++++-
 1 file changed, 140 insertions(+), 2 deletions(-)

diff --git a/include/nuttx/trace.h b/include/nuttx/trace.h
index 6e8e0b7a86e..f604176c7c0 100644
--- a/include/nuttx/trace.h
+++ b/include/nuttx/trace.h
@@ -36,135 +36,273 @@
 #ifdef CONFIG_TRACE
 #  define trace_begin(tag) sched_note_begin(tag)
 #  define trace_end(tag) sched_note_end(tag)
-
 #  define trace_beginex(tag, name) sched_note_beginex(tag, name)
 #  define trace_endex(tag, name) sched_note_endex(tag, name)
+#  define trace_mark(tag, s) sched_note_mark(tag, s)
+#  define trace_printf(tag, fmt, ...)
+    sched_note_printf(tag, fmt, ##__VA_ARGS__)
 #else
 #  define trace_begin(tag)
 #  define trace_end(tag)
-
 #  define trace_beginex(tag, name)
 #  define trace_endex(tag, name)
+#  define trace_mark(tag, s)
+#  define trace_printf(...)
 #endif
 
 #ifdef CONFIG_TRACE_APP
 #  define app_trace_begin() trace_begin(NOTE_TAG_APP)
 #  define app_trace_end() trace_end(NOTE_TAG_APP)
+#  define app_trace_beginex(name) trace_beginex(NOTE_TAG_APP, name)
+#  define app_trace_endex(name) trace_endex(NOTE_TAG_APP, name)
+#  define app_trace_mark(s) trace_mark(NOTE_TAG_APP, s)
+#  define app_trace_printf(fmt, ...)
+    sched_note_printf(NOTE_TAG_APP, fmt, ##__VA_ARGS__)
 #else
 #  define app_trace_begin()
 #  define app_trace_end()
+#  define app_trace_beginex(name)
+#  define app_trace_endex(name)
+#  define app_trace_mark(s)
+#  define app_trace_printf(...)
 #endif
 
 #ifdef CONFIG_TRACE_ARCH
 #  define arch_trace_begin() trace_begin(NOTE_TAG_ARCH)
 #  define arch_trace_end() trace_end(NOTE_TAG_ARCH)
+#  define arch_trace_beginex(name) trace_beginex(NOTE_TAG_ARCH, name)
+#  define arch_trace_endex(name) trace_endex(NOTE_TAG_ARCH, name)
+#  define arch_trace_mark(s) trace_mark(NOTE_TAG_ARCH, s)
+#  define arch_trace_printf(fmt, ...) \
+    trace_printf(NOTE_TAG_ARCH, fmt, ##__VA_ARGS__)
 #else
 #  define arch_trace_begin()
 #  define arch_trace_end()
+#  define arch_trace_beginex(name)
+#  define arch_trace_endex(name)
+#  define arch_trace_mark(s)
+#  define arch_trace_printf(...)
 #endif
 
 #ifdef CONFIG_TRACE_AUDIO
 #  define audio_trace_begin() trace_begin(NOTE_TAG_AUDIO)
 #  define audio_trace_end() trace_end(NOTE_TAG_AUDIO)
+#  define audio_trace_beginex(name) trace_beginex(NOTE_TAG_AUDIO, name)
+#  define audio_trace_endex(name) trace_endex(NOTE_TAG_AUDIO, name)
+#  define audio_trace_mark(s) trace_mark(NOTE_TAG_AUDIO, s)
+#  define audio_trace_printf(fmt, ...) \
+    trace_printf(NOTE_TAG_AUDIO, fmt, ##__VA_ARGS__)
 #else
 #  define audio_trace_begin()
 #  define audio_trace_end()
+#  define audio_trace_beginex(name)
+#  define audio_trace_endex(name)
+#  define audio_trace_mark(s)
+#  define audio_trace_printf(...)
 #endif
 
 #ifdef CONFIG_TRACE_BOARDS
 #  define boards_trace_begin() trace_begin(NOTE_TAG_BOARDS)
 #  define boards_trace_end() trace_end(NOTE_TAG_BOARDS)
+#  define boards_trace_beginex(name) trace_beginex(NOTE_TAG_BOARDS, name)
+#  define boards_trace_endex(name) trace_endex(NOTE_TAG_BOARDS, name)
+#  define boards_trace_mark(s) trace_mark(NOTE_TAG_BOARDS, s)
+#  define boards_trace_printf(fmt, ...) \
+    trace_printf(NOTE_TAG_BOARDS, fmt, ##__VA_ARGS__)
 #else
 #  define boards_trace_begin()
 #  define boards_trace_end()
+#  define boards_trace_beginex(name)
+#  define boards_trace_endex(name)
+#  define boards_trace_mark(s)
+#  define boards_trace_printf(...)
 #endif
 
 #ifdef CONFIG_TRACE_CRYPTO
 #  define crypto_trace_begin() trace_begin(NOTE_TAG_CRYPTO)
 #  define crypto_trace_end() trace_end(NOTE_TAG_CRYPTO)
+#  define crypto_trace_beginex(name) trace_beginex(NOTE_TAG_CRYPTO, name)
+#  define crypto_trace_endex(name) trace_endex(NOTE_TAG_CRYPTO, name)
+#  define crypto_trace_mark(s) trace_mark(NOTE_TAG_CRYPTO, s)
+#  define crypto_trace_printf(fmt, ...) \
+    trace_printf(NOTE_TAG_CRYPTO, fmt, ##__VA_ARGS__)
 #else
 #  define crypto_trace_begin()
 #  define crypto_trace_end()
+#  define crypto_trace_beginex(name)
+#  define crypto_trace_endex(name)
+#  define crypto_trace_mark(s)
+#  define crypto_trace_printf(...)
 #endif
 
 #ifdef CONFIG_TRACE_DRIVERS
 #  define drivers_trace_begin() trace_begin(NOTE_TAG_DRIVERS)
 #  define drivers_trace_end() trace_end(NOTE_TAG_DRIVERS)
+#  define drivers_trace_beginex(name) trace_beginex(NOTE_TAG_DRIVERS, name)
+#  define drivers_trace_endex(name) trace_endex(NOTE_TAG_DRIVERS, name)
+#  define drivers_trace_mark(s) trace_mark(NOTE_TAG_DRIVERS, s)
+#  define drivers_trace_printf(fmt, ...) \
+    trace_printf(NOTE_TAG_DRIVERS, fmt, )
 #else
 #  define drivers_trace_begin()
 #  define drivers_trace_end()
+#  define drivers_trace_beginex(name)
+#  define drivers_trace_endex(name)
+#  define drivers_trace_mark(s)
+#  define drivers_trace_printf(...)
 #endif
 
 #ifdef CONFIG_TRACE_FS
 #  define fs_trace_begin() trace_begin(NOTE_TAG_FS)
 #  define fs_trace_end() trace_end(NOTE_TAG_FS)
+#  define fs_trace_beginex(name) trace_beginex(NOTE_TAG_FS, name)
+#  define fs_trace_endex(name) trace_endex(NOTE_TAG_FS, name)
+#  define fs_trace_mark(s) trace_mark(NOTE_TAG_FS, s)
+#  define fs_trace_printf(fmt, ...) \
+    trace_printf(NOTE_TAG_FS, fmt, ##__VA_ARGS__)
 #else
 #  define fs_trace_begin()
 #  define fs_trace_end()
+#  define fs_trace_beginex(name)
+#  define fs_trace_endex(name)
+#  define fs_trace_mark(s)
+#  define fs_trace_printf(...)
 #endif
 
 #ifdef CONFIG_TRACE_GRAPHICS
 #  define graphics_trace_begin() trace_begin(NOTE_TAG_GRAPHICS)
 #  define graphics_trace_end() trace_end(NOTE_TAG_GRAPHICS)
+#  define graphics_trace_beginex(name) trace_beginex(NOTE_TAG_GRAPHICS, name)
+#  define graphics_trace_endex(name) trace_endex(NOTE_TAG_GRAPHICS, name)
+#  define graphics_trace_mark(s) trace_mark(NOTE_TAG_GRAPHICS, s)
+#  define graphics_trace_printf(fmt, ...) \
+    trace_printf(NOTE_TAG_GRAPHICS, fmt, ##__VA_ARGS__)
 #else
 #  define graphics_trace_begin()
 #  define graphics_trace_end()
+#  define graphics_trace_beginex(name)
+#  define graphics_trace_endex(name)
+#  define graphics_trace_mark(s)
+#  define graphics_trace_printf(...)
 #endif
 
 #ifdef CONFIG_TRACE_INPUT
 #  define input_trace_begin() trace_begin(NOTE_TAG_INPUT)
 #  define input_trace_end() trace_end(NOTE_TAG_INPUT)
+#  define input_trace_beginex(name) trace_beginex(NOTE_TAG_INPUT, name)
+#  define input_trace_endex(name) trace_endex(NOTE_TAG_INPUT, name)
+#  define input_trace_mark(s) trace_mark(NOTE_TAG_INPUT, s)
+#  define input_trace_printf(fmt, ...) \
+    trace_printf(NOTE_TAG_INPUT, fmt, ##__VA_ARGS__)
 #else
 #  define input_trace_begin()
 #  define input_trace_end()
+#  define input_trace_beginex(name)
+#  define input_trace_endex(name)
+#  define input_trace_mark(s)
+#  define input_trace_printf(...)
 #endif
 
 #ifdef CONFIG_TRACE_LIBS
 #  define libs_trace_begin() trace_begin(NOTE_TAG_LIBS)
 #  define libs_trace_end() trace_end(NOTE_TAG_LIBS)
+#  define libs_trace_beginex(name) trace_beginex(NOTE_TAG_LIBS, name)
+#  define libs_trace_endex(name) trace_endex(NOTE_TAG_LIBS, name)
+#  define libs_trace_mark(s) trace_mark(NOTE_TAG_LIBS, s)
+#  define libs_trace_printf(fmt, ...) \
+    trace_printf(NOTE_TAG_LIBS, fmt, ##__VA_ARGS__)
 #else
 #  define libs_trace_begin()
 #  define libs_trace_end()
+#  define libs_trace_beginex(name)
+#  define libs_trace_endex(name)
+#  define libs_trace_mark(s)
+#  define libs_trace_printf(...)
 #endif
 
 #ifdef CONFIG_TRACE_MM
 #  define mm_trace_begin() trace_begin(NOTE_TAG_MM)
 #  define mm_trace_end() trace_end(NOTE_TAG_MM)
+#  define mm_trace_beginex(name) trace_beginex(NOTE_TAG_MM, name)
+#  define mm_trace_endex(name) trace_endex(NOTE_TAG_MM, name)
+#  define mm_trace_mark(s) trace_mark(NOTE_TAG_MM, s)
+#  define mm_trace_printf(fmt, ...) \
+    trace_printf(NOTE_TAG_MM, fmt, ##__VA_ARGS__)
 #else
 #  define mm_trace_begin()
 #  define mm_trace_end()
+#  define mm_trace_beginex(name)
+#  define mm_trace_endex(name)
+#  define mm_trace_mark(s)
+#  define mm_trace_printf(...)
 #endif
 
 #ifdef CONFIG_TRACE_NET
 #  define net_trace_begin() trace_begin(NOTE_TAG_NET)
 #  define net_trace_end() trace_end(NOTE_TAG_NET)
+#  define net_trace_beginex(name) trace_beginex(NOTE_TAG_NET, name)
+#  define net_trace_endex(name) trace_endex(NOTE_TAG_NET, name)
+#  define net_trace_mark(s) trace_mark(NOTE_TAG_NET, s)
+#  define net_trace_printf(fmt, ...) \
+    trace_printf(NOTE_TAG_NET, fmt, ##__VA_ARGS__)
 #else
 #  define net_trace_begin()
 #  define net_trace_end()
+#  define net_trace_beginex(name)
+#  define net_trace_endex(name)
+#  define net_trace_mark(s)
+#  define net_trace_printf(...)
 #endif
 
 #ifdef CONFIG_TRACE_SCHED
 #  define sched_trace_begin() trace_begin(NOTE_TAG_SCHED)
 #  define sched_trace_end() trace_end(NOTE_TAG_SCHED)
+#  define sched_trace_beginex(name) trace_beginex(NOTE_TAG_SCHED, name)
+#  define sched_trace_endex(name) trace_endex(NOTE_TAG_SCHED, name)
+#  define sched_trace_mark(s) trace_mark(NOTE_TAG_SCHED, s)
+#  define sched_trace_printf(fmt, ...) \
+    trace_printf(NOTE_TAG_SCHED, fmt, ##__VA_ARGS__)
 #else
 #  define sched_trace_begin()
 #  define sched_trace_end()
+#  define sched_trace_beginex(name)
+#  define sched_trace_endex(name)
+#  define sched_trace_mark(s)
+#  define sched_trace_printf(...)
 #endif
 
 #ifdef CONFIG_TRACE_VIDEO
 #  define video_trace_begin() trace_begin(NOTE_TAG_VIDEO)
 #  define video_trace_end() trace_end(NOTE_TAG_VIDEO)
+#  define video_trace_beginex(name) trace_beginex(NOTE_TAG_VIDEO, name)
+#  define video_trace_endex(name) trace_endex(NOTE_TAG_VIDEO, name)
+#  define video_trace_mark(s) trace_mark(NOTE_TAG_VIDEO, s)
+#  define video_trace_printf(fmt, ...) \
+    trace_printf(NOTE_TAG_VIDEO, fmt, ##__VA_ARGS__)
 #else
 #  define video_trace_begin()
 #  define video_trace_end()
+#  define video_trace_beginex(name)
+#  define video_trace_endex(name)
+#  define video_trace_mark(s)
+#  define video_trace_printf(...)
 #endif
 
 #ifdef CONFIG_TRACE_WIRELESS
 #  define wireless_trace_begin() trace_begin(NOTE_TAG_WIRLESS)
 #  define wireless_trace_end() trace_end(NOTE_TAG_WIRLESS)
+#  define wireless_trace_beginex(name) trace_beginex(NOTE_TAG_WIRLESS, name)
+#  define wireless_trace_endex(name) trace_endex(NOTE_TAG_WIRLESS, name)
+#  define wireless_trace_mark(s) trace_mark(NOTE_TAG_WIRLESS, s)
+#  define wireless_trace_printf(fmt, ...) \
+    trace_printf(NOTE_TAG_WIRLESS, fmt, ##__VA_ARGS__)
 #else
 #  define wireless_trace_begin()
 #  define wireless_trace_end()
+#  define wireless_trace_beginex(name)
+#  define wireless_trace_endex(name)
+#  define wireless_trace_mark(s)
+#  define wireless_trace_printf(...)
 #endif
 
 #endif /* __INCLUDE_NUTTX_TRACE_H */

Reply via email to