>Actually, thinking about it some more, that would be very helpful. As
>I said before, I have worked on apps using IB CM. The only reason is
>to have complete control over the addressing. If I could use RDMA CM
>API in some kind of AF_GID addressing and service ID space, it would
>basically eliminate the need for IB CM entirely and make it alot less
>trouble to support things like iWarp, since it now just another AF/PF
>in the same API family.

In order to maintain application level compatibility, there are a few
requirements for the changes in this patch.  An event needs to be queued
indicating that the librdmacm rdma_resolve_addr() call is complete.  The IB CM
REQ message should carry the IP address, so that data should be set.  And the
state of the rdma_cm_id needs to change.

I did consider the possibility of having the sockaddr contain some IB related
address, with user space performing the mapping.  My thought was that the IP
address needed to be given to the kernel since the IB CM message carries the IP
address in the private data.  The GID could actually be extracted from the
rdma_set_ib_paths() call.

I'm not sure about defining a new address family for GIDs, given that a GID is
already supposed to be an IPv6 address.  Maybe the RDMA CM could check whether
an address mapped to IB GID or not.  If the source address of either an
rdma_bind_addr or rdma_resolve_addr call were an actual GID, it could assume the
same of the destination address.  Something would need to be done to determine
what would go into the IB CM REQ, but that may introduce incompatibilities. 

Note that between the two patches, this one is less important to scaling than
the other one.  It would be ideal to avoid sending ARP requests when they are
not needed. 

>You get the source address via the user (netlink) or kernel
>(ip_route_output_key) equivalent of 'ip route get x.x.x.x dev XXX'

Yes - ip route get gives what's needed.  Is there a simple way to obtain that
same data from within a program?

--
To unsubscribe from this list: send the line "unsubscribe linux-rdma" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to