update compat
[lttv.git] / trunk / lttv / ltt / ltt-private.h
CommitLineData
449cb9d7 1/* This file is part of the Linux Trace Toolkit viewer
2 * Copyright (C) 2003-2004 Xiangxiu Yang
1b44b0b5 3 * 2006 Mathieu Desnoyers
449cb9d7 4 *
1b44b0b5 5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Lesser General Public
7 * License Version 2.1 as published by the Free Software Foundation.
449cb9d7 8 *
1b44b0b5 9 * This library is distributed in the hope that it will be useful,
449cb9d7 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
1b44b0b5 11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
449cb9d7 13 *
1b44b0b5 14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the
16 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17 * Boston, MA 02111-1307, USA.
449cb9d7 18 */
19
fcdf0ec2 20#ifndef LTT_PRIVATE_H
21#define LTT_PRIVATE_H
22
858bd80a 23#include <glib.h>
cbd41522 24#include <sys/types.h>
fcdf0ec2 25#include <ltt/ltt.h>
3b10b765 26#include <endian.h>
29af7cfd 27#include <ltt/event.h>
e3247aa5 28
eed2ef37 29#ifndef max
30#define max(a,b) ((a)>(b)?(a):(b))
31#endif
32
2312de30 33#ifndef min
34#define min(a,b) ((a)<(b)?(a):(b))
35#endif
36
37
eed2ef37 38
3aee1200 39#define LTT_MAGIC_NUMBER 0x00D6B7ED
40#define LTT_REV_MAGIC_NUMBER 0xEDB7D600
41
42#define NSEC_PER_USEC 1000
43
3b10b765 44/* Byte ordering */
45#define LTT_GET_BO(t) ((t)->reverse_bo)
46
64dd41a5 47#define LTT_HAS_FLOAT(t) ((t)->float_word_order ! =0)
3b10b765 48#define LTT_GET_FLOAT_BO(t) \
64dd41a5 49 (((t)->float_word_order == __BYTE_ORDER) ? 0 : 1)
3b10b765 50
f104d082 51#define SEQUENCE_AVG_ELEMENTS 1000
1550fba6 52
53/*
54 * offsetof taken from Linux kernel.
55 */
56#undef offsetof
57#ifdef __compiler_offsetof
58#define offsetof(TYPE,MEMBER) __compiler_offsetof(TYPE,MEMBER)
59#else
60#define offsetof(TYPE, MEMBER) ((size_t) &((TYPE *)0)->MEMBER)
61#endif
62
3aee1200 63typedef guint8 uint8_t;
64typedef guint16 uint16_t;
65typedef guint32 uint32_t;
66typedef guint64 uint64_t;
67
64dd41a5 68/* Subbuffer header */
426f6149 69struct ltt_subbuffer_header_2_2 {
64dd41a5 70 uint64_t cycle_count_begin; /* Cycle count at subbuffer start */
71 uint64_t cycle_count_end; /* Cycle count at subbuffer end */
1550fba6 72 uint32_t magic_number; /*
73 * Trace magic number.
64dd41a5 74 * contains endianness information.
75 */
76 uint8_t major_version;
77 uint8_t minor_version;
78 uint8_t arch_size; /* Architecture pointer size */
79 uint8_t alignment; /* LTT data alignment */
80 uint64_t start_time_sec; /* NTP-corrected start time */
81 uint64_t start_time_usec;
82 uint64_t start_freq; /*
83 * Frequency at trace start,
84 * used all along the trace.
85 */
86 uint32_t freq_scale; /* Frequency scaling */
87 uint32_t lost_size; /* Size unused at end of subbuffer */
88 uint32_t buf_size; /* Size of this subbuffer */
426f6149 89 uint32_t events_lost; /*
90 * Events lost in this subbuffer since
91 * last subbuffer switch.
92 */
93 uint32_t subbuf_corrupt; /*
94 * Corrupted (lost) subbuffers since
95 * the begginig of the trace.
96 */
1550fba6 97 char header_end[0]; /* End of header */
64dd41a5 98};
99
426f6149 100typedef struct ltt_subbuffer_header_2_2 ltt_subbuffer_header_t;
1550fba6 101
102/*
103 * Return header size without padding after the structure. Don't use packed
104 * structure because gcc generates inefficient code on some architectures
105 * (powerpc, mips..)
106 */
107static inline size_t ltt_subbuffer_header_size(void)
108{
109 return offsetof(ltt_subbuffer_header_t, header_end);
110}
e3247aa5 111
3aee1200 112enum field_status { FIELD_UNKNOWN, FIELD_VARIABLE, FIELD_FIXED };
113
3aee1200 114typedef struct _LttBuffer {
115 void * head;
116 unsigned int index;
117
118 struct {
119 LttTime timestamp;
120 uint64_t cycle_count;
986e2a7c 121 uint64_t freq; /* Frequency in khz */
3aee1200 122 } begin;
123 struct {
124 LttTime timestamp;
125 uint64_t cycle_count;
986e2a7c 126 uint64_t freq; /* Frequency in khz */
3aee1200 127 } end;
128 uint32_t lost_size; /* Size unused at the end of the buffer */
129
130 /* Timekeeping */
131 uint64_t tsc; /* Current timestamp counter */
986e2a7c 132 uint64_t freq; /* Frequency in khz */
791dffa6 133 guint32 cyc2ns_scale;
3aee1200 134} LttBuffer;
135
29af7cfd 136struct LttTracefile {
3aee1200 137 gboolean cpu_online; //is the cpu online ?
d3d34f49 138 GQuark long_name; //tracefile complete filename
3aee1200 139 GQuark name; //tracefile name
140 guint cpu_num; //cpu number of the tracefile
c88ddec5 141 guint tid; //Usertrace tid, else 0
142 guint pgid; //Usertrace pgid, else 0
143 guint64 creation; //Usertrace creation, else 0
e3247aa5 144 LttTrace * trace; //trace containing the tracefile
145 int fd; //file descriptor
146 off_t file_size; //file size
f628823c 147 //unsigned block_size; //block_size
f104d082 148 guint num_blocks; //number of blocks in the file
3aee1200 149 gboolean reverse_bo; //must we reverse byte order ?
3b10b765 150 gboolean float_word_order; //what is the byte order of floats ?
256a5b3a 151 size_t alignment; //alignment of events in the tracefile.
c88ddec5 152 // 0 or the architecture size in bytes.
3aee1200 153
823820eb 154 size_t buffer_header_size;
d1bb700c 155 uint8_t tscbits;
2fc874ab 156 uint8_t eventbits;
d1bb700c 157 uint64_t tsc_mask;
426f6149 158 uint64_t tsc_mask_next_bit; //next MSB after the mask<
159 uint32_t events_lost;
160 uint32_t subbuf_corrupt;
823820eb 161
c88ddec5 162 /* Current event */
3aee1200 163 LttEvent event; //Event currently accessible in the trace
164
c88ddec5 165 /* Current block */
3aee1200 166 LttBuffer buffer; //current buffer
167 guint32 buf_size; /* The size of blocks */
e3247aa5 168};
7c6b3cd7 169
a5dcde2f 170/* The characteristics of the system on which the trace was obtained
171 is described in a LttSystemDescription structure. */
172
29af7cfd 173struct LttSystemDescription {
45e14832 174 gchar *description;
175 gchar *node_name;
176 gchar *domain_name;
a5dcde2f 177 unsigned nb_cpu;
178 LttArchSize size;
179 LttArchEndian endian;
45e14832 180 gchar *kernel_name;
181 gchar *kernel_release;
182 gchar *kernel_version;
183 gchar *machine;
184 gchar *processor;
185 gchar *hardware_platform;
186 gchar *operating_system;
a5dcde2f 187 LttTime trace_start;
188 LttTime trace_end;
189};
190
f104d082 191/* Calculate the offset needed to align the type.
256a5b3a 192 * If alignment is 0, alignment is disactivated.
f104d082 193 * else, the function returns the offset needed to
256a5b3a 194 * align align_drift on the alignment value (should be
f104d082 195 * the size of the architecture). */
196static inline unsigned int ltt_align(size_t align_drift,
83e160f2 197 size_t size_of_type,
256a5b3a 198 size_t alignment)
f104d082 199{
256a5b3a 200 size_t align_offset = min(alignment, size_of_type);
c88ddec5 201
256a5b3a 202 if(!alignment)
203 return 0;
c88ddec5 204
205 g_assert(size_of_type != 0);
256a5b3a 206 return ((align_offset - align_drift) & (align_offset-1));
f104d082 207}
208
f104d082 209
fcdf0ec2 210#endif /* LTT_PRIVATE_H */
This page took 0.080985 seconds and 4 git commands to generate.