@@ -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;
@@ -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;
@@ -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);
Add support for the set_vf_guid and get_vf_config verbs. Signed-off-by: Or Gerlitz <ogerlitz@mellanox.com> --- 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(-)