Commit 676068db authored by Vincent Mailhol's avatar Vincent Mailhol Committed by Marc Kleine-Budde

can: do not increase rx statistics when generating a CAN rx error message frame

The CAN error message frames (i.e. error skb) are an interface
specific to socket CAN. The payload of the CAN error message frames
does not correspond to any actual data sent on the wire. Only an error
flag and a delimiter are transmitted when an error occurs (c.f. ISO
11898-1 section 10.4.4.2 "Error flag").

For this reason, it makes no sense to increment the rx_packets and
rx_bytes fields of struct net_device_stats because no actual payload
were transmitted on the wire.

This patch fixes all the CAN drivers.

Link: https://lore.kernel.org/all/20211207121531.42941-2-mailhol.vincent@wanadoo.fr
CC: Marc Kleine-Budde <mkl@pengutronix.de>
CC: Nicolas Ferre <nicolas.ferre@microchip.com>
CC: Alexandre Belloni <alexandre.belloni@bootlin.com>
CC: Ludovic Desroches <ludovic.desroches@microchip.com>
CC: Chandrasekar Ramakrishnan <rcsekar@samsung.com>
CC: Maxime Ripard <mripard@kernel.org>
CC: Chen-Yu Tsai <wens@csie.org>
CC: Jernej Skrabec <jernej.skrabec@gmail.com>
CC: Appana Durga Kedareswara rao <appana.durga.rao@xilinx.com>
CC: Naga Sureshkumar Relli <naga.sureshkumar.relli@xilinx.com>
CC: Michal Simek <michal.simek@xilinx.com>
CC: Stephane Grosjean <s.grosjean@peak-system.com>
Tested-by: Jimmy Assarsson <extja@kvaser.com> # kvaser
Signed-off-by: default avatarVincent Mailhol <mailhol.vincent@wanadoo.fr>
Acked-by: Stefan Mätje <stefan.maetje@esd.eu> # esd_usb2
Tested-by: Stefan Mätje <stefan.maetje@esd.eu> # esd_usb2
Signed-off-by: default avatarMarc Kleine-Budde <mkl@pengutronix.de>
parent e233640c
...@@ -553,8 +553,6 @@ static void at91_rx_overflow_err(struct net_device *dev) ...@@ -553,8 +553,6 @@ static void at91_rx_overflow_err(struct net_device *dev)
cf->can_id |= CAN_ERR_CRTL; cf->can_id |= CAN_ERR_CRTL;
cf->data[1] = CAN_ERR_CRTL_RX_OVERFLOW; cf->data[1] = CAN_ERR_CRTL_RX_OVERFLOW;
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_receive_skb(skb); netif_receive_skb(skb);
} }
...@@ -779,8 +777,6 @@ static int at91_poll_err(struct net_device *dev, int quota, u32 reg_sr) ...@@ -779,8 +777,6 @@ static int at91_poll_err(struct net_device *dev, int quota, u32 reg_sr)
at91_poll_err_frame(dev, cf, reg_sr); at91_poll_err_frame(dev, cf, reg_sr);
dev->stats.rx_packets++;
dev->stats.rx_bytes += cf->len;
netif_receive_skb(skb); netif_receive_skb(skb);
return 1; return 1;
...@@ -1037,8 +1033,6 @@ static void at91_irq_err(struct net_device *dev) ...@@ -1037,8 +1033,6 @@ static void at91_irq_err(struct net_device *dev)
at91_irq_err_state(dev, cf, new_state); at91_irq_err_state(dev, cf, new_state);
dev->stats.rx_packets++;
dev->stats.rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
priv->can.state = new_state; priv->can.state = new_state;
......
...@@ -920,7 +920,6 @@ static int c_can_handle_state_change(struct net_device *dev, ...@@ -920,7 +920,6 @@ static int c_can_handle_state_change(struct net_device *dev,
unsigned int reg_err_counter; unsigned int reg_err_counter;
unsigned int rx_err_passive; unsigned int rx_err_passive;
struct c_can_priv *priv = netdev_priv(dev); struct c_can_priv *priv = netdev_priv(dev);
struct net_device_stats *stats = &dev->stats;
struct can_frame *cf; struct can_frame *cf;
struct sk_buff *skb; struct sk_buff *skb;
struct can_berr_counter bec; struct can_berr_counter bec;
...@@ -996,8 +995,6 @@ static int c_can_handle_state_change(struct net_device *dev, ...@@ -996,8 +995,6 @@ static int c_can_handle_state_change(struct net_device *dev,
break; break;
} }
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_receive_skb(skb); netif_receive_skb(skb);
return 1; return 1;
...@@ -1064,8 +1061,6 @@ static int c_can_handle_bus_err(struct net_device *dev, ...@@ -1064,8 +1061,6 @@ static int c_can_handle_bus_err(struct net_device *dev,
break; break;
} }
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_receive_skb(skb); netif_receive_skb(skb);
return 1; return 1;
} }
......
...@@ -499,7 +499,6 @@ static void cc770_rx(struct net_device *dev, unsigned int mo, u8 ctrl1) ...@@ -499,7 +499,6 @@ static void cc770_rx(struct net_device *dev, unsigned int mo, u8 ctrl1)
static int cc770_err(struct net_device *dev, u8 status) static int cc770_err(struct net_device *dev, u8 status)
{ {
struct cc770_priv *priv = netdev_priv(dev); struct cc770_priv *priv = netdev_priv(dev);
struct net_device_stats *stats = &dev->stats;
struct can_frame *cf; struct can_frame *cf;
struct sk_buff *skb; struct sk_buff *skb;
u8 lec; u8 lec;
...@@ -571,8 +570,6 @@ static int cc770_err(struct net_device *dev, u8 status) ...@@ -571,8 +570,6 @@ static int cc770_err(struct net_device *dev, u8 status)
} }
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
return 0; return 0;
......
...@@ -136,7 +136,6 @@ EXPORT_SYMBOL_GPL(can_change_state); ...@@ -136,7 +136,6 @@ EXPORT_SYMBOL_GPL(can_change_state);
static void can_restart(struct net_device *dev) static void can_restart(struct net_device *dev)
{ {
struct can_priv *priv = netdev_priv(dev); struct can_priv *priv = netdev_priv(dev);
struct net_device_stats *stats = &dev->stats;
struct sk_buff *skb; struct sk_buff *skb;
struct can_frame *cf; struct can_frame *cf;
int err; int err;
...@@ -155,9 +154,6 @@ static void can_restart(struct net_device *dev) ...@@ -155,9 +154,6 @@ static void can_restart(struct net_device *dev)
cf->can_id |= CAN_ERR_RESTARTED; cf->can_id |= CAN_ERR_RESTARTED;
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx_ni(skb); netif_rx_ni(skb);
restart: restart:
......
...@@ -54,8 +54,10 @@ static int can_rx_offload_napi_poll(struct napi_struct *napi, int quota) ...@@ -54,8 +54,10 @@ static int can_rx_offload_napi_poll(struct napi_struct *napi, int quota)
struct can_frame *cf = (struct can_frame *)skb->data; struct can_frame *cf = (struct can_frame *)skb->data;
work_done++; work_done++;
stats->rx_packets++; if (!(cf->can_id & CAN_ERR_FLAG)) {
stats->rx_bytes += cf->len; stats->rx_packets++;
stats->rx_bytes += cf->len;
}
netif_receive_skb(skb); netif_receive_skb(skb);
} }
......
...@@ -430,8 +430,6 @@ static int ifi_canfd_handle_lec_err(struct net_device *ndev) ...@@ -430,8 +430,6 @@ static int ifi_canfd_handle_lec_err(struct net_device *ndev)
priv->base + IFI_CANFD_INTERRUPT); priv->base + IFI_CANFD_INTERRUPT);
writel(IFI_CANFD_ERROR_CTR_ER_ENABLE, priv->base + IFI_CANFD_ERROR_CTR); writel(IFI_CANFD_ERROR_CTR_ER_ENABLE, priv->base + IFI_CANFD_ERROR_CTR);
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_receive_skb(skb); netif_receive_skb(skb);
return 1; return 1;
...@@ -456,7 +454,6 @@ static int ifi_canfd_handle_state_change(struct net_device *ndev, ...@@ -456,7 +454,6 @@ static int ifi_canfd_handle_state_change(struct net_device *ndev,
enum can_state new_state) enum can_state new_state)
{ {
struct ifi_canfd_priv *priv = netdev_priv(ndev); struct ifi_canfd_priv *priv = netdev_priv(ndev);
struct net_device_stats *stats = &ndev->stats;
struct can_frame *cf; struct can_frame *cf;
struct sk_buff *skb; struct sk_buff *skb;
struct can_berr_counter bec; struct can_berr_counter bec;
...@@ -522,8 +519,6 @@ static int ifi_canfd_handle_state_change(struct net_device *ndev, ...@@ -522,8 +519,6 @@ static int ifi_canfd_handle_state_change(struct net_device *ndev,
break; break;
} }
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_receive_skb(skb); netif_receive_skb(skb);
return 1; return 1;
......
...@@ -1310,9 +1310,6 @@ static int kvaser_pciefd_rx_error_frame(struct kvaser_pciefd_can *can, ...@@ -1310,9 +1310,6 @@ static int kvaser_pciefd_rx_error_frame(struct kvaser_pciefd_can *can,
cf->data[6] = bec.txerr; cf->data[6] = bec.txerr;
cf->data[7] = bec.rxerr; cf->data[7] = bec.rxerr;
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
return 0; return 0;
} }
...@@ -1510,8 +1507,6 @@ static void kvaser_pciefd_handle_nack_packet(struct kvaser_pciefd_can *can, ...@@ -1510,8 +1507,6 @@ static void kvaser_pciefd_handle_nack_packet(struct kvaser_pciefd_can *can,
if (skb) { if (skb) {
cf->can_id |= CAN_ERR_BUSERROR; cf->can_id |= CAN_ERR_BUSERROR;
stats->rx_bytes += cf->len;
stats->rx_packets++;
netif_rx(skb); netif_rx(skb);
} else { } else {
stats->rx_dropped++; stats->rx_dropped++;
......
...@@ -647,9 +647,6 @@ static int m_can_handle_lec_err(struct net_device *dev, ...@@ -647,9 +647,6 @@ static int m_can_handle_lec_err(struct net_device *dev,
break; break;
} }
stats->rx_packets++;
stats->rx_bytes += cf->len;
if (cdev->is_peripheral) if (cdev->is_peripheral)
timestamp = m_can_get_timestamp(cdev); timestamp = m_can_get_timestamp(cdev);
...@@ -706,7 +703,6 @@ static int m_can_handle_state_change(struct net_device *dev, ...@@ -706,7 +703,6 @@ static int m_can_handle_state_change(struct net_device *dev,
enum can_state new_state) enum can_state new_state)
{ {
struct m_can_classdev *cdev = netdev_priv(dev); struct m_can_classdev *cdev = netdev_priv(dev);
struct net_device_stats *stats = &dev->stats;
struct can_frame *cf; struct can_frame *cf;
struct sk_buff *skb; struct sk_buff *skb;
struct can_berr_counter bec; struct can_berr_counter bec;
...@@ -771,9 +767,6 @@ static int m_can_handle_state_change(struct net_device *dev, ...@@ -771,9 +767,6 @@ static int m_can_handle_state_change(struct net_device *dev,
break; break;
} }
stats->rx_packets++;
stats->rx_bytes += cf->len;
if (cdev->is_peripheral) if (cdev->is_peripheral)
timestamp = m_can_get_timestamp(cdev); timestamp = m_can_get_timestamp(cdev);
......
...@@ -401,13 +401,14 @@ static int mscan_rx_poll(struct napi_struct *napi, int quota) ...@@ -401,13 +401,14 @@ static int mscan_rx_poll(struct napi_struct *napi, int quota)
continue; continue;
} }
if (canrflg & MSCAN_RXF) if (canrflg & MSCAN_RXF) {
mscan_get_rx_frame(dev, frame); mscan_get_rx_frame(dev, frame);
else if (canrflg & MSCAN_ERR_IF) stats->rx_packets++;
stats->rx_bytes += frame->len;
} else if (canrflg & MSCAN_ERR_IF) {
mscan_get_err_frame(dev, frame, canrflg); mscan_get_err_frame(dev, frame, canrflg);
}
stats->rx_packets++;
stats->rx_bytes += frame->len;
work_done++; work_done++;
netif_receive_skb(skb); netif_receive_skb(skb);
} }
......
...@@ -561,9 +561,6 @@ static void pch_can_error(struct net_device *ndev, u32 status) ...@@ -561,9 +561,6 @@ static void pch_can_error(struct net_device *ndev, u32 status)
priv->can.state = state; priv->can.state = state;
netif_receive_skb(skb); netif_receive_skb(skb);
stats->rx_packets++;
stats->rx_bytes += cf->len;
} }
static irqreturn_t pch_can_interrupt(int irq, void *dev_id) static irqreturn_t pch_can_interrupt(int irq, void *dev_id)
......
...@@ -409,8 +409,6 @@ static int pucan_handle_status(struct peak_canfd_priv *priv, ...@@ -409,8 +409,6 @@ static int pucan_handle_status(struct peak_canfd_priv *priv,
return -ENOMEM; return -ENOMEM;
} }
stats->rx_packets++;
stats->rx_bytes += cf->len;
pucan_netif_rx(skb, msg->ts_low, msg->ts_high); pucan_netif_rx(skb, msg->ts_low, msg->ts_high);
return 0; return 0;
...@@ -438,8 +436,6 @@ static int pucan_handle_cache_critical(struct peak_canfd_priv *priv) ...@@ -438,8 +436,6 @@ static int pucan_handle_cache_critical(struct peak_canfd_priv *priv)
cf->data[6] = priv->bec.txerr; cf->data[6] = priv->bec.txerr;
cf->data[7] = priv->bec.rxerr; cf->data[7] = priv->bec.rxerr;
stats->rx_bytes += cf->len;
stats->rx_packets++;
netif_rx(skb); netif_rx(skb);
return 0; return 0;
......
...@@ -223,7 +223,6 @@ static void tx_failure_cleanup(struct net_device *ndev) ...@@ -223,7 +223,6 @@ static void tx_failure_cleanup(struct net_device *ndev)
static void rcar_can_error(struct net_device *ndev) static void rcar_can_error(struct net_device *ndev)
{ {
struct rcar_can_priv *priv = netdev_priv(ndev); struct rcar_can_priv *priv = netdev_priv(ndev);
struct net_device_stats *stats = &ndev->stats;
struct can_frame *cf; struct can_frame *cf;
struct sk_buff *skb; struct sk_buff *skb;
u8 eifr, txerr = 0, rxerr = 0; u8 eifr, txerr = 0, rxerr = 0;
...@@ -362,11 +361,8 @@ static void rcar_can_error(struct net_device *ndev) ...@@ -362,11 +361,8 @@ static void rcar_can_error(struct net_device *ndev)
} }
} }
if (skb) { if (skb)
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
}
} }
static void rcar_can_tx_done(struct net_device *ndev) static void rcar_can_tx_done(struct net_device *ndev)
......
...@@ -1033,8 +1033,6 @@ static void rcar_canfd_error(struct net_device *ndev, u32 cerfl, ...@@ -1033,8 +1033,6 @@ static void rcar_canfd_error(struct net_device *ndev, u32 cerfl,
/* Clear channel error interrupts that are handled */ /* Clear channel error interrupts that are handled */
rcar_canfd_write(priv->base, RCANFD_CERFL(ch), rcar_canfd_write(priv->base, RCANFD_CERFL(ch),
RCANFD_CERFL_ERR(~cerfl)); RCANFD_CERFL_ERR(~cerfl));
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
} }
...@@ -1174,8 +1172,6 @@ static void rcar_canfd_state_change(struct net_device *ndev, ...@@ -1174,8 +1172,6 @@ static void rcar_canfd_state_change(struct net_device *ndev,
rx_state = txerr <= rxerr ? state : 0; rx_state = txerr <= rxerr ? state : 0;
can_change_state(ndev, cf, tx_state, rx_state); can_change_state(ndev, cf, tx_state, rx_state);
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
} }
} }
......
...@@ -487,8 +487,6 @@ static int sja1000_err(struct net_device *dev, uint8_t isrc, uint8_t status) ...@@ -487,8 +487,6 @@ static int sja1000_err(struct net_device *dev, uint8_t isrc, uint8_t status)
can_bus_off(dev); can_bus_off(dev);
} }
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
return 0; return 0;
......
...@@ -633,13 +633,10 @@ static int sun4i_can_err(struct net_device *dev, u8 isrc, u8 status) ...@@ -633,13 +633,10 @@ static int sun4i_can_err(struct net_device *dev, u8 isrc, u8 status)
can_bus_off(dev); can_bus_off(dev);
} }
if (likely(skb)) { if (likely(skb))
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
} else { else
return -ENOMEM; return -ENOMEM;
}
return 0; return 0;
} }
......
...@@ -397,8 +397,6 @@ static void ems_usb_rx_err(struct ems_usb *dev, struct ems_cpc_msg *msg) ...@@ -397,8 +397,6 @@ static void ems_usb_rx_err(struct ems_usb *dev, struct ems_cpc_msg *msg)
stats->rx_errors++; stats->rx_errors++;
} }
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
} }
......
...@@ -293,8 +293,6 @@ static void esd_usb2_rx_event(struct esd_usb2_net_priv *priv, ...@@ -293,8 +293,6 @@ static void esd_usb2_rx_event(struct esd_usb2_net_priv *priv,
priv->bec.txerr = txerr; priv->bec.txerr = txerr;
priv->bec.rxerr = rxerr; priv->bec.rxerr = rxerr;
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
} }
} }
......
...@@ -849,13 +849,6 @@ int es58x_rx_err_msg(struct net_device *netdev, enum es58x_err error, ...@@ -849,13 +849,6 @@ int es58x_rx_err_msg(struct net_device *netdev, enum es58x_err error,
break; break;
} }
/* driver/net/can/dev.c:can_restart() takes in account error
* messages in the RX stats. Doing the same here for
* consistency.
*/
netdev->stats.rx_packets++;
netdev->stats.rx_bytes += CAN_ERR_DLC;
if (cf) { if (cf) {
if (cf->data[1]) if (cf->data[1])
cf->can_id |= CAN_ERR_CRTL; cf->can_id |= CAN_ERR_CRTL;
......
...@@ -279,8 +279,6 @@ int kvaser_usb_can_rx_over_error(struct net_device *netdev) ...@@ -279,8 +279,6 @@ int kvaser_usb_can_rx_over_error(struct net_device *netdev)
cf->can_id |= CAN_ERR_CRTL; cf->can_id |= CAN_ERR_CRTL;
cf->data[1] = CAN_ERR_CRTL_RX_OVERFLOW; cf->data[1] = CAN_ERR_CRTL_RX_OVERFLOW;
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
return 0; return 0;
......
...@@ -870,7 +870,6 @@ static void kvaser_usb_hydra_update_state(struct kvaser_usb_net_priv *priv, ...@@ -870,7 +870,6 @@ static void kvaser_usb_hydra_update_state(struct kvaser_usb_net_priv *priv,
struct net_device *netdev = priv->netdev; struct net_device *netdev = priv->netdev;
struct can_frame *cf; struct can_frame *cf;
struct sk_buff *skb; struct sk_buff *skb;
struct net_device_stats *stats;
enum can_state new_state, old_state; enum can_state new_state, old_state;
old_state = priv->can.state; old_state = priv->can.state;
...@@ -920,9 +919,6 @@ static void kvaser_usb_hydra_update_state(struct kvaser_usb_net_priv *priv, ...@@ -920,9 +919,6 @@ static void kvaser_usb_hydra_update_state(struct kvaser_usb_net_priv *priv,
cf->data[6] = bec->txerr; cf->data[6] = bec->txerr;
cf->data[7] = bec->rxerr; cf->data[7] = bec->rxerr;
stats = &netdev->stats;
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
} }
...@@ -1075,8 +1071,6 @@ kvaser_usb_hydra_error_frame(struct kvaser_usb_net_priv *priv, ...@@ -1075,8 +1071,6 @@ kvaser_usb_hydra_error_frame(struct kvaser_usb_net_priv *priv,
cf->data[6] = bec.txerr; cf->data[6] = bec.txerr;
cf->data[7] = bec.rxerr; cf->data[7] = bec.rxerr;
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
priv->bec.txerr = bec.txerr; priv->bec.txerr = bec.txerr;
...@@ -1110,8 +1104,6 @@ static void kvaser_usb_hydra_one_shot_fail(struct kvaser_usb_net_priv *priv, ...@@ -1110,8 +1104,6 @@ static void kvaser_usb_hydra_one_shot_fail(struct kvaser_usb_net_priv *priv,
} }
stats->tx_errors++; stats->tx_errors++;
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
} }
......
...@@ -642,8 +642,6 @@ static void kvaser_usb_leaf_tx_acknowledge(const struct kvaser_usb *dev, ...@@ -642,8 +642,6 @@ static void kvaser_usb_leaf_tx_acknowledge(const struct kvaser_usb *dev,
if (skb) { if (skb) {
cf->can_id |= CAN_ERR_RESTARTED; cf->can_id |= CAN_ERR_RESTARTED;
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
} else { } else {
netdev_err(priv->netdev, netdev_err(priv->netdev,
...@@ -844,8 +842,6 @@ static void kvaser_usb_leaf_rx_error(const struct kvaser_usb *dev, ...@@ -844,8 +842,6 @@ static void kvaser_usb_leaf_rx_error(const struct kvaser_usb *dev,
cf->data[6] = es->txerr; cf->data[6] = es->txerr;
cf->data[7] = es->rxerr; cf->data[7] = es->rxerr;
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
} }
......
...@@ -521,8 +521,6 @@ static int pcan_usb_decode_error(struct pcan_usb_msg_context *mc, u8 n, ...@@ -521,8 +521,6 @@ static int pcan_usb_decode_error(struct pcan_usb_msg_context *mc, u8 n,
&hwts->hwtstamp); &hwts->hwtstamp);
} }
mc->netdev->stats.rx_packets++;
mc->netdev->stats.rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
return 0; return 0;
......
...@@ -577,9 +577,6 @@ static int pcan_usb_fd_decode_status(struct pcan_usb_fd_if *usb_if, ...@@ -577,9 +577,6 @@ static int pcan_usb_fd_decode_status(struct pcan_usb_fd_if *usb_if,
if (!skb) if (!skb)
return -ENOMEM; return -ENOMEM;
netdev->stats.rx_packets++;
netdev->stats.rx_bytes += cf->len;
peak_usb_netif_rx_64(skb, le32_to_cpu(sm->ts_low), peak_usb_netif_rx_64(skb, le32_to_cpu(sm->ts_low),
le32_to_cpu(sm->ts_high)); le32_to_cpu(sm->ts_high));
......
...@@ -660,8 +660,6 @@ static int pcan_usb_pro_handle_error(struct pcan_usb_pro_interface *usb_if, ...@@ -660,8 +660,6 @@ static int pcan_usb_pro_handle_error(struct pcan_usb_pro_interface *usb_if,
hwts = skb_hwtstamps(skb); hwts = skb_hwtstamps(skb);
peak_usb_get_ts_time(&usb_if->time_ref, le32_to_cpu(er->ts32), &hwts->hwtstamp); peak_usb_get_ts_time(&usb_if->time_ref, le32_to_cpu(er->ts32), &hwts->hwtstamp);
netdev->stats.rx_packets++;
netdev->stats.rx_bytes += can_frame->len;
netif_rx(skb); netif_rx(skb);
return 0; return 0;
......
...@@ -621,8 +621,10 @@ static void ucan_rx_can_msg(struct ucan_priv *up, struct ucan_message_in *m) ...@@ -621,8 +621,10 @@ static void ucan_rx_can_msg(struct ucan_priv *up, struct ucan_message_in *m)
memcpy(cf->data, m->msg.can_msg.data, cf->len); memcpy(cf->data, m->msg.can_msg.data, cf->len);
/* don't count error frames as real packets */ /* don't count error frames as real packets */
stats->rx_packets++; if (!(cf->can_id & CAN_ERR_FLAG)) {
stats->rx_bytes += cf->len; stats->rx_packets++;
stats->rx_bytes += cf->len;
}
/* pass it to Linux */ /* pass it to Linux */
netif_rx(skb); netif_rx(skb);
......
...@@ -447,8 +447,6 @@ static void usb_8dev_rx_err_msg(struct usb_8dev_priv *priv, ...@@ -447,8 +447,6 @@ static void usb_8dev_rx_err_msg(struct usb_8dev_priv *priv,
priv->bec.txerr = txerr; priv->bec.txerr = txerr;
priv->bec.rxerr = rxerr; priv->bec.rxerr = rxerr;
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
} }
......
...@@ -965,13 +965,8 @@ static void xcan_update_error_state_after_rxtx(struct net_device *ndev) ...@@ -965,13 +965,8 @@ static void xcan_update_error_state_after_rxtx(struct net_device *ndev)
xcan_set_error_state(ndev, new_state, skb ? cf : NULL); xcan_set_error_state(ndev, new_state, skb ? cf : NULL);
if (skb) { if (skb)
struct net_device_stats *stats = &ndev->stats;
stats->rx_packets++;
stats->rx_bytes += cf->len;
netif_rx(skb); netif_rx(skb);
}
} }
} }
...@@ -1095,8 +1090,6 @@ static void xcan_err_interrupt(struct net_device *ndev, u32 isr) ...@@ -1095,8 +1090,6 @@ static void xcan_err_interrupt(struct net_device *ndev, u32 isr)
if (skb) { if (skb) {
skb_cf->can_id |= cf.can_id; skb_cf->can_id |= cf.can_id;
memcpy(skb_cf->data, cf.data, CAN_ERR_DLC); memcpy(skb_cf->data, cf.data, CAN_ERR_DLC);
stats->rx_packets++;
stats->rx_bytes += CAN_ERR_DLC;
netif_rx(skb); netif_rx(skb);
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment