[lttng-dev] [PATCH lttng-tools] Fix: set errno with value from SO_ERROR on error.
Jérémie Galarneau
jeremie.galarneau at efficios.com
Tue Feb 27 11:17:58 EST 2018
Merged in master, stable-2.10, and stable-2.9.
Thanks,
Jérémie
On Tue, Feb 20, 2018 at 10:06:31PM -0500, Jonathan Rajotte wrote:
> Debugging output at the same time in case of asynchronous handling.
>
> Signed-off-by: Jonathan Rajotte <jonathan.rajotte-julien at efficios.com>
> ---
> src/common/sessiond-comm/inet.c | 6 ++++++
> src/common/sessiond-comm/inet6.c | 7 +++++++
> 2 files changed, 13 insertions(+)
>
> diff --git a/src/common/sessiond-comm/inet.c b/src/common/sessiond-comm/inet.c
> index 25dbd21..0e72bb7 100644
> --- a/src/common/sessiond-comm/inet.c
> +++ b/src/common/sessiond-comm/inet.c
> @@ -176,6 +176,8 @@ int connect_with_timeout(struct lttcomm_sock *sock)
> goto success;
> }
>
> + DBG("Asynchronous connect for sock %d, performing polling with"
> + " timeout: %lums", sock->fd, timeout);
> /*
> * Perform poll loop following EINPROGRESS recommendation from
> * connect(2) man page.
> @@ -202,12 +204,16 @@ int connect_with_timeout(struct lttcomm_sock *sock)
> ret = getsockopt(sock->fd, SOL_SOCKET,
> SO_ERROR, &optval, &optval_len);
> if (ret) {
> + PERROR("getsockopt");
> goto error;
> }
> if (!optval) {
> + /* errno is set to zero from getsockopt */
> connect_ret = 0;
> goto success;
> } else {
> + /* Get actual connect() errno from opt_val */
> + errno = optval;
> goto error;
> }
> }
> diff --git a/src/common/sessiond-comm/inet6.c b/src/common/sessiond-comm/inet6.c
> index 0b0383c..071fd52 100644
> --- a/src/common/sessiond-comm/inet6.c
> +++ b/src/common/sessiond-comm/inet6.c
> @@ -174,6 +174,9 @@ int connect_with_timeout(struct lttcomm_sock *sock)
> goto success;
> }
>
> + DBG("Asynchronous connect for sock %d, performing polling with"
> + " timeout: %lums", sock->fd, timeout);
> +
> /*
> * Perform poll loop following EINPROGRESS recommendation from
> * connect(2) man page.
> @@ -200,12 +203,16 @@ int connect_with_timeout(struct lttcomm_sock *sock)
> ret = getsockopt(sock->fd, SOL_SOCKET,
> SO_ERROR, &optval, &optval_len);
> if (ret) {
> + PERROR("getsockopt");
> goto error;
> }
> if (!optval) {
> + /* errno is set to zero from getsockopt */
> connect_ret = 0;
> goto success;
> } else {
> + /* Get actual connect() errno from opt_val */
> + errno = optval;
> goto error;
> }
> }
> --
> 2.7.4
>
More information about the lttng-dev
mailing list