Hi Oliver,
Thanks for the review comments.
> On 03/03/2016 04:38 PM, Ramesh Shanmugasundaram wrote:
>
> > Changes since v1:
> > * Removed testmodes & debugfs code (suggested by Oliver H)
> > * Fixed tx path race issue by introducing lock (suggested by Marc K)
> > * Removed __maybe_unused attribute of rcar_canfd_of_table
> >
>
>
> > obj-$(CONFIG_CAN_M_CAN) += m_can/
> > obj-$(CONFIG_CAN_RCAR) += rcar_can.o
> > +obj-$(CONFIG_CANFD_RCAR) += rcar_canfd.o
>
> Just for the sake of an ordered directory structure:
>
> Would it make sense to create a rcar directory where rcar_can.c and
> rcar_canfd.c are placed?
>
Yes. I'll place them in rcar dir.
> Additionally (besides of one accident with the obsolete PCH_CAN) all CAN
> drivers start with CONFIG_CAN_...
>
> Following that scheme the config option should be named
>
> CONFIG_CAN_RCAR_CANFD
>
> as we had in CONFIG_CAN_IFI_CANFD.
Agreed.
>
> > obj-$(CONFIG_CAN_SJA1000) += sja1000/
> > obj-$(CONFIG_CAN_SUN4I) += sun4i_can.o
> > obj-$(CONFIG_CAN_TI_HECC) += ti_hecc.o
> > diff --git a/drivers/net/can/rcar_canfd.c
> > b/drivers/net/can/rcar_canfd.c
>
> (..)
>
> > +/* Channel priv data */
> > +struct rcar_canfd_channel {
> > + struct can_priv can; /* Must be the first member */
> > + struct net_device *ndev;
> > + struct rcar_canfd_global *gpriv; /* Controller reference */
> > + void __iomem *base; /* Register base address */
> > +#ifdef CONFIG_DEBUG_FS
> > + struct dentry *dev_root;
> > +#endif /* CONFIG_DEBUG_FS */
>
> Some missed stuff from debugfs removal?
:-(. Sorry. Will clean up.
>
> > + struct napi_struct napi;
> > + u8 tx_len[RCANFD_FIFO_DEPTH]; /* For net stats */
> > + u32 tx_head; /* Incremented on xmit */
> > + u32 tx_tail; /* Incremented on xmit done */
> > + u32 channel; /* Channel number */
> > + spinlock_t tx_lock; /* To protect tx path */
> > +};
>
> (..)
>
> > +static int rcar_canfd_start(struct net_device *ndev) {
> > + struct rcar_canfd_channel *priv = netdev_priv(ndev);
> > + int err = -EOPNOTSUPP;
> > + u32 sts, ch = priv->channel;
> > + u32 ridx = ch + RCANFD_RFFIFO_IDX;
> > +
> > + /* Ensure channel starts in FD mode */
> > + if (!(priv->can.ctrlmode & CAN_CTRLMODE_FD)) {
> > + netdev_err(ndev, "enable can fd mode for channel %d\n", ch);
> > + goto fail_mode;
> > + }
>
> What's the reason behind this check?
>
> A CAN FD capable CAN controller can be either configured to run as CAN 2.0
> (Classic CAN) or as CAN FD controller.
>
> So why are to throwing an error here and produce an initialization
> failure?
When this controller is configured in FD mode and used only with CAN 2.0 nodes,
it still expects a DTSEG (data bitrate) configuration same as NTSEG (nominal
bitrate). This check, specifically in ndo_open, ensures both are configured and
will work fine with CAN 2.0 nodes (e.g.)
"ip link set can0 up type can bitrate 1000000 dbitrate 1000000 fd on"
If I don't have this check, a configuration like this
"ip link set can0 up type can bitrate 1000000"
will bring up the controller without DTSEG configured.
Thanks,
Ramesh