On 28/08/2025 13:10, Fan Gong wrote:
> As netif_queue_set_napi checks napi->dev, if it doesn't have it and
> it will warn_on and return. So we should use netif_napi_add before
> netif_queue_set_napi because netif_napi_add has "napi->dev = dev".
>
> Co-developed-by: Xin Guo <guoxin09@huawei.com>
> Signed-off-by: Xin Guo <guoxin09@huawei.com>
> Co-developed-by: Zhu Yikai <zhuyikai1@h-partners.com>
> Signed-off-by: Zhu Yikai <zhuyikai1@h-partners.com>
> Signed-off-by: Fan Gong <gongfan1@huawei.com>
> ---
> drivers/net/ethernet/huawei/hinic3/hinic3_irq.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/drivers/net/ethernet/huawei/hinic3/hinic3_irq.c b/drivers/net/ethernet/huawei/hinic3/hinic3_irq.c
> index 33eb9080739d..a69b361225e9 100644
> --- a/drivers/net/ethernet/huawei/hinic3/hinic3_irq.c
> +++ b/drivers/net/ethernet/huawei/hinic3/hinic3_irq.c
> @@ -42,11 +42,11 @@ static void qp_add_napi(struct hinic3_irq_cfg *irq_cfg)
> {
> struct hinic3_nic_dev *nic_dev = netdev_priv(irq_cfg->netdev);
>
> + netif_napi_add(nic_dev->netdev, &irq_cfg->napi, hinic3_poll);
> netif_queue_set_napi(irq_cfg->netdev, irq_cfg->irq_id,
> NETDEV_QUEUE_TYPE_RX, &irq_cfg->napi);
> netif_queue_set_napi(irq_cfg->netdev, irq_cfg->irq_id,
> NETDEV_QUEUE_TYPE_TX, &irq_cfg->napi);
> - netif_napi_add(nic_dev->netdev, &irq_cfg->napi, hinic3_poll);
> napi_enable(&irq_cfg->napi);
> }
>
Reviewed-by: Vadim Fedorenko <vadim.fedorenko@linux.dev>