[lttng-dev] [PATCH lttng-tools v2] Fix: Use SOL_SOCKET level for SO_KEEPALIVE on all platform

Jérémie Galarneau jeremie.galarneau at efficios.com
Tue Feb 27 11:14:42 EST 2018


Merged in master, stable-2.10, and stable-2.9.

Thanks!
Jérémie

On Wed, Feb 21, 2018 at 04:59:54PM -0500, Jonathan Rajotte wrote:
> On Linux, COMPAT_SOCKET_LEVEL was set to SOL_TCP instead
> of SOL_SOCKET, this resulted in execution of:
>     setsockopt(..., SOL_TCP, TCP_DEFER_ACCEPT, ...)
> 
> Instead of:
>     setsockopt(..., SOL_SOCKET, SO_KEEPALIVE, ...)
> 
> Hence, TCP keep alive was not enabled.
> 
> COMPAT_SOCKET_LEVEL is not needed. All platforms supported use the
> SOL_SOCKET level for SO_KEEPALIVE.
> 
> Signed-off-by: Jonathan Rajotte <jonathan.rajotte-julien at efficios.com>
> ---
>  src/bin/lttng-relayd/tcp_keep_alive.c | 5 +----
>  1 file changed, 1 insertion(+), 4 deletions(-)
> 
> diff --git a/src/bin/lttng-relayd/tcp_keep_alive.c b/src/bin/lttng-relayd/tcp_keep_alive.c
> index 4a2cd9f..469bec3 100644
> --- a/src/bin/lttng-relayd/tcp_keep_alive.c
> +++ b/src/bin/lttng-relayd/tcp_keep_alive.c
> @@ -36,7 +36,6 @@
>  /* Per-platform definitions of TCP socket options. */
>  #if defined (__linux__)
>  
> -#define COMPAT_SOCKET_LEVEL SOL_TCP
>  #define COMPAT_TCP_LEVEL SOL_TCP
>  #define COMPAT_TCP_ABORT_THRESHOLD 0 /* Does not exist on linux. */
>  #define COMPAT_TCP_KEEPIDLE TCP_KEEPIDLE
> @@ -45,7 +44,6 @@
>  
>  #elif defined (__sun__) /* ! defined (__linux__) */
>  
> -#define COMPAT_SOCKET_LEVEL SOL_SOCKET
>  #define COMPAT_TCP_LEVEL IPPROTO_TCP
>  
>  #ifdef TCP_KEEPALIVE_THRESHOLD
> @@ -65,7 +63,6 @@
>  
>  #else /* ! defined (__linux__) && ! defined (__sun__) */
>  
> -#define COMPAT_SOCKET_LEVEL 0
>  #define COMPAT_TCP_LEVEL 0
>  #define COMPAT_TCP_ABORT_THRESHOLD 0
>  #define COMPAT_TCP_KEEPIDLE 0
> @@ -547,7 +544,7 @@ int socket_apply_keep_alive_config(int socket_fd)
>  		goto end;
>  	}
>  
> -	ret = setsockopt(socket_fd, COMPAT_SOCKET_LEVEL, SO_KEEPALIVE, &val,
> +	ret = setsockopt(socket_fd, SOL_SOCKET, SO_KEEPALIVE, &val,
>  			sizeof(val));
>  	if (ret < 0) {
>  		PERROR("setsockopt so_keepalive");
> -- 
> 2.7.4
> 


More information about the lttng-dev mailing list