]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
IB/rxe: Do not hide uABI stuff in memcpy
authorJason Gunthorpe <jgg@mellanox.com>
Tue, 12 Jun 2018 02:56:50 +0000 (20:56 -0600)
committerJason Gunthorpe <jgg@mellanox.com>
Mon, 18 Jun 2018 17:09:05 +0000 (11:09 -0600)
struct rxe_global_route and struct ib_global_route are not the same thing
and should not be memcpy'd over each other, do a member by member copy
instead. This allows the layout of the in-kernel struct ib_global_route to
be changed without breaking rxe.

Reviewed-by: Zhu Yanjun <yanjun.zhu@oracle.com>
Reviewed-by: Leon Romanovsky <leonro@mellanox.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
drivers/infiniband/sw/rxe/rxe_av.c

index 7f1ae364088a07cad8de98189ee82603b1d8d2e6..c0f972c58d551e263bc722ec6b4675907bc41cd3 100644 (file)
@@ -55,16 +55,29 @@ int rxe_av_chk_attr(struct rxe_dev *rxe, struct rdma_ah_attr *attr)
 void rxe_av_from_attr(u8 port_num, struct rxe_av *av,
                     struct rdma_ah_attr *attr)
 {
+       const struct ib_global_route *grh = rdma_ah_read_grh(attr);
+
        memset(av, 0, sizeof(*av));
-       memcpy(&av->grh, rdma_ah_read_grh(attr),
-              sizeof(*rdma_ah_read_grh(attr)));
+       memcpy(av->grh.dgid.raw, grh->dgid.raw, sizeof(grh->dgid.raw));
+       av->grh.flow_label = grh->flow_label;
+       av->grh.sgid_index = grh->sgid_index;
+       av->grh.hop_limit = grh->hop_limit;
+       av->grh.traffic_class = grh->traffic_class;
        av->port_num = port_num;
 }
 
 void rxe_av_to_attr(struct rxe_av *av, struct rdma_ah_attr *attr)
 {
+       struct ib_global_route *grh = rdma_ah_retrieve_grh(attr);
+
        attr->type = RDMA_AH_ATTR_TYPE_ROCE;
-       memcpy(rdma_ah_retrieve_grh(attr), &av->grh, sizeof(av->grh));
+
+       memcpy(grh->dgid.raw, av->grh.dgid.raw, sizeof(av->grh.dgid.raw));
+       grh->flow_label = av->grh.flow_label;
+       grh->sgid_index = av->grh.sgid_index;
+       grh->hop_limit = av->grh.hop_limit;
+       grh->traffic_class = av->grh.traffic_class;
+
        rdma_ah_set_ah_flags(attr, IB_AH_GRH);
        rdma_ah_set_port_num(attr, av->port_num);
 }