All of lore.kernel.org
 help / color / mirror / Atom feed
From: Dario Binacchi <dario.binacchi@amarulasolutions.com>
To: Marc Kleine-Budde <mkl@pengutronix.de>
Cc: linux-kernel@vger.kernel.org, michael@amarulasolutions.com,
	Amarula patchwork <linux-amarula@amarulasolutions.com>,
	Oliver Hartkopp <socketcan@hartkopp.net>,
	"David S. Miller" <davem@davemloft.net>,
	Eric Dumazet <edumazet@google.com>,
	Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
	Jakub Kicinski <kuba@kernel.org>,
	Jiri Slaby <jirislaby@kernel.org>,
	Paolo Abeni <pabeni@redhat.com>,
	Sebastian Andrzej Siewior <bigeasy@linutronix.de>,
	Vincent Mailhol <mailhol.vincent@wanadoo.fr>,
	Wolfgang Grandegger <wg@grandegger.com>,
	linux-can@vger.kernel.org, netdev@vger.kernel.org
Subject: Re: [PATCH v3 12/13] can: slcan: extend the protocol with error info
Date: Mon, 13 Jun 2022 23:04:38 +0200	[thread overview]
Message-ID: <CABGWkvrq6+N0rUaAmw_dJjJQAwMFv3-xK=LtTb-CSfTYFTs7QQ@mail.gmail.com> (raw)
In-Reply-To: <20220613073208.anak24kpffnngube@pengutronix.de>

On Mon, Jun 13, 2022 at 9:32 AM Marc Kleine-Budde <mkl@pengutronix.de> wrote:
>
> On 12.06.2022 23:39:26, Dario Binacchi wrote:
> > It extends the protocol to receive the adapter CAN communication errors
> > and forward them to the netdev upper levels.
> >
> > Signed-off-by: Dario Binacchi <dario.binacchi@amarulasolutions.com>
> >
> > ---
> >
> > (no changes since v2)
> >
> > Changes in v2:
> > - Protect decoding against the case the len value is longer than the
> >   received data.
>
> Where is that check?

I added the default case in the switch statement. Each line that is
processed by slc_bump_err()
is terminated by a '\r' or '\a' character. If len value is longer than
the received characters, it will
enter the default case for the eol character and the function will return.
But I realize now that I am wrong, the terminator is not placed in the
buffer passed to slc_bump_err() !!!!!! :)
I will add the right check in v4.

Thanks and regards,
Dario

>
> > - Continue error handling even if no skb can be allocated.
> >
> >  drivers/net/can/slcan/slcan-core.c | 130 ++++++++++++++++++++++++++++-
> >  1 file changed, 129 insertions(+), 1 deletion(-)
> >
> > diff --git a/drivers/net/can/slcan/slcan-core.c b/drivers/net/can/slcan/slcan-core.c
> > index 3df35ae8f040..48077edb9497 100644
> > --- a/drivers/net/can/slcan/slcan-core.c
> > +++ b/drivers/net/can/slcan/slcan-core.c
> > @@ -175,8 +175,118 @@ int slcan_enable_err_rst_on_open(struct net_device *ndev, bool on)
> >    *                  STANDARD SLCAN DECAPSULATION                     *
> >    ************************************************************************/
> >
> > +static void slc_bump_err(struct slcan *sl)
> > +{
> > +     struct net_device *dev = sl->dev;
> > +     struct sk_buff *skb;
> > +     struct can_frame *cf;
> > +     char *cmd = sl->rbuff;
> > +     bool rx_errors = false, tx_errors = false;
> > +     int i, len;
> > +
> > +     if (*cmd != 'e')
> > +             return;
>
> This has already been checked in the caller, right?
>
> > +
> > +     cmd += SLC_CMD_LEN;
> > +     /* get len from sanitized ASCII value */
> > +     len = *cmd++;
> > +     if (len >= '0' && len < '9')
> > +             len -= '0';
> > +     else
> > +             return;
> > +
> > +     skb = alloc_can_err_skb(dev, &cf);
> > +
> > +     if (skb)
> > +             cf->can_id |= CAN_ERR_PROT | CAN_ERR_BUSERROR;
> > +
> > +     for (i = 0; i < len; i++, cmd++) {
> > +             switch (*cmd) {
> > +             case 'a':
> > +                     netdev_dbg(dev, "ACK error\n");
> > +                     tx_errors = true;
>
> Nitpick:
> Please decide if you want to set tx/tx_errors here and increment at the
> end of the function....or.....
>
> > +                     if (skb) {
> > +                             cf->can_id |= CAN_ERR_ACK;
> > +                             cf->data[3] = CAN_ERR_PROT_LOC_ACK;
> > +                     }
> > +
> > +                     break;
> > +             case 'b':
> > +                     netdev_dbg(dev, "Bit0 error\n");
> > +                     tx_errors = true;
> > +                     if (skb)
> > +                             cf->data[2] |= CAN_ERR_PROT_BIT0;
> > +
> > +                     break;
> > +             case 'B':
> > +                     netdev_dbg(dev, "Bit1 error\n");
> > +                     tx_errors = true;
> > +                     if (skb)
> > +                             cf->data[2] |= CAN_ERR_PROT_BIT1;
> > +
> > +                     break;
> > +             case 'c':
> > +                     netdev_dbg(dev, "CRC error\n");
> > +                     rx_errors = true;
> > +                     if (skb) {
> > +                             cf->data[2] |= CAN_ERR_PROT_BIT;
> > +                             cf->data[3] = CAN_ERR_PROT_LOC_CRC_SEQ;
> > +                     }
> > +
> > +                     break;
> > +             case 'f':
> > +                     netdev_dbg(dev, "Form Error\n");
> > +                     rx_errors = true;
> > +                     if (skb)
> > +                             cf->data[2] |= CAN_ERR_PROT_FORM;
> > +
> > +                     break;
> > +             case 'o':
> > +                     netdev_dbg(dev, "Rx overrun error\n");
> > +                     dev->stats.rx_over_errors++;
> > +                     dev->stats.rx_errors++;
>
> ....if you want to increment in the case.
>
> > +                     if (skb) {
> > +                             cf->can_id |= CAN_ERR_CRTL;
> > +                             cf->data[1] = CAN_ERR_CRTL_RX_OVERFLOW;
> > +                     }
> > +
> > +                     break;
> > +             case 'O':
> > +                     netdev_dbg(dev, "Tx overrun error\n");
> > +                     dev->stats.tx_errors++;
> > +                     if (skb) {
> > +                             cf->can_id |= CAN_ERR_CRTL;
> > +                             cf->data[1] = CAN_ERR_CRTL_TX_OVERFLOW;
> > +                     }
> > +
> > +                     break;
> > +             case 's':
> > +                     netdev_dbg(dev, "Stuff error\n");
> > +                     rx_errors = true;
> > +                     if (skb)
> > +                             cf->data[2] |= CAN_ERR_PROT_STUFF;
> > +
> > +                     break;
> > +             default:
> > +                     if (skb)
> > +                             dev_kfree_skb(skb);
> > +
> > +                     return;
> > +             }
> > +     }
> > +
> > +     if (rx_errors)
> > +             dev->stats.rx_errors++;
> > +
> > +     if (tx_errors)
> > +             dev->stats.tx_errors++;
> > +
> > +     if (skb)
> > +             netif_rx(skb);
> > +}
> > +
> >  /* Send one completely decapsulated can_frame to the network layer */
> > -static void slc_bump(struct slcan *sl)
> > +static void slc_bump_frame(struct slcan *sl)
> >  {
> >       struct sk_buff *skb;
> >       struct can_frame *cf;
> > @@ -255,6 +365,24 @@ static void slc_bump(struct slcan *sl)
> >       dev_kfree_skb(skb);
> >  }
> >
> > +static void slc_bump(struct slcan *sl)
> > +{
> > +     switch (sl->rbuff[0]) {
> > +     case 'r':
> > +             fallthrough;
> > +     case 't':
> > +             fallthrough;
> > +     case 'R':
> > +             fallthrough;
> > +     case 'T':
> > +             return slc_bump_frame(sl);
> > +     case 'e':
> > +             return slc_bump_err(sl);
> > +     default:
> > +             return;
> > +     }
> > +}
> > +
> >  /* parse tty input stream */
> >  static void slcan_unesc(struct slcan *sl, unsigned char s)
> >  {
> > --
> > 2.32.0
> >
> >
>
> Marc
>
> --
> Pengutronix e.K.                 | Marc Kleine-Budde           |
> Embedded Linux                   | https://www.pengutronix.de  |
> Vertretung West/Dortmund         | Phone: +49-231-2826-924     |
> Amtsgericht Hildesheim, HRA 2686 | Fax:   +49-5121-206917-5555 |



-- 

Dario Binacchi

Embedded Linux Developer

dario.binacchi@amarulasolutions.com

__________________________________


Amarula Solutions SRL

Via Le Canevare 30, 31100 Treviso, Veneto, IT

T. +39 042 243 5310
info@amarulasolutions.com

www.amarulasolutions.com

  reply	other threads:[~2022-06-13 21:21 UTC|newest]

Thread overview: 25+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-06-12 21:39 [PATCH v3 00/13] can: slcan: extend supported features Dario Binacchi
2022-06-12 21:39 ` [PATCH v3 01/13] can: slcan: use the BIT() helper Dario Binacchi
2022-06-12 21:39 ` [PATCH v3 02/13] can: slcan: use netdev helpers to print out messages Dario Binacchi
2022-06-12 21:39 ` [PATCH v3 03/13] can: slcan: use the alloc_can_skb() helper Dario Binacchi
2022-06-12 21:39 ` [PATCH v3 04/13] can: slcan: use CAN network device driver API Dario Binacchi
2022-06-13  7:01   ` Marc Kleine-Budde
2022-06-12 21:39 ` [PATCH v3 05/13] can: netlink: dump bitrate 0 if can_priv::bittiming.bitrate is -1U Dario Binacchi
2022-06-13  7:10   ` Marc Kleine-Budde
2022-06-13 20:44     ` Dario Binacchi
2022-06-14  7:24       ` Marc Kleine-Budde
2022-06-12 21:39 ` [PATCH v3 06/13] can: slcan: allow to send commands to the adapter Dario Binacchi
2022-06-12 21:39 ` [PATCH v3 07/13] can: slcan: set bitrate by CAN device driver API Dario Binacchi
2022-06-13  7:17   ` Marc Kleine-Budde
2022-06-12 21:39 ` [PATCH v3 08/13] can: slcan: send the open command to the adapter Dario Binacchi
2022-06-12 21:39 ` [PATCH v3 09/13] can: slcan: send the close " Dario Binacchi
2022-06-13  7:22   ` Marc Kleine-Budde
2022-06-12 21:39 ` [PATCH v3 10/13] can: slcan: move driver into separate sub directory Dario Binacchi
2022-06-12 21:39 ` [PATCH v3 11/13] can: slcan: add ethtool support to reset adapter errors Dario Binacchi
2022-06-12 21:39 ` [PATCH v3 12/13] can: slcan: extend the protocol with error info Dario Binacchi
2022-06-13  7:32   ` Marc Kleine-Budde
2022-06-13 21:04     ` Dario Binacchi [this message]
2022-06-12 21:39 ` [PATCH v3 13/13] can: slcan: extend the protocol with CAN state info Dario Binacchi
2022-06-13  7:37   ` Marc Kleine-Budde
2022-06-14  6:29     ` Dario Binacchi
2022-06-14  7:22       ` Marc Kleine-Budde

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to='CABGWkvrq6+N0rUaAmw_dJjJQAwMFv3-xK=LtTb-CSfTYFTs7QQ@mail.gmail.com' \
    --to=dario.binacchi@amarulasolutions.com \
    --cc=bigeasy@linutronix.de \
    --cc=davem@davemloft.net \
    --cc=edumazet@google.com \
    --cc=gregkh@linuxfoundation.org \
    --cc=jirislaby@kernel.org \
    --cc=kuba@kernel.org \
    --cc=linux-amarula@amarulasolutions.com \
    --cc=linux-can@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=mailhol.vincent@wanadoo.fr \
    --cc=michael@amarulasolutions.com \
    --cc=mkl@pengutronix.de \
    --cc=netdev@vger.kernel.org \
    --cc=pabeni@redhat.com \
    --cc=socketcan@hartkopp.net \
    --cc=wg@grandegger.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.