int queue_num = priv->ae_handle->kinfo.num_tqps;
        struct hnae3_handle *handle = priv->ae_handle;
        struct hns3_enet_ring *ring;
+       u64 rx_length_errors = 0;
+       u64 rx_crc_errors = 0;
+       u64 rx_multicast = 0;
        unsigned int start;
+       u64 tx_errors = 0;
+       u64 rx_errors = 0;
        unsigned int idx;
        u64 tx_bytes = 0;
        u64 rx_bytes = 0;
                        tx_pkts += ring->stats.tx_pkts;
                        tx_drop += ring->stats.tx_busy;
                        tx_drop += ring->stats.sw_err_cnt;
+                       tx_errors += ring->stats.tx_busy;
+                       tx_errors += ring->stats.sw_err_cnt;
                } while (u64_stats_fetch_retry_irq(&ring->syncp, start));
 
                /* fetch the rx stats */
                        rx_drop += ring->stats.non_vld_descs;
                        rx_drop += ring->stats.err_pkt_len;
                        rx_drop += ring->stats.l2_err;
+                       rx_errors += ring->stats.non_vld_descs;
+                       rx_errors += ring->stats.l2_err;
+                       rx_crc_errors += ring->stats.l2_err;
+                       rx_crc_errors += ring->stats.l3l4_csum_err;
+                       rx_multicast += ring->stats.rx_multicast;
+                       rx_length_errors += ring->stats.err_pkt_len;
                } while (u64_stats_fetch_retry_irq(&ring->syncp, start));
        }
 
        stats->rx_bytes = rx_bytes;
        stats->rx_packets = rx_pkts;
 
-       stats->rx_errors = netdev->stats.rx_errors;
-       stats->multicast = netdev->stats.multicast;
-       stats->rx_length_errors = netdev->stats.rx_length_errors;
-       stats->rx_crc_errors = netdev->stats.rx_crc_errors;
+       stats->rx_errors = rx_errors;
+       stats->multicast = rx_multicast;
+       stats->rx_length_errors = rx_length_errors;
+       stats->rx_crc_errors = rx_crc_errors;
        stats->rx_missed_errors = netdev->stats.rx_missed_errors;
 
-       stats->tx_errors = netdev->stats.tx_errors;
-       stats->rx_dropped = rx_drop + netdev->stats.rx_dropped;
-       stats->tx_dropped = tx_drop + netdev->stats.tx_dropped;
+       stats->tx_errors = tx_errors;
+       stats->rx_dropped = rx_drop;
+       stats->tx_dropped = tx_drop;
        stats->collisions = netdev->stats.collisions;
        stats->rx_over_errors = netdev->stats.rx_over_errors;
        stats->rx_frame_errors = netdev->stats.rx_frame_errors;
 
        return (u8 *)buff;
 }
 
-static void hclge_update_netstat(struct hclge_hw_stats *hw_stats,
-                                struct net_device_stats *net_stats)
-{
-       net_stats->tx_dropped = 0;
-       net_stats->rx_errors = hw_stats->mac_stats.mac_rx_oversize_pkt_num;
-       net_stats->rx_errors += hw_stats->mac_stats.mac_rx_undersize_pkt_num;
-       net_stats->rx_errors += hw_stats->mac_stats.mac_rx_fcs_err_pkt_num;
-
-       net_stats->multicast = hw_stats->mac_stats.mac_tx_multi_pkt_num;
-       net_stats->multicast += hw_stats->mac_stats.mac_rx_multi_pkt_num;
-
-       net_stats->rx_crc_errors = hw_stats->mac_stats.mac_rx_fcs_err_pkt_num;
-       net_stats->rx_length_errors =
-               hw_stats->mac_stats.mac_rx_undersize_pkt_num;
-       net_stats->rx_length_errors +=
-               hw_stats->mac_stats.mac_rx_oversize_pkt_num;
-       net_stats->rx_over_errors =
-               hw_stats->mac_stats.mac_rx_oversize_pkt_num;
-}
-
 static void hclge_update_stats_for_all(struct hclge_dev *hdev)
 {
        struct hnae3_handle *handle;
        if (status)
                dev_err(&hdev->pdev->dev,
                        "Update MAC stats fail, status = %d.\n", status);
-
-       hclge_update_netstat(&hdev->hw_stats, &handle->kinfo.netdev->stats);
 }
 
 static void hclge_update_stats(struct hnae3_handle *handle,
 {
        struct hclge_vport *vport = hclge_get_vport(handle);
        struct hclge_dev *hdev = vport->back;
-       struct hclge_hw_stats *hw_stats = &hdev->hw_stats;
        int status;
 
        if (test_and_set_bit(HCLGE_STATE_STATISTICS_UPDATING, &hdev->state))
                        "Update TQPS stats fail, status = %d.\n",
                        status);
 
-       hclge_update_netstat(hw_stats, net_stats);
-
        clear_bit(HCLGE_STATE_STATISTICS_UPDATING, &hdev->state);
 }