Fix: cmd_rotate_session() returns unexpected error codes
[lttng-tools.git] / src / bin / lttng-sessiond / kernel.h
CommitLineData
20fe2104
DG
1/*
2 * Copyright (C) 2011 - David Goulet <david.goulet@polymtl.ca>
3 *
d14d33bf
AM
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License, version 2 only,
6 * as published by the Free Software Foundation.
20fe2104
DG
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
d14d33bf 10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20fe2104
DG
11 * GNU General Public License for more details.
12 *
d14d33bf
AM
13 * You should have received a copy of the GNU General Public License along
14 * with this program; if not, write to the Free Software Foundation, Inc.,
15 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
20fe2104
DG
16 */
17
18#ifndef _LTT_KERNEL_CTL_H
19#define _LTT_KERNEL_CTL_H
20
8c0faa1d 21#include "session.h"
6dc3064a 22#include "snapshot.h"
62499ad6 23#include "trace-kernel.h"
f34daff7 24
2ef84c95
DG
25/*
26 * Default size for the event list when kernel_list_events is called. This size
050349bb
DG
27 * value is based on the initial LTTng 2.0 version set of tracepoints.
28 *
29 * This is NOT an upper bound because if the real event list size is bigger,
30 * dynamic reallocation is performed.
2ef84c95 31 */
6725fe19 32#define KERNEL_EVENT_INIT_LIST_SIZE 64
a5dfbb9d 33#define KERNEL_TRACKER_PIDS_INIT_LIST_SIZE 64
2ef84c95 34
d65106b1 35int kernel_add_channel_context(struct ltt_kernel_channel *chan,
645328ae 36 struct ltt_kernel_context *ctx);
8c0faa1d 37int kernel_create_session(struct ltt_session *session, int tracer_fd);
b082db07 38int kernel_create_channel(struct ltt_kernel_session *session,
fdd9eb17 39 struct lttng_channel *chan);
00a62084
MD
40int kernel_create_event(struct lttng_event *ev, struct ltt_kernel_channel *channel,
41 char *filter_expression, struct lttng_filter_bytecode *filter);
26cc6b4e 42int kernel_disable_channel(struct ltt_kernel_channel *chan);
19e70852
DG
43int kernel_disable_event(struct ltt_kernel_event *event);
44int kernel_enable_event(struct ltt_kernel_event *event);
d36b8583 45int kernel_enable_channel(struct ltt_kernel_channel *chan);
ccf10263
MD
46int kernel_track_pid(struct ltt_kernel_session *session, int pid);
47int kernel_untrack_pid(struct ltt_kernel_session *session, int pid);
a4b92340 48int kernel_open_metadata(struct ltt_kernel_session *session);
f3ed775e
DG
49int kernel_open_metadata_stream(struct ltt_kernel_session *session);
50int kernel_open_channel_stream(struct ltt_kernel_channel *channel);
51int kernel_flush_buffer(struct ltt_kernel_channel *channel);
52int kernel_metadata_flush_buffer(int fd);
8c0faa1d
DG
53int kernel_start_session(struct ltt_kernel_session *session);
54int kernel_stop_session(struct ltt_kernel_session *session);
9f19cc17 55ssize_t kernel_list_events(int tracer_fd, struct lttng_event **event_list);
f3ed775e 56void kernel_wait_quiescent(int fd);
88076e89
JD
57int kernel_validate_version(int tracer_fd,
58 struct lttng_kernel_tracer_version *kernel_tracer_version,
59 struct lttng_kernel_tracer_abi_version *kernel_tracer_abi_version);
2f77fc4b 60void kernel_destroy_session(struct ltt_kernel_session *ksess);
fb5f35b6 61void kernel_destroy_channel(struct ltt_kernel_channel *kchan);
6dc3064a 62int kernel_snapshot_record(struct ltt_kernel_session *ksess,
d07ceecd
MD
63 struct snapshot_output *output, int wait,
64 uint64_t nb_packets_per_stream);
834978fd 65int kernel_syscall_mask(int chan_fd, char **syscall_mask, uint32_t *nr_bits);
d5a1b7aa 66enum lttng_error_code kernel_rotate_session(struct ltt_session *session);
20fe2104 67
335a95b7 68int init_kernel_workarounds(void);
a5dfbb9d
MD
69ssize_t kernel_list_tracker_pids(struct ltt_kernel_session *session,
70 int **_pids);
6e21424e 71int kernel_supports_ring_buffer_snapshot_sample_positions(int tracer_fd);
335a95b7 72
20fe2104 73#endif /* _LTT_KERNEL_CTL_H */
This page took 0.081356 seconds and 4 git commands to generate.