mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-18 17:54:13 +08:00
sfc: Don't count RX checksum errors during loopback self-test
The loopback self-test checks that IP packets with incorrect checksums are not altered when sent on a queue with checksum generation off. These should not contribute to RX error statistics. Signed-off-by: Ben Hutchings <bhutchings@solarflare.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
740ced9927
commit
5005087728
@ -784,15 +784,18 @@ static void falcon_handle_rx_not_ok(struct efx_rx_queue *rx_queue,
|
||||
rx_ev_buf_owner_id_err | rx_ev_eth_crc_err |
|
||||
rx_ev_frm_trunc | rx_ev_ip_hdr_chksum_err);
|
||||
|
||||
/* Count errors that are not in MAC stats. */
|
||||
/* Count errors that are not in MAC stats. Ignore expected
|
||||
* checksum errors during self-test. */
|
||||
if (rx_ev_frm_trunc)
|
||||
++rx_queue->channel->n_rx_frm_trunc;
|
||||
else if (rx_ev_tobe_disc)
|
||||
++rx_queue->channel->n_rx_tobe_disc;
|
||||
else if (rx_ev_ip_hdr_chksum_err)
|
||||
++rx_queue->channel->n_rx_ip_hdr_chksum_err;
|
||||
else if (rx_ev_tcp_udp_chksum_err)
|
||||
++rx_queue->channel->n_rx_tcp_udp_chksum_err;
|
||||
else if (!efx->loopback_selftest) {
|
||||
if (rx_ev_ip_hdr_chksum_err)
|
||||
++rx_queue->channel->n_rx_ip_hdr_chksum_err;
|
||||
else if (rx_ev_tcp_udp_chksum_err)
|
||||
++rx_queue->channel->n_rx_tcp_udp_chksum_err;
|
||||
}
|
||||
if (rx_ev_ip_frag_err)
|
||||
++rx_queue->channel->n_rx_ip_frag_err;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user