net/ena: fix setting host attributes
The hardware may reject adding host_info in case support for host_info is missing in the list of supported features. On the other hand the list of supported features may contain support for the host_info - typical bootstrap problem. This patch solves it by removing check against support for host_info attribute and improves error handling by reacting only to host attribute write failure to the hardware. Fixes: 99ecfbf845b3 ("ena: import communication layer") Cc: stable@dpdk.org Signed-off-by: Jakub Palider <jpa@semihalf.com>
This commit is contained in:
parent
478aed44d5
commit
201ff2e57a
@ -2590,19 +2590,11 @@ int ena_com_set_host_attributes(struct ena_com_dev *ena_dev)
|
||||
struct ena_com_admin_queue *admin_queue;
|
||||
struct ena_admin_set_feat_cmd cmd;
|
||||
struct ena_admin_set_feat_resp resp;
|
||||
int ret;
|
||||
|
||||
int ret = 0;
|
||||
|
||||
if (unlikely(!ena_dev)) {
|
||||
ena_trc_err("%s : ena_dev is NULL\n", __func__);
|
||||
return ENA_COM_NO_DEVICE;
|
||||
}
|
||||
|
||||
if (!ena_com_check_supported_feature_id(ena_dev,
|
||||
ENA_ADMIN_HOST_ATTR_CONFIG)) {
|
||||
ena_trc_warn("Set host attribute isn't supported\n");
|
||||
return ENA_COM_PERMISSION;
|
||||
}
|
||||
/* Host attribute config is called before ena_com_get_dev_attr_feat
|
||||
* so ena_com can't check if the feature is supported.
|
||||
*/
|
||||
|
||||
memset(&cmd, 0x0, sizeof(cmd));
|
||||
admin_queue = &ena_dev->admin_queue;
|
||||
|
@ -368,12 +368,9 @@ static void ena_config_host_info(struct ena_com_dev *ena_dev)
|
||||
|
||||
rc = ena_com_set_host_attributes(ena_dev);
|
||||
if (rc) {
|
||||
if (rc == -EPERM)
|
||||
RTE_LOG(ERR, PMD, "Cannot set host attributes\n");
|
||||
else
|
||||
RTE_LOG(ERR, PMD, "Cannot set host attributes\n");
|
||||
|
||||
goto err;
|
||||
RTE_LOG(ERR, PMD, "Cannot set host attributes\n");
|
||||
if (rc != -EPERM)
|
||||
goto err;
|
||||
}
|
||||
|
||||
return;
|
||||
@ -424,11 +421,9 @@ static void ena_config_debug_area(struct ena_adapter *adapter)
|
||||
|
||||
rc = ena_com_set_host_attributes(&adapter->ena_dev);
|
||||
if (rc) {
|
||||
if (rc == -EPERM)
|
||||
RTE_LOG(WARNING, PMD, "Cannot set host attributes\n");
|
||||
else
|
||||
RTE_LOG(ERR, PMD, "Cannot set host attributes\n");
|
||||
goto err;
|
||||
RTE_LOG(WARNING, PMD, "Cannot set host attributes\n");
|
||||
if (rc != -EPERM)
|
||||
goto err;
|
||||
}
|
||||
|
||||
return;
|
||||
@ -1239,14 +1234,14 @@ static int ena_device_init(struct ena_com_dev *ena_dev,
|
||||
goto err_mmio_read_less;
|
||||
}
|
||||
|
||||
ena_config_host_info(ena_dev);
|
||||
|
||||
/* To enable the msix interrupts the driver needs to know the number
|
||||
* of queues. So the driver uses polling mode to retrieve this
|
||||
* information.
|
||||
*/
|
||||
ena_com_set_admin_polling_mode(ena_dev, true);
|
||||
|
||||
ena_config_host_info(ena_dev);
|
||||
|
||||
/* Get Device Attributes and features */
|
||||
rc = ena_com_get_dev_attr_feat(ena_dev, get_feat_ctx);
|
||||
if (rc) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user