int (*get_info)(struct hnae_handle *handle,
                        u8 *auto_neg, u16 *speed, u8 *duplex);
        void (*toggle_ring_irq)(struct hnae_ring *ring, u32 val);
-       void (*toggle_queue_status)(struct hnae_queue *queue, u32 val);
        void (*adjust_link)(struct hnae_handle *handle, int speed, int duplex);
        int (*set_loopback)(struct hnae_handle *handle,
                            enum hnae_loop loop_mode, int en);
 
 static int hns_ae_start(struct hnae_handle *handle)
 {
        int ret;
+       int k;
        struct hns_mac_cb *mac_cb = hns_get_mac_cb(handle);
 
        ret = hns_mac_vm_config_bc_en(mac_cb, 0, true);
        if (ret)
                return ret;
 
+       for (k = 0; k < handle->q_num; k++) {
+               if (AE_IS_VER1(mac_cb->dsaf_dev->dsaf_ver))
+                       hns_rcb_int_clr_hw(handle->qs[k],
+                                          RCB_INT_FLAG_TX | RCB_INT_FLAG_RX);
+               else
+                       hns_rcbv2_int_clr_hw(handle->qs[k],
+                                            RCB_INT_FLAG_TX | RCB_INT_FLAG_RX);
+       }
        hns_ae_ring_enable_all(handle, 1);
        msleep(100);
 
        hns_rcbv2_int_ctrl_hw(ring->q, flag, mask);
 }
 
-static void hns_ae_toggle_queue_status(struct hnae_queue *queue, u32 val)
-{
-       struct dsaf_device *dsaf_dev = hns_ae_get_dsaf_dev(queue->dev);
-
-       if (AE_IS_VER1(dsaf_dev->dsaf_ver))
-               hns_rcb_int_clr_hw(queue, RCB_INT_FLAG_TX | RCB_INT_FLAG_RX);
-       else
-               hns_rcbv2_int_clr_hw(queue, RCB_INT_FLAG_TX | RCB_INT_FLAG_RX);
-
-       hns_rcb_start(queue, val);
-}
-
 static int hns_ae_get_link_status(struct hnae_handle *handle)
 {
        u32 link_status;
        .stop = hns_ae_stop,
        .reset = hns_ae_reset,
        .toggle_ring_irq = hns_ae_toggle_ring_irq,
-       .toggle_queue_status = hns_ae_toggle_queue_status,
        .get_status = hns_ae_get_link_status,
        .get_info = hns_ae_get_mac_info,
        .adjust_link = hns_ae_adjust_link,
 
 {
        struct hns_nic_priv *priv = netdev_priv(ndev);
        struct hnae_handle *h = priv->ae_handle;
-       int i, j, k;
+       int i, j;
        int ret;
 
        ret = hns_nic_init_irq(priv);
                        goto out_has_some_queues;
        }
 
-       for (k = 0; k < h->q_num; k++)
-               h->dev->ops->toggle_queue_status(h->qs[k], 1);
-
        ret = h->dev->ops->set_mac_addr(h, ndev->dev_addr);
        if (ret)
                goto out_set_mac_addr_err;
 out_start_err:
        netif_stop_queue(ndev);
 out_set_mac_addr_err:
-       for (k = 0; k < h->q_num; k++)
-               h->dev->ops->toggle_queue_status(h->qs[k], 0);
 out_has_some_queues:
        for (j = i - 1; j >= 0; j--)
                hns_nic_ring_close(ndev, j);