Hi,

> -----Original Message-----
> From: [email protected] [mailto:linux-rdma-
> [email protected]] On Behalf Of Gustavo A. R. Silva
> Sent: Thursday, May 4, 2017 12:42 PM
> To: Doug Ledford <[email protected]>; Sean Hefty
> <[email protected]>; Hal Rosenstock <[email protected]>; Sagi
> Grimberg <[email protected]>; Bart Van Assche
> <[email protected]>; Steve Wise <[email protected]>;
> Leon Romanovsky <[email protected]>; Yishai Hadas
> <[email protected]>; Moni Shoua <[email protected]>
> Cc: [email protected]; [email protected]
> Subject: [infiniband-core] question about arguments position
> 
> 
> Hello everybody,
> 
> While looking into Coverity ID 1351047 I ran into the following piece of code 
> at
> drivers/infiniband/core/verbs.c:496:
> 
> ret = rdma_addr_find_l2_eth_by_grh(&dgid, &sgid,
>                                     ah_attr->dmac,
>                                     wc->wc_flags & IB_WC_WITH_VLAN ?
>                                     NULL : &vlan_id,
>                                     &if_index, &hoplimit);
> 
> 
> The issue here is that the position of arguments in the call to
> rdma_addr_find_l2_eth_by_grh() function do not match the order of the
> parameters:
> 
> &dgid is passed to sgid
> &sgid is passed to dgid
> 
> This is the function prototype:
> 
> int rdma_addr_find_l2_eth_by_grh(const union ib_gid *sgid,
>                                const union ib_gid *dgid,
>                                u8 *dmac, u16 *vlan_id, int *if_index,
>                                int *hoplimit)
> 
> My question here is if this is intentional?
> 
Yes. ib_init_ah_from_wc() creates ah from the incoming packet.
Incoming packet has dgid of the receiver node on which this code is getting 
executed
And sgid contains the GID of the sender.

When resolving mac address of destination, you use arrived dgid as sgid.
And use sgid as dgid because sgid contains destinations GID whom to respond to.

Reply via email to