All of lore.kernel.org
 help / color / mirror / Atom feed
From: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
To: Xin Long <lucien.xin@gmail.com>
Cc: network dev <netdev@vger.kernel.org>,
	linux-sctp@vger.kernel.org, davem@davemloft.net,
	Neil Horman <nhorman@tuxdriver.com>
Subject: Re: [PATCH net] sctp: do not allow the v4 socket to bind a v4mapped v6 address
Date: Mon, 15 Jan 2018 20:17:32 +0000	[thread overview]
Message-ID: <20180115201732.GA7580@localhost.localdomain> (raw)
In-Reply-To: <e43f937592a7b022a72bdbbd784742ee6b3f6def.1516006920.git.lucien.xin@gmail.com>

On Mon, Jan 15, 2018 at 05:02:00PM +0800, Xin Long wrote:
> The check in sctp_sockaddr_af is not robust enough to forbid binding a
> v4mapped v6 addr on a v4 socket.
> 
> The worse thing is that v4 socket's bind_verify would not convert this
> v4mapped v6 addr to a v4 addr. syzbot even reported a crash as the v4
> socket bound a v6 addr.
> 
> This patch is to fix it by doing the common sa.sa_family check first,
> then AF_INET check for v4mapped v6 addrs.
> 
> Fixes: 7dab83de50c7 ("sctp: Support ipv6only AF_INET6 sockets.")
> Reported-by: syzbot+7b7b518b1228d2743963@syzkaller.appspotmail.com
> Acked-by: Neil Horman <nhorman@tuxdriver.com>
> Signed-off-by: Xin Long <lucien.xin@gmail.com>

Acked-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>

> ---
>  net/sctp/socket.c | 14 ++++++--------
>  1 file changed, 6 insertions(+), 8 deletions(-)
> 
> diff --git a/net/sctp/socket.c b/net/sctp/socket.c
> index feb2ca6..039fcb6 100644
> --- a/net/sctp/socket.c
> +++ b/net/sctp/socket.c
> @@ -335,16 +335,14 @@ static struct sctp_af *sctp_sockaddr_af(struct sctp_sock *opt,
>  	if (len < sizeof (struct sockaddr))
>  		return NULL;
>  
> +	if (!opt->pf->af_supported(addr->sa.sa_family, opt))
> +		return NULL;
> +
>  	/* V4 mapped address are really of AF_INET family */
>  	if (addr->sa.sa_family = AF_INET6 &&
> -	    ipv6_addr_v4mapped(&addr->v6.sin6_addr)) {
> -		if (!opt->pf->af_supported(AF_INET, opt))
> -			return NULL;
> -	} else {
> -		/* Does this PF support this AF? */
> -		if (!opt->pf->af_supported(addr->sa.sa_family, opt))
> -			return NULL;
> -	}
> +	    ipv6_addr_v4mapped(&addr->v6.sin6_addr) &&
> +	    !opt->pf->af_supported(AF_INET, opt))
> +		return NULL;
>  
>  	/* If we get this far, af is valid. */
>  	af = sctp_get_af_specific(addr->sa.sa_family);
> -- 
> 2.1.0
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-sctp" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 

WARNING: multiple messages have this Message-ID (diff)
From: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
To: Xin Long <lucien.xin@gmail.com>
Cc: network dev <netdev@vger.kernel.org>,
	linux-sctp@vger.kernel.org, davem@davemloft.net,
	Neil Horman <nhorman@tuxdriver.com>
Subject: Re: [PATCH net] sctp: do not allow the v4 socket to bind a v4mapped v6 address
Date: Mon, 15 Jan 2018 18:17:32 -0200	[thread overview]
Message-ID: <20180115201732.GA7580@localhost.localdomain> (raw)
In-Reply-To: <e43f937592a7b022a72bdbbd784742ee6b3f6def.1516006920.git.lucien.xin@gmail.com>

On Mon, Jan 15, 2018 at 05:02:00PM +0800, Xin Long wrote:
> The check in sctp_sockaddr_af is not robust enough to forbid binding a
> v4mapped v6 addr on a v4 socket.
> 
> The worse thing is that v4 socket's bind_verify would not convert this
> v4mapped v6 addr to a v4 addr. syzbot even reported a crash as the v4
> socket bound a v6 addr.
> 
> This patch is to fix it by doing the common sa.sa_family check first,
> then AF_INET check for v4mapped v6 addrs.
> 
> Fixes: 7dab83de50c7 ("sctp: Support ipv6only AF_INET6 sockets.")
> Reported-by: syzbot+7b7b518b1228d2743963@syzkaller.appspotmail.com
> Acked-by: Neil Horman <nhorman@tuxdriver.com>
> Signed-off-by: Xin Long <lucien.xin@gmail.com>

Acked-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>

> ---
>  net/sctp/socket.c | 14 ++++++--------
>  1 file changed, 6 insertions(+), 8 deletions(-)
> 
> diff --git a/net/sctp/socket.c b/net/sctp/socket.c
> index feb2ca6..039fcb6 100644
> --- a/net/sctp/socket.c
> +++ b/net/sctp/socket.c
> @@ -335,16 +335,14 @@ static struct sctp_af *sctp_sockaddr_af(struct sctp_sock *opt,
>  	if (len < sizeof (struct sockaddr))
>  		return NULL;
>  
> +	if (!opt->pf->af_supported(addr->sa.sa_family, opt))
> +		return NULL;
> +
>  	/* V4 mapped address are really of AF_INET family */
>  	if (addr->sa.sa_family == AF_INET6 &&
> -	    ipv6_addr_v4mapped(&addr->v6.sin6_addr)) {
> -		if (!opt->pf->af_supported(AF_INET, opt))
> -			return NULL;
> -	} else {
> -		/* Does this PF support this AF? */
> -		if (!opt->pf->af_supported(addr->sa.sa_family, opt))
> -			return NULL;
> -	}
> +	    ipv6_addr_v4mapped(&addr->v6.sin6_addr) &&
> +	    !opt->pf->af_supported(AF_INET, opt))
> +		return NULL;
>  
>  	/* If we get this far, af is valid. */
>  	af = sctp_get_af_specific(addr->sa.sa_family);
> -- 
> 2.1.0
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-sctp" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 

  reply	other threads:[~2018-01-15 20:17 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-01-15  9:02 [PATCH net] sctp: do not allow the v4 socket to bind a v4mapped v6 address Xin Long
2018-01-15  9:02 ` Xin Long
2018-01-15 20:17 ` Marcelo Ricardo Leitner [this message]
2018-01-15 20:17   ` Marcelo Ricardo Leitner
2018-01-16 19:25 ` David Miller
2018-01-16 19:25   ` David Miller

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20180115201732.GA7580@localhost.localdomain \
    --to=marcelo.leitner@gmail.com \
    --cc=davem@davemloft.net \
    --cc=linux-sctp@vger.kernel.org \
    --cc=lucien.xin@gmail.com \
    --cc=netdev@vger.kernel.org \
    --cc=nhorman@tuxdriver.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.