net/hns3: fix Rx with PTP
The Rx and Tx vector algorithm of hns3 PMD don't support PTP
function. Currently, hns3 driver uses 'pf->ptp_enable' to check
whether PTP is enabled so as to not select Rx and Tx vector
algorithm. And the variable is set when call rte_eth_timesync_enable().
Namely, it may not be set before selecting Rx/Tx function, let's say
the case: set PTP offload in dev_configure(), do dev_start() and then
call rte_eth_timesync_enable(). In this case, all PTP packets can not
be received to application. So this patch fixes the check based on the
RTE_ETH_RX_OFFLOAD_TIMESTAMP flag.
Fixes: 3ca3dcd651
("net/hns3: fix vector Rx/Tx when PTP enabled")
Cc: stable@dpdk.org
Signed-off-by: Huisong Li <lihuisong@huawei.com>
Signed-off-by: Dongdong Liu <liudongdong3@huawei.com>
This commit is contained in:
parent
58e3daad9d
commit
4ac14c1d96
@ -125,7 +125,6 @@ hns3_timesync_enable(struct rte_eth_dev *dev)
|
||||
|
||||
if (pf->ptp_enable)
|
||||
return 0;
|
||||
hns3_warn(hw, "note: please ensure Rx/Tx burst mode is simple or common when enabling PTP!");
|
||||
|
||||
rte_spinlock_lock(&hw->lock);
|
||||
ret = hns3_timesync_configure(hns, true);
|
||||
|
@ -17,15 +17,18 @@ int
|
||||
hns3_tx_check_vec_support(struct rte_eth_dev *dev)
|
||||
{
|
||||
struct rte_eth_txmode *txmode = &dev->data->dev_conf.txmode;
|
||||
struct hns3_adapter *hns = dev->data->dev_private;
|
||||
struct hns3_pf *pf = &hns->pf;
|
||||
struct rte_eth_rxmode *rxmode = &dev->data->dev_conf.rxmode;
|
||||
|
||||
/* Only support RTE_ETH_TX_OFFLOAD_MBUF_FAST_FREE */
|
||||
if (txmode->offloads != RTE_ETH_TX_OFFLOAD_MBUF_FAST_FREE)
|
||||
return -ENOTSUP;
|
||||
|
||||
/* Vec is not supported when PTP enabled */
|
||||
if (pf->ptp_enable)
|
||||
/*
|
||||
* PTP function requires the cooperation of Rx and Tx.
|
||||
* Tx vector isn't supported if RTE_ETH_RX_OFFLOAD_TIMESTAMP is set
|
||||
* in Rx offloads.
|
||||
*/
|
||||
if (rxmode->offloads & RTE_ETH_RX_OFFLOAD_TIMESTAMP)
|
||||
return -ENOTSUP;
|
||||
|
||||
return 0;
|
||||
@ -232,9 +235,8 @@ hns3_rx_check_vec_support(struct rte_eth_dev *dev)
|
||||
{
|
||||
struct rte_eth_rxmode *rxmode = &dev->data->dev_conf.rxmode;
|
||||
uint64_t offloads_mask = RTE_ETH_RX_OFFLOAD_TCP_LRO |
|
||||
RTE_ETH_RX_OFFLOAD_VLAN;
|
||||
struct hns3_adapter *hns = dev->data->dev_private;
|
||||
struct hns3_pf *pf = &hns->pf;
|
||||
RTE_ETH_RX_OFFLOAD_VLAN |
|
||||
RTE_ETH_RX_OFFLOAD_TIMESTAMP;
|
||||
|
||||
if (dev->data->scattered_rx)
|
||||
return -ENOTSUP;
|
||||
@ -245,9 +247,5 @@ hns3_rx_check_vec_support(struct rte_eth_dev *dev)
|
||||
if (hns3_rxq_iterate(dev, hns3_rxq_vec_check, NULL) != 0)
|
||||
return -ENOTSUP;
|
||||
|
||||
/* Vec is not supported when PTP enabled */
|
||||
if (pf->ptp_enable)
|
||||
return -ENOTSUP;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user