Re: [PATCH for-next 2/2] RDMA/efa: Report host information to the device

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

 



On 10/05/2020 15:29, Leon Romanovsky wrote:
> On Sun, May 10, 2020 at 02:59:18PM +0300, Gal Pressman wrote:
>> diff --git a/drivers/infiniband/hw/efa/efa_admin_cmds_defs.h b/drivers/infiniband/hw/efa/efa_admin_cmds_defs.h
>> index 96b104ab5415..efdeebc9ea9b 100644
>> --- a/drivers/infiniband/hw/efa/efa_admin_cmds_defs.h
>> +++ b/drivers/infiniband/hw/efa/efa_admin_cmds_defs.h
>> @@ -37,7 +37,7 @@ enum efa_admin_aq_feature_id {
>>  	EFA_ADMIN_NETWORK_ATTR                      = 3,
>>  	EFA_ADMIN_QUEUE_ATTR                        = 4,
>>  	EFA_ADMIN_HW_HINTS                          = 5,
>> -	EFA_ADMIN_FEATURES_OPCODE_NUM               = 8,
>> +	EFA_ADMIN_HOST_INFO                         = 6,
>>  };
>>
>>  /* QP transport type */
>> @@ -799,6 +799,55 @@ struct efa_admin_mmio_req_read_less_resp {
>>  	u32 reg_val;
>>  };
>>
>> +enum efa_admin_os_type {
>> +	EFA_ADMIN_OS_LINUX                          = 0,
>> +	EFA_ADMIN_OS_WINDOWS                        = 1,
> 
> Not used.

That's the device interface..

> 
>> +};
>> +
>> +struct efa_admin_host_info {
>> +	/* OS distribution string format */
>> +	u8 os_dist_str[128];
>> +
>> +	/* Defined in enum efa_admin_os_type */
>> +	u32 os_type;
>> +
>> +	/* Kernel version string format */
>> +	u8 kernel_ver_str[32];
>> +
>> +	/* Kernel version numeric format */
>> +	u32 kernel_ver;
>> +
>> +	/*
>> +	 * 7:0 : driver_module_type
>> +	 * 15:8 : driver_sub_minor
>> +	 * 23:16 : driver_minor
>> +	 * 31:24 : driver_major
>> +	 */
>> +	u32 driver_ver;
> 
> No to this.

Same, this is the device interface.
And obviously it's not used as we don't have a driver version.

> 
>> +
>> +	/*
>> +	 * Device's Bus, Device and Function
>> +	 * 2:0 : function
>> +	 * 7:3 : device
>> +	 * 15:8 : bus
>> +	 */
>> +	u16 bdf;
>> +
>> +	/*
>> +	 * Spec version
>> +	 * 7:0 : spec_minor
>> +	 * 15:8 : spec_major
>> +	 */
>> +	u16 spec_ver;
>> +
>> +	/*
>> +	 * 0 : intree - Intree driver
>> +	 * 1 : gdr - GPUDirect RDMA supported
>> +	 * 31:2 : reserved2
>> +	 */
>> +	u32 flags;
>> +};
>> +
>>  /* create_qp_cmd */
>>  #define EFA_ADMIN_CREATE_QP_CMD_SQ_VIRT_MASK                BIT(0)
>>  #define EFA_ADMIN_CREATE_QP_CMD_RQ_VIRT_MASK                BIT(1)
>> @@ -820,4 +869,17 @@ struct efa_admin_mmio_req_read_less_resp {
>>  /* feature_device_attr_desc */
>>  #define EFA_ADMIN_FEATURE_DEVICE_ATTR_DESC_RDMA_READ_MASK   BIT(0)
>>
>> +/* host_info */
>> +#define EFA_ADMIN_HOST_INFO_DRIVER_MODULE_TYPE_MASK         GENMASK(7, 0)
>> +#define EFA_ADMIN_HOST_INFO_DRIVER_SUB_MINOR_MASK           GENMASK(15, 8)
>> +#define EFA_ADMIN_HOST_INFO_DRIVER_MINOR_MASK               GENMASK(23, 16)
>> +#define EFA_ADMIN_HOST_INFO_DRIVER_MAJOR_MASK               GENMASK(31, 24)
> 
> Not in use.

Same.

> 
>> +#define EFA_ADMIN_HOST_INFO_FUNCTION_MASK                   GENMASK(2, 0)
>> +#define EFA_ADMIN_HOST_INFO_DEVICE_MASK                     GENMASK(7, 3)
>> +#define EFA_ADMIN_HOST_INFO_BUS_MASK                        GENMASK(15, 8)
>> +#define EFA_ADMIN_HOST_INFO_SPEC_MINOR_MASK                 GENMASK(7, 0)
>> +#define EFA_ADMIN_HOST_INFO_SPEC_MAJOR_MASK                 GENMASK(15, 8)
>> +#define EFA_ADMIN_HOST_INFO_INTREE_MASK                     BIT(0)
>> +#define EFA_ADMIN_HOST_INFO_GDR_MASK                        BIT(1)
>> +
>>  #endif /* _EFA_ADMIN_CMDS_H_ */
>> +static void efa_set_host_info(struct efa_dev *dev)
>> +{
>> +	struct efa_admin_set_feature_resp resp = {};
>> +	struct efa_admin_set_feature_cmd cmd = {};
>> +	struct efa_admin_host_info *hinf;
>> +	u32 bufsz = sizeof(*hinf);
>> +	dma_addr_t hinf_dma;
>> +
>> +	if (!efa_com_check_supported_feature_id(&dev->edev,
>> +						EFA_ADMIN_HOST_INFO))
>> +		return;
>> +
>> +	/* Failures in host info set shall not disturb probe */
>> +	hinf = dma_alloc_coherent(&dev->pdev->dev, bufsz, &hinf_dma,
>> +				  GFP_KERNEL);
>> +	if (!hinf)
>> +		return;
>> +
>> +	strlcpy(hinf->os_dist_str, utsname()->release,
>> +		min(sizeof(hinf->os_dist_str), sizeof(utsname()->release)));
>> +	hinf->os_type = EFA_ADMIN_OS_LINUX;
>> +	strlcpy(hinf->kernel_ver_str, utsname()->version,
>> +		min(sizeof(hinf->kernel_ver_str), sizeof(utsname()->version)));
>> +	hinf->kernel_ver = LINUX_VERSION_CODE;
>> +	EFA_SET(&hinf->bdf, EFA_ADMIN_HOST_INFO_BUS, dev->pdev->bus->number);
>> +	EFA_SET(&hinf->bdf, EFA_ADMIN_HOST_INFO_DEVICE,
>> +		PCI_SLOT(dev->pdev->devfn));
>> +	EFA_SET(&hinf->bdf, EFA_ADMIN_HOST_INFO_FUNCTION,
>> +		PCI_FUNC(dev->pdev->devfn));
>> +	EFA_SET(&hinf->spec_ver, EFA_ADMIN_HOST_INFO_SPEC_MAJOR,
>> +		EFA_COMMON_SPEC_VERSION_MAJOR);
>> +	EFA_SET(&hinf->spec_ver, EFA_ADMIN_HOST_INFO_SPEC_MINOR,
>> +		EFA_COMMON_SPEC_VERSION_MINOR);
>> +	EFA_SET(&hinf->flags, EFA_ADMIN_HOST_INFO_INTREE, 1);
> 
> Ohhh, so users will change this line voluntarily?

Are you worried with out of tree users?



[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