[lttng-dev] [PATCH 2/3] Add default subbuf sizes getter functions

Mathieu Desnoyers mathieu.desnoyers at efficios.com
Tue Nov 13 13:59:42 EST 2012


* Simon Marchi (simon.marchi at polymtl.ca) wrote:
> This patch adds functions to retrieve defaults subbuf sizes. It uses the
> DEFAULT_*_SUBBUF_SIZE defines from defaults.h but also make sure that the
> values are at least as big as the page size.
> 
> The functions are defined as static inline in defaults.h.

Please prefix your subject with e.g.:

[PATCH lttng-tools x/y]

more below,

> 
> Signed-off-by: Simon Marchi <simon.marchi at polymtl.ca>
> ---
>  src/common/Makefile.am |    2 +-
>  src/common/defaults.c  |   50 +++++++++++++++++++++++++++++++++++++++++++
>  src/common/defaults.h  |   55 ++++++++++++++++++++++++++++++++++++++++++++++++
>  3 files changed, 106 insertions(+), 1 deletions(-)
>  create mode 100644 src/common/defaults.c
> 
> diff --git a/src/common/Makefile.am b/src/common/Makefile.am
> index b43b376..f91259c 100644
> --- a/src/common/Makefile.am
> +++ b/src/common/Makefile.am
> @@ -12,7 +12,7 @@ noinst_HEADERS = lttng-kernel.h defaults.h macros.h error.h futex.h \
>  noinst_LTLIBRARIES = libcommon.la
>  
>  libcommon_la_SOURCES = error.h error.c utils.c utils.h runas.c runas.h \
> -                       common.h futex.c futex.h uri.c uri.h
> +                       common.h futex.c futex.h uri.c uri.h defaults.c
>  
>  # Consumer library
>  noinst_LTLIBRARIES += libconsumer.la
> diff --git a/src/common/defaults.c b/src/common/defaults.c
> new file mode 100644
> index 0000000..ee6b777
> --- /dev/null
> +++ b/src/common/defaults.c
> @@ -0,0 +1,50 @@
> +/*
> + * Copyright (C) 2012 - Simon Marchi <simon.marchi at polymtl.ca>
> + *
> + * This program is free software; you can redistribute it and/or modify
> + * it under the terms of the GNU General Public License, version 2 only,
> + * as published by the Free Software Foundation.
> + *
> + * This program is distributed in the hope that it will be useful, but WITHOUT
> + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
> + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
> + * more details.
> + *
> + * You should have received a copy of the GNU General Public License along
> + * with this program; if not, write to the Free Software Foundation, Inc.,
> + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
> + */
> +
> +#include <stddef.h>
> +#include <unistd.h>
> +
> +#include "defaults.h"
> +
> +#include  "macros.h"
> +
> +size_t default_channel_subbuf_size;
> +size_t default_metadata_subbuf_size;
> +size_t default_kernel_channel_subbuf_size;
> +size_t default_ust_channel_subbuf_size;
> +
> +static void __attribute__((constructor)) init_defaults(void)
> +{
> +	/* libringbuffer won't accept subbuf sizes smaller than the page size,
> +	 * so. If the default subbuf size is smaller, replace it by the page
> +	 * size. */
> +	long page_size = sysconf(_SC_PAGESIZE);
> +
> +	if (page_size < 0) {
> +		page_size = 0;
> +	}
> +
> +	default_channel_subbuf_size =
> +    max(DEFAULT_CHANNEL_SUBBUF_SIZE, page_size);
> +	default_metadata_subbuf_size =
> +    max(DEFAULT_METADATA_SUBBUF_SIZE, page_size);
> +	default_kernel_channel_subbuf_size =
> +    max(DEFAULT_KERNEL_CHANNEL_SUBBUF_SIZE, page_size);
> +	default_ust_channel_subbuf_size =
> +    max(DEFAULT_UST_CHANNEL_SUBBUF_SIZE, page_size);

spaces -> tabs

Thanks,

Mathieu

> +}
> +
> diff --git a/src/common/defaults.h b/src/common/defaults.h
> index 0c0b6ac..efcd792 100644
> --- a/src/common/defaults.h
> +++ b/src/common/defaults.h
> @@ -160,4 +160,59 @@
>  #define DEFAULT_APP_SOCKET_RW_TIMEOUT       5  /* sec */
>  #define DEFAULT_APP_SOCKET_TIMEOUT_ENV      "LTTNG_APP_SOCKET_TIMEOUT"
>  
> +
> +extern size_t default_channel_subbuf_size;
> +extern size_t default_metadata_subbuf_size;
> +extern size_t default_ust_channel_subbuf_size;
> +extern size_t default_kernel_channel_subbuf_size;
> +
> +
> +/*
> + * Returns the default subbuf size.
> + *
> + * This function depends on a value that is set at constructor time, so it is
> + * unsafe to call it from another constructor.
> + */
> +static inline
> +size_t default_get_channel_subbuf_size(void)
> +{
> +	return default_channel_subbuf_size;
> +}
> +
> +/*
> + * Returns the default metadata subbuf size.
> + *
> + * This function depends on a value that is set at constructor time, so it is
> + * unsafe to call it from another constructor.
> + */
> +static inline
> +size_t default_get_metadata_subbuf_size(void)
> +{
> +	return default_metadata_subbuf_size;
> +}
> +
> +/*
> + * Returns the default subbuf size for the kernel domain.
> + *
> + * This function depends on a value that is set at constructor time, so it is
> + * unsafe to call it from another constructor.
> + */
> +static inline
> +size_t default_get_kernel_channel_subbuf_size(void)
> +{
> +	return default_kernel_channel_subbuf_size;
> +}
> +
> +/*
> + * Returns the default subbuf size for the UST domain.
> + *
> + * This function depends on a value that is set at constructor time, so it is
> + * unsafe to call it from another constructor.
> + */
> +static inline
> +size_t default_get_ust_channel_subbuf_size(void)
> +{
> +	return default_ust_channel_subbuf_size;
> +}
> +
>  #endif /* _DEFAULTS_H */
> -- 
> 1.7.1
> 
> 
> _______________________________________________
> lttng-dev mailing list
> lttng-dev at lists.lttng.org
> http://lists.lttng.org/cgi-bin/mailman/listinfo/lttng-dev

-- 
Mathieu Desnoyers
Operating System Efficiency R&D Consultant
EfficiOS Inc.
http://www.efficios.com



More information about the lttng-dev mailing list