2 * Copyright (C) 2005,2006 Mathieu Desnoyers (mathieu.desnoyers@polymtl.ca)
4 * This contains the core definitions for the Linux Trace Toolkit.
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21 #ifndef UST_TRACERCORE_H
22 #define UST_TRACERCORE_H
24 #include <ust/kernelcompat.h>
25 //ust// #include <linux/percpu.h>
27 /* ltt's root dir in debugfs */
28 #define LTT_ROOT "ltt"
31 * All modifications of ltt_traces must be done by ltt-tracer.c, while holding
32 * the semaphore. Only reading of this information can be done elsewhere, with
33 * the RCU mechanism : the preemption must be disabled while reading the
37 struct list_head setup_head
; /* Pre-allocated traces list */
38 struct list_head head
; /* Allocated Traces list */
39 unsigned int num_active_traces
; /* Number of active traces */
40 } ____cacheline_aligned
;
42 extern struct ltt_traces ltt_traces
;
44 /* Keep track of trap nesting inside LTT */
45 //ust// DECLARE_PER_CPU(unsigned int, ltt_nesting);
46 extern unsigned int ltt_nesting
;
48 typedef int (*ltt_run_filter_functor
)(void *trace
, uint16_t eID
);
49 //typedef int (*ltt_run_filter_functor)(void *, __u16);
51 extern ltt_run_filter_functor ltt_run_filter
;
53 extern void ltt_filter_register(ltt_run_filter_functor func
);
54 extern void ltt_filter_unregister(void);
56 #if defined(CONFIG_LTT) && defined(CONFIG_LTT_ALIGNMENT)
59 * Calculate the offset needed to align the type.
60 * size_of_type must be non-zero.
62 static inline unsigned int ltt_align(size_t align_drift
, size_t size_of_type
)
64 size_t alignment
= min(sizeof(void *), size_of_type
);
65 return (alignment
- align_drift
) & (alignment
- 1);
67 /* Default arch alignment */
70 static inline int ltt_get_alignment(void)
72 return sizeof(void *);
77 static inline unsigned int ltt_align(size_t align_drift
,
83 #define LTT_ALIGN __attribute__((packed))
85 static inline int ltt_get_alignment(void)
89 #endif /* defined(CONFIG_LTT) && defined(CONFIG_LTT_ALIGNMENT) */
91 #endif /* UST_TRACERCORE_H */