Add support for the set_vf_guid and get_vf_config verbs.

Signed-off-by: Or Gerlitz <[email protected]>
---
 drivers/infiniband/hw/mlx4/main.c        |   26 ++++++++++++++++++++++++++
 drivers/net/ethernet/mellanox/mlx4/cmd.c |   26 ++++++++++++++++++--------
 include/linux/mlx4/device.h              |    2 ++
 3 files changed, 46 insertions(+), 8 deletions(-)

diff --git a/drivers/infiniband/hw/mlx4/main.c 
b/drivers/infiniband/hw/mlx4/main.c
index 57070c5..17b6fa7 100644
--- a/drivers/infiniband/hw/mlx4/main.c
+++ b/drivers/infiniband/hw/mlx4/main.c
@@ -1325,6 +1325,27 @@ err_malloc:
        return err;
 }
 
+static int mlx4_ib_set_vf_guid(struct ib_device *ibdev, int port, int vf, u64 
guid)
+{
+       int slave;
+       struct mlx4_ib_dev *mdev = to_mdev(ibdev);
+
+       slave = mlx4_get_slave_indx(mdev->dev, vf);
+       if (slave < 0)
+               return -EINVAL;
+
+       mlx4_store_admin_alias_guid(mdev, port, slave, cpu_to_be64(guid));
+
+       return 0;
+}
+
+static int mlx4_ib_get_vf_config(struct ib_device *ibdev, int port, int vf, 
struct ifla_vf_info *ivf)
+{
+       struct mlx4_ib_dev *mdev = to_mdev(ibdev);
+
+       return mlx4_get_vf_config(mdev->dev, port, vf, ivf);
+}
+
 static struct mlx4_ib_gid_entry *find_gid_entry(struct mlx4_ib_qp *qp, u8 *raw)
 {
        struct mlx4_ib_gid_entry *ge;
@@ -2250,6 +2271,11 @@ static void *mlx4_ib_add(struct mlx4_dev *dev)
                ibdev->ib_dev.dealloc_fmr       = mlx4_ib_fmr_dealloc;
        }
 
+       if (mlx4_is_master(ibdev->dev)) {
+               ibdev->ib_dev.set_vf_guid   = mlx4_ib_set_vf_guid;
+               ibdev->ib_dev.get_vf_config = mlx4_ib_get_vf_config;
+       }
+
        if (dev->caps.flags & MLX4_DEV_CAP_FLAG_MEM_WINDOW ||
            dev->caps.bmme_flags & MLX4_BMME_FLAG_TYPE_2_WIN) {
                ibdev->ib_dev.alloc_mw = mlx4_ib_alloc_mw;
diff --git a/drivers/net/ethernet/mellanox/mlx4/cmd.c 
b/drivers/net/ethernet/mellanox/mlx4/cmd.c
index 7761045..a544650 100644
--- a/drivers/net/ethernet/mellanox/mlx4/cmd.c
+++ b/drivers/net/ethernet/mellanox/mlx4/cmd.c
@@ -2647,7 +2647,7 @@ u32 mlx4_comm_get_version(void)
         return ((u32) CMD_CHAN_IF_REV << 8) | (u32) CMD_CHAN_VER;
 }
 
-static int mlx4_get_slave_indx(struct mlx4_dev *dev, int vf)
+int mlx4_get_slave_indx(struct mlx4_dev *dev, int vf)
 {
        if ((vf < 0) || (vf >= dev->persist->num_vfs)) {
                mlx4_err(dev, "Bad vf number:%d (number of activated vf: %d)\n",
@@ -2657,6 +2657,7 @@ static int mlx4_get_slave_indx(struct mlx4_dev *dev, int 
vf)
 
        return vf+1;
 }
+EXPORT_SYMBOL_GPL(mlx4_get_slave_indx);
 
 int mlx4_get_vf_indx(struct mlx4_dev *dev, int slave)
 {
@@ -3089,13 +3090,22 @@ int mlx4_get_vf_config(struct mlx4_dev *dev, int port, 
int vf, struct ifla_vf_in
        s_info = &priv->mfunc.master.vf_admin[slave].vport[port];
        ivf->vf = vf;
 
-       /* need to convert it to a func */
-       ivf->mac[0] = ((s_info->mac >> (5*8)) & 0xff);
-       ivf->mac[1] = ((s_info->mac >> (4*8)) & 0xff);
-       ivf->mac[2] = ((s_info->mac >> (3*8)) & 0xff);
-       ivf->mac[3] = ((s_info->mac >> (2*8)) & 0xff);
-       ivf->mac[4] = ((s_info->mac >> (1*8)) & 0xff);
-       ivf->mac[5] = ((s_info->mac)  & 0xff);
+       if (dev->caps.port_mask[port] == MLX4_PORT_TYPE_ETH) {
+               ivf->mac[0] = ((s_info->mac >> (5*8)) & 0xff);
+               ivf->mac[1] = ((s_info->mac >> (4*8)) & 0xff);
+               ivf->mac[2] = ((s_info->mac >> (3*8)) & 0xff);
+               ivf->mac[3] = ((s_info->mac >> (2*8)) & 0xff);
+               ivf->mac[4] = ((s_info->mac >> (1*8)) & 0xff);
+               ivf->mac[5] = ((s_info->mac)  & 0xff);
+       } else {
+               u64 guid = be64_to_cpu(s_info->guid);
+               ivf->mac[0] = ((guid >> (7*8)) & 0xff);
+               ivf->mac[1] = ((guid >> (6*8)) & 0xff);
+               ivf->mac[2] = ((guid >> (5*8)) & 0xff);
+               ivf->mac[3] = ((guid >> (2*8)) & 0xff);
+               ivf->mac[4] = ((guid >> (1*8)) & 0xff);
+               ivf->mac[5] = ((guid)  & 0xff);
+       }
 
        ivf->vlan               = s_info->default_vlan;
        ivf->qos                = s_info->default_qos;
diff --git a/include/linux/mlx4/device.h b/include/linux/mlx4/device.h
index 83e80ab..e5a70bd 100644
--- a/include/linux/mlx4/device.h
+++ b/include/linux/mlx4/device.h
@@ -1382,6 +1382,8 @@ int mlx4_get_slave_from_roce_gid(struct mlx4_dev *dev, 
int port, u8 *gid,
 int mlx4_get_roce_gid_from_slave(struct mlx4_dev *dev, int port, int slave_id,
                                 u8 *gid);
 
+int mlx4_get_slave_indx(struct mlx4_dev *dev, int vf);
+
 int mlx4_FLOW_STEERING_IB_UC_QP_RANGE(struct mlx4_dev *dev, u32 min_range_qpn,
                                      u32 max_range_qpn);
 
-- 
1.7.1

--
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