Re: [PATCH rdma-next 02/15] net/mlx5: Set software owner ID during init HCA

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 12/24/2017 4:00 PM, Or Gerlitz wrote:
> On Sun, Dec 24, 2017 at 2:57 PM, Leon Romanovsky <leon@xxxxxxxxxx> wrote:
>> From: Daniel Jurgens <danielj@xxxxxxxxxxxx>
>>
>> Generate a unique 128bit identifier for each host and pass that value to
>> firmware in the INIT_HCA command if it reports the sw_owner_id
>> capo ability. This value is used by FW to determine if functions are in
>> use by the same host.
> "capo ability"?
>
> did you want to say the same driver instance? b/c multiple instances
> of the driver can run on a host
No, we want to set the same SW owner ID set for all devices for that host.  Not per driver instance.
>
>
>> Signed-off-by: Daniel Jurgens <danielj@xxxxxxxxxxxx>
>> Reviewed-by: Parav Pandit <parav@xxxxxxxxxxxx>
>> ---
>>  drivers/net/ethernet/mellanox/mlx5/core/fw.c        | 10 +++++++++-
>>  drivers/net/ethernet/mellanox/mlx5/core/main.c      |  6 +++++-
>>  drivers/net/ethernet/mellanox/mlx5/core/mlx5_core.h |  2 +-
>>  include/linux/mlx5/device.h                         |  5 +++++
>>  include/linux/mlx5/mlx5_ifc.h                       |  5 ++++-
>>  5 files changed, 24 insertions(+), 4 deletions(-)
>>
>> diff --git a/drivers/net/ethernet/mellanox/mlx5/core/fw.c b/drivers/net/ethernet/mellanox/mlx5/core/fw.c
>> index 5ef1b56b6a96..9d11e92fb541 100644
>> --- a/drivers/net/ethernet/mellanox/mlx5/core/fw.c
>> +++ b/drivers/net/ethernet/mellanox/mlx5/core/fw.c
>> @@ -195,12 +195,20 @@ int mlx5_query_hca_caps(struct mlx5_core_dev *dev)
>>         return 0;
>>  }
>>
>> -int mlx5_cmd_init_hca(struct mlx5_core_dev *dev)
>> +int mlx5_cmd_init_hca(struct mlx5_core_dev *dev, uint32_t *sw_owner_id)
>>  {
>>         u32 out[MLX5_ST_SZ_DW(init_hca_out)] = {0};
>>         u32 in[MLX5_ST_SZ_DW(init_hca_in)]   = {0};
>> +       int i;
>>
>>         MLX5_SET(init_hca_in, in, opcode, MLX5_CMD_OP_INIT_HCA);
>> +
>> +       if (MLX5_CAP_GEN(dev, sw_owner_id)) {
>> +               for (i = 0; i < 4; i++)
>> +                       MLX5_ARRAY_SET(init_hca_in, in, sw_owner_id, i,
>> +                                      sw_owner_id[i]);
>> +       }
>> +
>>         return mlx5_cmd_exec(dev, in, sizeof(in), out, sizeof(out));
>>  }
>>
>> diff --git a/drivers/net/ethernet/mellanox/mlx5/core/main.c b/drivers/net/ethernet/mellanox/mlx5/core/main.c
>> index 5f323442cc5a..5f3dc0ede917 100644
>> --- a/drivers/net/ethernet/mellanox/mlx5/core/main.c
>> +++ b/drivers/net/ethernet/mellanox/mlx5/core/main.c
>> @@ -75,6 +75,8 @@ static unsigned int prof_sel = MLX5_DEFAULT_PROF;
>>  module_param_named(prof_sel, prof_sel, uint, 0444);
>>  MODULE_PARM_DESC(prof_sel, "profile selector. Valid range 0 - 2");
>>
>> +static u32 sw_owner_id[4];
>> +
>>  enum {
>>         MLX5_ATOMIC_REQ_MODE_BE = 0x0,
>>         MLX5_ATOMIC_REQ_MODE_HOST_ENDIANNESS = 0x1,
>> @@ -1052,7 +1054,7 @@ static int mlx5_load_one(struct mlx5_core_dev *dev, struct mlx5_priv *priv,
>>                 goto reclaim_boot_pages;
>>         }
>>
>> -       err = mlx5_cmd_init_hca(dev);
>> +       err = mlx5_cmd_init_hca(dev, sw_owner_id);
>>         if (err) {
>>                 dev_err(&pdev->dev, "init hca failed\n");
>>                 goto err_pagealloc_stop;
>> @@ -1574,6 +1576,8 @@ static int __init init(void)
>>  {
>>         int err;
>>
>> +       get_random_bytes(&sw_owner_id, sizeof(sw_owner_id));
>> +
>>         mlx5_core_verify_params();
>>         mlx5_register_debugfs();
>>
>> diff --git a/drivers/net/ethernet/mellanox/mlx5/core/mlx5_core.h b/drivers/net/ethernet/mellanox/mlx5/core/mlx5_core.h
>> index ff4a0b889a6f..b05868728da7 100644
>> --- a/drivers/net/ethernet/mellanox/mlx5/core/mlx5_core.h
>> +++ b/drivers/net/ethernet/mellanox/mlx5/core/mlx5_core.h
>> @@ -86,7 +86,7 @@ enum {
>>
>>  int mlx5_query_hca_caps(struct mlx5_core_dev *dev);
>>  int mlx5_query_board_id(struct mlx5_core_dev *dev);
>> -int mlx5_cmd_init_hca(struct mlx5_core_dev *dev);
>> +int mlx5_cmd_init_hca(struct mlx5_core_dev *dev, uint32_t *sw_owner_id);
>>  int mlx5_cmd_teardown_hca(struct mlx5_core_dev *dev);
>>  int mlx5_cmd_force_teardown_hca(struct mlx5_core_dev *dev);
>>  void mlx5_core_event(struct mlx5_core_dev *dev, enum mlx5_dev_event event,
>> diff --git a/include/linux/mlx5/device.h b/include/linux/mlx5/device.h
>> index 409ffb14298a..18c041966ab8 100644
>> --- a/include/linux/mlx5/device.h
>> +++ b/include/linux/mlx5/device.h
>> @@ -79,6 +79,11 @@
>>                      << __mlx5_dw_bit_off(typ, fld))); \
>>  } while (0)
>>
>> +#define MLX5_ARRAY_SET(typ, p, fld, idx, v) do { \
>> +       BUILD_BUG_ON(__mlx5_bit_off(typ, fld) % 32); \
>> +       MLX5_SET(typ, p, fld[idx], v); \
>> +} while (0)
>> +
> Parav, Dan, we I pointed to you during the dscp trust mode work, changes
> to this area of the code should have the RB sig of Eli Cohen or Saeed if you
> can't get Eli, please do that.
>
>
>>  #define MLX5_SET_TO_ONES(typ, p, fld) do { \
>>         BUILD_BUG_ON(__mlx5_st_sz_bits(typ) % 32);             \
>>         *((__be32 *)(p) + __mlx5_dw_off(typ, fld)) = \
>> diff --git a/include/linux/mlx5/mlx5_ifc.h b/include/linux/mlx5/mlx5_ifc.h
>> index 38a7577a9ce7..b1c81d7a86cb 100644
>> --- a/include/linux/mlx5/mlx5_ifc.h
>> +++ b/include/linux/mlx5/mlx5_ifc.h
>> @@ -1066,7 +1066,9 @@ struct mlx5_ifc_cmd_hca_cap_bits {
>>         u8         reserved_at_5f8[0x3];
>>         u8         log_max_xrq[0x5];
>>
>> -       u8         reserved_at_600[0x200];
>> +       u8         reserved_at_600[0x1e];
>> +       u8         sw_owner_id;
>> +       u8         reserved_at_61f[0x1e1];
>>  };
>>
>>  enum mlx5_flow_destination_type {
>> @@ -5531,6 +5533,7 @@ struct mlx5_ifc_init_hca_in_bits {
>>         u8         op_mod[0x10];
>>
>>         u8         reserved_at_40[0x40];
>> +       u8         sw_owner_id[4][0x20];
>>  };
> can we do here just a plane addition of bits? don't have the code
> infront of me, but seems suspicious
I don't understand what you are asking.  This is what the tool generated.
--
To unsubscribe from this list: send the line "unsubscribe linux-rdma" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Photo]     [Yosemite News]     [Yosemite Photos]     [Linux Kernel]     [Linux SCSI]     [XFree86]
  Powered by Linux