Man page - tracefs_instance_set_subbuf_size(3)
Packages contas this manual
- tracefs_binary_write(3)
- tracefs_cpu_open(3)
- tracefs_cpu_pipe(3)
- tracefs_instance_file_read_number(3)
- tracefs_kretprobe_raw(3)
- tracefs_hist_get_event(3)
- tracefs_synth_add_start_field(3)
- tracefs_instance_get_trace_dir(3)
- tracefs_kprobe_raw(3)
- tracefs_instance_get_file(3)
- tracefs_file_exists(3)
- tracefs_hist_pause(3)
- tracefs_set_loglevel(3)
- tracefs_instance_set_affinity_raw(3)
- tracefs_synth_get_start_hist(3)
- tracefs_instance_get_buffer_percent(3)
- tracefs_instance_find_cid_pid(3)
- tracefs_error_last(3)
- tracefs_synth_set_instance(3)
- tracefs_synth_add_end_field(3)
- tracefs_filter_string_append(3)
- tracefs_hist_alloc_nd(3)
- tracefs_instance_file_write(3)
- tracefs_synth_show_start_hist(3)
- tracefs_cpu_write(3)
- tracefs_buffer_stat_dropped_events(3)
- tracefs_snapshot_clear(3)
- tracefs_trace_on(3)
- tracefs_binary_init(3)
- tracefs_instance_get_affinity_set(3)
- tracefs_tracing_dir_is_mounted(3)
- tracefs_cpu_buffered_read(3)
- tracefs_iterate_stop(3)
- tracefs_event_file_read(3)
- tracefs_options(3)
- tracefs_event_get_file(3)
- tracefs_instances(3)
- tracefs_filter_pid_events(3)
- tracefs_synth_save(3)
- tracefs_instance_file_clear(3)
- tracefs_load_cmdlines(3)
- tracefs_buffer_stat_read_events(3)
- tracefs_filter_pid_function(3)
- tracefs_get_clock(3)
- tracefs_instance_file_write_number(3)
- tracefs_dynevent_destroy_all(3)
- tracefs_put_tracing_file(3)
- tracefs_event_disable(3)
- tracefs_buffer_stat_entries(3)
- tracefs_tracer_available(3)
- tracefs_follow_event_clear(3)
- tracefs_uprobe_alloc(3)
- tracefs_event_filter_clear(3)
- tracefs_buffer_stat_commit_overrun(3)
- tracefs_option_name(3)
- tracefs_instances_walk(3)
- tracefs_instance_get_affinity(3)
- tracefs_hist_alloc_2d(3)
- tracefs_event_file_clear(3)
- tracefs_synth_complete(3)
- tracefs_trace_pipe_print(3)
- tracefs_event_enable(3)
- tracefs_hist_command(3)
- tracefs_hist_get_system(3)
- tracefs_snapshot_free(3)
- tracefs_get_tracing_file(3)
- tracefs_hist_echo_cmd(3)
- tracefs_hist_continue(3)
- tracefs_synth_get_event(3)
- tracefs_synth_raw_fmt(3)
- tracefs_uretprobe_alloc(3)
- tracefs_instance_set_affinity(3)
- tracefs_trace_pipe_stream(3)
- tracefs_printf(3)
- tracefs_event_file_exists(3)
- tracefs_synth_get_name(3)
- tracefs_follow_missed_events_clear(3)
- tracefs_hist_alloc(3)
- tracefs_synth_add_compare_field(3)
- tracefs_hist_sort_key_direction(3)
- tracefs_filter_pid_events_clear(3)
- tracefs_filter_functions(3)
- tracefs_hist_alloc_nd_cnt(3)
- tracefs_instance_reset(3)
- tracefs_eprobe_alloc(3)
- tracefs_dynevent_destroy(3)
- tracefs_tracer_set(3)
- tracefs_cpu_snapshot_open(3)
- tracefs_instance_set_subbuf_size(3)
- tracefs_option_enable(3)
- tracefs_trace_off(3)
- tracefs_synth_append_start_filter(3)
- tracefs_list_size(3)
- tracefs_instance_file_read(3)
- tracefs_cpu_open_mapped(3)
- tracefs_event_file_append(3)
- tracefs_dynevent_get(3)
- tracefs_synth_show_event(3)
- tracefs_kretprobe_alloc(3)
- tracefs_hist_add_value(3)
- tracefs_instance_set_affinity_set(3)
- tracefs_follow_missed_events(3)
- tracefs_follow_event(3)
- tracefs_trace_pipe_stop(3)
- tracefs_event_is_enabled(3)
- tracefs_list_add(3)
- tracefs_instance_file_append(3)
- tracefs_instance_get_subbuf_size(3)
- tracefs_dynevent_free(3)
- tracefs_cpu_flush_buf(3)
- tracefs_instance_get_buffer_size(3)
- tracefs_event_filter_apply(3)
- tracefs_find_cid_pid(3)
- tracefs_cpu_flush(3)
- tracefs_vprintf(3)
- tracefs_synth_alloc(3)
- tracefs_synth_show_end_hist(3)
- tracefs_instance_get_affinity_raw(3)
- tracefs_hist_destroy(3)
- tracefs_dynevent_list_free(3)
- tracefs_list_free(3)
- tracefs_function_notrace(3)
- tracefs_instance_tracers(3)
- tracefs_fill_local_events(3)
- tracefs_load_headers(3)
- tracefs_cpu_free_fd(3)
- tracefs_cpu_read_buf(3)
- tracefs_error_all(3)
- tracefs_cpu_read_size(3)
- tracefs_hist_append_filter(3)
- tracefs_error_clear(3)
- tracefs_instance_is_new(3)
- tracefs_trace_on_get_fd(3)
- tracefs_synth_add_match_field(3)
- tracefs_trace_off_fd(3)
- tracefs_option_id(3)
- tracefs_cpu_read(3)
- tracefs_dynevent_get_all(3)
- tracefs_cpu_flush_write(3)
- tracefs_trace_on_fd(3)
- tracefs_synth_create(3)
- tracefs_buffer_stat_bytes(3)
- tracefs_instance_clear(3)
- tracefs_instance_destroy(3)
- tracefs_buffer_stat_overrun(3)
- tracefs_cpu_close(3)
- tracefs_hist_add_key(3)
- tracefs_synth_trace(3)
- sqlhist(1)
- tracefs_dynevent_get_event(3)
- tracefs_cpu_stop(3)
- tracefs_buffer_stat_timestamp(3)
- tracefs_print_init(3)
- tracefs_system_events(3)
- tracefs_option_is_supported(3)
- tracefs_snapshot_snap(3)
- tracefs_instance_put_stat(3)
- tracefs_tracers(3)
- tracefs_instance_free(3)
- tracefs_cpu_alloc_fd(3)
- tracefs_tracing_dir(3)
- tracefs_instance_alloc(3)
- tracefs_instance_file_open(3)
- tracefs_trace_is_on(3)
- tracefs_print_close(3)
- tracefs_synth_free(3)
- tracefs_synth_destroy(3)
- tracefs_instance_get_name(3)
- tracefs_cpu_is_mapped(3)
- tracefs_hist_start(3)
- tracefs_option_mask_is_set(3)
- tracefs_kprobe_alloc(3)
- tracefs_buffer_stat_event_timestamp(3)
- tracefs_hist_get_name(3)
- tracefs_hist_add_sort_key(3)
- tracefs_filter_pid_function_clear(3)
- tracefs_hist_add_key_cnt(3)
- tracefs_option_is_enabled(3)
- tracefs_kprobe_destroy(3)
- tracefs_option_disable(3)
- tracefs_hist_set_sort_key(3)
- tracefs_cpu_buffered_read_buf(3)
- tracefs_debug_dir(3)
- tracefs_instance_get_stat(3)
- tracefs_instance_set_buffer_percent(3)
- tracefs_sql(3)
- tracefs_hist_free(3)
- tracefs_cpu_unmap(3)
- tracefs_synth_snapshot(3)
- tracefs_cpu_map(3)
- tracefs_dynevent_info(3)
- tracefs_hist_add_name(3)
- tracefs_synth_append_end_filter(3)
- tracefs_hist_reset(3)
- tracefs_dynevent_create(3)
- tracefs_local_events(3)
- tracefs_time_conversion(3)
- tracefs_instance_get_dir(3)
- tracefs_instance_exists(3)
- tracefs_set_tracing_dir(3)
- tracefs_local_events_system(3)
- tracefs_event_systems(3)
- tracefs_options_get_supported(3)
- tracefs_iterate_snapshot_events(3)
- tracefs_function_filter(3)
- tracefs_instance_set_buffer_size(3)
- tracefs_filter_string_verify(3)
- tracefs_synth_echo_cmd(3)
- tracefs_iterate_raw_events(3)
- tracefs_instance_create(3)
- tracefs_tracer_clear(3)
- libtracefs(3)
- tracefs_mapped_is_supported(3)
- tracefs_binary_close(3)
- tracefs_event_file_write(3)
- tracefs_dir_exists(3)
- tracefs_options_get_enabled(3)
apt-get install libtracefs-doc
Manual
| LIBTRACEFS(3) | libtracefs Manual | LIBTRACEFS(3) |
NAME
tracefs_instance_get_subbuf_size, tracefs_instance_set_subbuf_size - Helper functions for working with ring buffer sub buffers.
SYNOPSIS
#include <tracefs.h> size_t tracefs_instance_get_subbuf_size(struct tracefs_instance *instance); int tracefs_instance_set_subbuf_size(struct tracefs_instance *instance, size_t size);
DESCRIPTION
Helper functions for working with the sub-buffers of the tracing ring buffer. The tracing ring buffer is broken up into sub-buffers. An event can not be bigger than the data section of the sub-buffer (see tep_get_sub_buffer_data_size(3)). By default, the ring buffer uses the architectures page_size as the default size of the sub-buffer, but this can be limiting if there is a need for large events, for example, the application wants to write large strings into the trace_marker file.
The tracefs_instance_get_subbuf_size() returns the current size in kilobytes fo the ring buffer sub-buffers.
The tracefs_instance_set_subbuf_size() will write the size in kilobytes of what the new sub-buffer size should be. Note, that this is only a hint to what the minimum sub-buffer size should be. It also does not take into account the meta-data that is used by the sub-buffer, so the size written should be no less than 16 bytes more than the maximum event size that will be used. The kernel will likely make the sub-buffer size larger than specified, as it may need to align the size for implementation purposes.
RETURN VALUE
The tracefs_instance_get_subbuf_size() returns the size of the current sub-buffer for the given instance ring buffer or -1 on error.
The tracefs_instance_set_subbuf_size() will return 0 if it successfully set the instance ring buffer sub-buffer size in kilobytes, or -1 on error.
EXAMPLE
#include <stdlib.h>
#include <tracefs.h>
#include <errno.h>
int main(int argc, char **argv)
{
struct tep_handle *tep;
ssize_t save_subsize;
ssize_t subsize;
char *trace;
char buf[3000];
int meta_size;
int ret;
int i;
tep = tep_alloc();
ret = tracefs_load_headers(NULL, tep);
tep_free(tep);
if (ret < 0) {
perror("reading headers");
exit(-1);
}
meta_size = tep_get_sub_buffer_size(tep) - tep_get_sub_buffer_data_size(tep);
save_subsize = tracefs_instance_get_subbuf_size(NULL);
if (save_subsize < 0) {
printf("Changing sub-buffer size not available\n");
exit(-1);
}
subsize = save_subsize * 1024;
/* Have at least 4 writes fit on a sub-buffer */
if (subsize - meta_size < sizeof(buf) *4 ) {
subsize = ((sizeof(buf) * 4 + meta_size) + 1023) / 1024;
tracefs_instance_set_subbuf_size(NULL, subsize);
}
for (i = 0; i < sizeof(buf) - 1; i++) {
buf[i] = '0' + i % 10;
}
buf[i] = '\0';
tracefs_instance_clear(NULL);
for (i = 0; i < 4; i++) {
ret = tracefs_printf(NULL, "%s\n", buf);
if (ret < 0)
perror("write");
}
trace = tracefs_instance_file_read(NULL, "trace", NULL);
printf("%s\n", trace);
free(trace);
printf("Buffer size was: %zd * 1024\n",
tracefs_instance_get_subbuf_size(NULL));
tracefs_instance_set_subbuf_size(NULL, save_subsize);
}
FILES
tracefs.h
Header file to include in order to have access to the library APIs. -ltracefs
Linker switch to add when building a program that uses the library.
SEE ALSO
libtracefs(3), libtraceevent(3), trace-cmd(1)
AUTHOR
Steven Rostedt <rostedt@goodmis.org[1]> Tzvetomir Stoyanov <tz.stoyanov@gmail.com[2]>
REPORTING BUGS
Report bugs to <linux-trace-devel@vger.kernel.org[3]>
LICENSE
libtracefs is Free Software licensed under the GNU LGPL 2.1
RESOURCES
https://git.kernel.org/pub/scm/libs/libtrace/libtracefs.git/
COPYING
Copyright (C) 2020 VMware, Inc. Free use of this software is granted under the terms of the GNU Public License (GPL).
NOTES
- 1.
- rostedt@goodmis.org
- 2.
- tz.stoyanov@gmail.com
- 3.
- linux-trace-devel@vger.kernel.org
| 07/27/2024 | libtracefs 1.8.1 |