[ltt-dev] [UST PATCH] Get Online targets checker

Mathieu Desnoyers compudj at krystal.dyndns.org
Fri Mar 25 23:59:17 EDT 2011


* Matthew Khouzam (matthew.khouzam at ericsson.com) wrote:
> Signed-off-by: Matthew Khouzam <matthew.khouzam at ericsson.com>
> ---
>  libustctl/libustctl.c |    9 ++++++++-
>  1 files changed, 8 insertions(+), 1 deletions(-)
>
> diff --git a/libustctl/libustctl.c b/libustctl/libustctl.c
> index d57e645..3b5ae84 100644
> --- a/libustctl/libustctl.c
> +++ b/libustctl/libustctl.c
> @@ -92,8 +92,11 @@ pid_t *ustctl_get_online_pids(void)
>  {
>      struct dirent *dirent;
>      DIR *dir;
> +    DIR *proc_dir;
> +    char proc_dir_path[80]; /* proc + / + int always smaller than 80 */

Hi Matthew,

Please don't use hardcoded values like this. It's begging for buffer
overflows. You should use PATH_MAX instead.

>      unsigned int ret_size = 1 * sizeof(pid_t), i = 0;
>      dir = opendir(SOCK_DIR);
>      if (!dir) {
>  @@ -117,7 +120,11 @@ pid_t *ustctl_get_online_pids(void)
>               * We need to figure out an intelligent way of solving
>               * this, maybe connect-disconnect.
>               */
> -            if (1) {
> +             snprintf( proc_dir_path, 80, "/proc/%u/" , ret[i]) ;

Please use PATH_MAX here too.

And if you ever really need to use something smaller (here we really
just don't care about a slightly larger stack size in userspace), you
should do a define at the top of the file so we know there is a
non-standard value buried in there.

Thanks,

Mathieu


> +             proc_dir = opendir(proc_dir_path);
> +             /* maybe we should remove the empty dir in this pass too*/
> +             if( proc_dir != NULL )
> +            {
>                  ret_size += sizeof(pid_t);
>                  ret = (pid_t *) realloc(ret, ret_size);
>                  ++i;
> -- 
> 1.7.0.4
>
>
> _______________________________________________
> ltt-dev mailing list
> ltt-dev at lists.casi.polymtl.ca
> http://lists.casi.polymtl.ca/cgi-bin/mailman/listinfo/ltt-dev
>

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




More information about the lttng-dev mailing list