[lttng-dev] [PATCH] Fix I/O-related error values in ustctl

Mathieu Desnoyers mathieu.desnoyers at efficios.com
Mon Jan 21 10:58:06 EST 2013


* David Goulet (dgoulet at efficios.com) wrote:
> Acked-by: David Goulet <dgoulet at efficios.com>

merged into master branch and stable-2.1.

Thanks,

Mathieu

> 
> Mathieu Desnoyers:
> > These internal ustctl API members document >=0 as OK values. Make sure
> > reply recv errors are returned as errors.
> > 
> > Clarify ustctl_create_stream() error values.
> > 
> > Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers at efficios.com>
> > ---
> > diff --git a/include/lttng/ust-ctl.h b/include/lttng/ust-ctl.h
> > index c2b255c..11beaba 100644
> > --- a/include/lttng/ust-ctl.h
> > +++ b/include/lttng/ust-ctl.h
> > @@ -23,7 +23,7 @@
> >  
> >  /*
> >   * Error values: all the following functions return:
> > - * >= 0: Sucess (LTTNG_UST_OK)
> > + * >= 0: Success (LTTNG_UST_OK)
> >   * < 0: error code.
> >   */
> >  int ustctl_register_done(int sock);
> > @@ -34,8 +34,6 @@ int ustctl_open_metadata(int sock, int session_handle,
> >  int ustctl_create_channel(int sock, int session_handle,
> >  		struct lttng_ust_channel_attr *chops,
> >  		struct lttng_ust_object_data **channel_data);
> > -int ustctl_create_stream(int sock, struct lttng_ust_object_data *channel_data,
> > -		struct lttng_ust_object_data **stream_data);
> >  int ustctl_create_event(int sock, struct lttng_ust_event *ev,
> >  		struct lttng_ust_object_data *channel_data,
> >  		struct lttng_ust_object_data **event_data);
> > @@ -51,6 +49,15 @@ int ustctl_start_session(int sock, int handle);
> >  int ustctl_stop_session(int sock, int handle);
> >  
> >  /*
> > + * Return -ENOENT if no more stream is available for creation.
> > + * Return 0 on success.
> > + * Return negative error value on system error.
> > + * Return positive error value on UST error.
> > + */
> > +int ustctl_create_stream(int sock, struct lttng_ust_object_data *channel_data,
> > +		struct lttng_ust_object_data **stream_data);
> > +
> > +/*
> >   * ustctl_tracepoint_list returns a tracepoint list handle, or negative
> >   * error value.
> >   */
> > diff --git a/liblttng-ust-comm/lttng-ust-comm.c b/liblttng-ust-comm/lttng-ust-comm.c
> > index 9a67ea1..db9910d 100644
> > --- a/liblttng-ust-comm/lttng-ust-comm.c
> > +++ b/liblttng-ust-comm/lttng-ust-comm.c
> > @@ -435,7 +435,10 @@ int ustcomm_send_app_cmd(int sock,
> >  	ret = ustcomm_send_app_msg(sock, lum);
> >  	if (ret)
> >  		return ret;
> > -	return ustcomm_recv_app_reply(sock, lur, lum->handle, lum->cmd);
> > +	ret = ustcomm_recv_app_reply(sock, lur, lum->handle, lum->cmd);
> > +	if (ret > 0)
> > +		return -EIO;
> > +	return ret;
> >  }
> >  
> >  /*
> > 

-- 
Mathieu Desnoyers
EfficiOS Inc.
http://www.efficios.com



More information about the lttng-dev mailing list