Port changes from lttng-kt
[lttng-ust.git] / libust / tracercore.h
CommitLineData
183646e6
PMF
1/*
2 * Copyright (C) 2005,2006 Mathieu Desnoyers (mathieu.desnoyers@polymtl.ca)
3 *
4 * This contains the core definitions for the Linux Trace Toolkit.
8fc2d8db
PMF
5 *
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.
10 *
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.
15 *
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
183646e6
PMF
19 */
20
b73a4c47
PMF
21#ifndef UST_TRACERCORE_H
22#define UST_TRACERCORE_H
183646e6 23
fbca6b62 24#include <ust/kernelcompat.h>
183646e6
PMF
25//ust// #include <linux/percpu.h>
26
27/* ltt's root dir in debugfs */
28#define LTT_ROOT "ltt"
29
30/*
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
34 * list.
35 */
36struct ltt_traces {
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;
41
42extern struct ltt_traces ltt_traces;
43
183646e6
PMF
44/* Keep track of trap nesting inside LTT */
45//ust// DECLARE_PER_CPU(unsigned int, ltt_nesting);
bb07823d 46extern unsigned int ltt_nesting;
183646e6
PMF
47
48typedef int (*ltt_run_filter_functor)(void *trace, uint16_t eID);
1ae7f074 49//typedef int (*ltt_run_filter_functor)(void *, __u16);
183646e6
PMF
50
51extern ltt_run_filter_functor ltt_run_filter;
52
53extern void ltt_filter_register(ltt_run_filter_functor func);
54extern void ltt_filter_unregister(void);
55
56#if defined(CONFIG_LTT) && defined(CONFIG_LTT_ALIGNMENT)
57
58/*
59 * Calculate the offset needed to align the type.
60 * size_of_type must be non-zero.
61 */
62static inline unsigned int ltt_align(size_t align_drift, size_t size_of_type)
63{
64 size_t alignment = min(sizeof(void *), size_of_type);
65 return (alignment - align_drift) & (alignment - 1);
66}
67/* Default arch alignment */
68#define LTT_ALIGN
69
70static inline int ltt_get_alignment(void)
71{
72 return sizeof(void *);
73}
74
75#else
76
77static inline unsigned int ltt_align(size_t align_drift,
78 size_t size_of_type)
79{
80 return 0;
81}
82
83#define LTT_ALIGN __attribute__((packed))
84
85static inline int ltt_get_alignment(void)
86{
87 return 0;
88}
89#endif /* defined(CONFIG_LTT) && defined(CONFIG_LTT_ALIGNMENT) */
90
b73a4c47 91#endif /* UST_TRACERCORE_H */
This page took 0.035593 seconds and 4 git commands to generate.