From: Doug Ledford <dledford-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
To: Leon Romanovsky <leon-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
Cc: linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
Jack Morgenstein
<jackm-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org>,
Spencer Baugh <sbaugh-n2IX9UM++eDQT0dZR+AlfA@public.gmane.org>
Subject: Re: [PATCH] RDMA/cma: Fix unknown symbol when CONFIG_IPV6 is not enabled
Date: Tue, 24 Jan 2017 16:28:50 -0500 [thread overview]
Message-ID: <1485293330.43764.80.camel@redhat.com> (raw)
In-Reply-To: <20170115181500.4465-1-leon-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
[-- Attachment #1: Type: text/plain, Size: 2284 bytes --]
On Sun, 2017-01-15 at 20:15 +0200, Leon Romanovsky wrote:
> From: Jack Morgenstein <jackm-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org>
>
> If IPV6 has not been enabled in the underlying kernel, we must avoid
> calling IPV6 procedures in rdma_cm.ko.
>
> This requires using "IS_ENABLED(CONFIG_IPV6)" in "if" statements
> surrounding any code which calls external IPV6 procedures.
This seems strange....
> In the instance fixed here, procedure cma_bind_addr() called
> ipv6_addr_type() -- which resulted in calling external procedure
> __ipv6_addr_type().
>
> Fixes: 6c26a77124ff ("RDMA/cma: fix IPv6 address resolution")
> Cc: <stable-u79uwXL29TY76Z2rM5mHXA@public.gmane.org> # v4.2+
> Cc: Spencer Baugh <sbaugh-n2IX9UM++eDQT0dZR+AlfA@public.gmane.org>
> Signed-off-by: Jack Morgenstein <jackm-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org>
> Reviewed-by: Moni Shoua <monis-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
> Signed-off-by: Leon Romanovsky <leon-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
> ---
> drivers/infiniband/core/cma.c | 3 ++-
> 1 file changed, 2 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/infiniband/core/cma.c
> b/drivers/infiniband/core/cma.c
> index bd8d051..e19f19c 100644
> --- a/drivers/infiniband/core/cma.c
> +++ b/drivers/infiniband/core/cma.c
> @@ -2822,7 +2822,8 @@ static int cma_bind_addr(struct rdma_cm_id *id,
> struct sockaddr *src_addr,
> if (!src_addr || !src_addr->sa_family) {
> src_addr = (struct sockaddr *) &id-
> >route.addr.src_addr;
> src_addr->sa_family = dst_addr->sa_family;
> - if (dst_addr->sa_family == AF_INET6) {
Why this construct? Isn't the norm to simply surround the entire if
statement with
#if IS_ENABLED(CONFIG_IPV6)
...
#endif
> + if (IS_ENABLED(CONFIG_IPV6) &&
> + dst_addr->sa_family == AF_INET6) {
> struct sockaddr_in6 *src_addr6 = (struct
> sockaddr_in6 *) src_addr;
> struct sockaddr_in6 *dst_addr6 = (struct
> sockaddr_in6 *) dst_addr;
> src_addr6->sin6_scope_id = dst_addr6-
> >sin6_scope_id;
> --
> 2.10.2
>
--
Doug Ledford <dledford-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
GPG KeyID: B826A3330E572FDD
Key fingerprint = AE6B 1BDA 122B 23B4 265B 1274 B826 A333 0E57 2FDD
[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 819 bytes --]
next prev parent reply other threads:[~2017-01-24 21:28 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-01-15 18:15 [PATCH] RDMA/cma: Fix unknown symbol when CONFIG_IPV6 is not enabled Leon Romanovsky
[not found] ` <20170115181500.4465-1-leon-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
2017-01-24 21:28 ` Doug Ledford [this message]
[not found] ` <1485293330.43764.80.camel-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2017-01-25 6:51 ` Leon Romanovsky
[not found] ` <20170125065115.GM6005-U/DQcQFIOTAAJjI8aNfphQ@public.gmane.org>
2017-01-26 16:14 ` Doug Ledford
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=1485293330.43764.80.camel@redhat.com \
--to=dledford-h+wxahxf7alqt0dzr+alfa@public.gmane.org \
--cc=jackm-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org \
--cc=leon-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org \
--cc=linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=sbaugh-n2IX9UM++eDQT0dZR+AlfA@public.gmane.org \
/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.