All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] Enabling rcar_can changelink support
@ 2017-04-29 19:48 ` Bogdan Mirea
  0 siblings, 0 replies; 6+ messages in thread
From: Bogdan Mirea @ 2017-04-29 19:48 UTC (permalink / raw)
  To: linux-can, linux-renesas-soc, mkl, socketcan; +Cc: Bogdan Mirea, Eugen Hristev

Added rcar_can_set_bittiming as can.do_set_bittiming callback that will
be called from can_changelink generic callback when link state is
changed.

This enables set bittiming support:
	ip link set can0 type can bitrate 500000 triple-sampling on

Signed-off-by: Bogdan Mirea <Bogdan-Stefan_mirea@mentor.com>
Signed-off-by: Eugen Hristev <Eugen_hristev@mentor.com>
---
 drivers/net/can/rcar_can.c | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)

diff --git a/drivers/net/can/rcar/rcar_can.c b/drivers/net/can/rcar/rcar_can.c
index 788459f..cfabb95 100644
--- a/drivers/net/can/rcar/rcar_can.c
+++ b/drivers/net/can/rcar/rcar_can.c
@@ -419,7 +419,7 @@ static irqreturn_t rcar_can_interrupt(int irq, void *dev_id)
 	return IRQ_HANDLED;
 }
 
-static void rcar_can_set_bittiming(struct net_device *dev)
+static int rcar_can_set_bittiming(struct net_device *dev)
 {
 	struct rcar_can_priv *priv = netdev_priv(dev);
 	struct can_bittiming *bt = &priv->can.bittiming;
@@ -433,6 +433,8 @@ static void rcar_can_set_bittiming(struct net_device *dev)
 	 * read/write (but not on 8-bit, contrary to the manuals)...
 	 */
 	writel((bcr << 8) | priv->clock_select, &priv->regs->bcr);
+
+	return 0;
 }
 
 static void rcar_can_start(struct net_device *ndev)
@@ -809,6 +811,7 @@ static int rcar_can_probe(struct platform_device *pdev)
 	priv->clock_select = clock_select;
 	priv->can.clock.freq = clk_get_rate(priv->can_clk);
 	priv->can.bittiming_const = &rcar_can_bittiming_const;
+	priv->can.do_set_bittiming = &rcar_can_set_bittiming;
 	priv->can.do_set_mode = rcar_can_do_set_mode;
 	priv->can.do_get_berr_counter = rcar_can_get_berr_counter;
 	priv->can.ctrlmode_supported = CAN_CTRLMODE_BERR_REPORTING;
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 6+ messages in thread

* [PATCH] Enabling rcar_can changelink support
@ 2017-04-29 19:48 ` Bogdan Mirea
  0 siblings, 0 replies; 6+ messages in thread
From: Bogdan Mirea @ 2017-04-29 19:48 UTC (permalink / raw)
  To: linux-can, linux-renesas-soc, mkl, socketcan; +Cc: Bogdan Mirea, Eugen Hristev

Added rcar_can_set_bittiming as can.do_set_bittiming callback that will
be called from can_changelink generic callback when link state is
changed.

This enables set bittiming support:
	ip link set can0 type can bitrate 500000 triple-sampling on

Signed-off-by: Bogdan Mirea <Bogdan-Stefan_mirea@mentor.com>
Signed-off-by: Eugen Hristev <Eugen_hristev@mentor.com>
---
 drivers/net/can/rcar_can.c | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)

diff --git a/drivers/net/can/rcar/rcar_can.c b/drivers/net/can/rcar/rcar_can.c
index 788459f..cfabb95 100644
--- a/drivers/net/can/rcar/rcar_can.c
+++ b/drivers/net/can/rcar/rcar_can.c
@@ -419,7 +419,7 @@ static irqreturn_t rcar_can_interrupt(int irq, void *dev_id)
 	return IRQ_HANDLED;
 }
 
-static void rcar_can_set_bittiming(struct net_device *dev)
+static int rcar_can_set_bittiming(struct net_device *dev)
 {
 	struct rcar_can_priv *priv = netdev_priv(dev);
 	struct can_bittiming *bt = &priv->can.bittiming;
@@ -433,6 +433,8 @@ static void rcar_can_set_bittiming(struct net_device *dev)
 	 * read/write (but not on 8-bit, contrary to the manuals)...
 	 */
 	writel((bcr << 8) | priv->clock_select, &priv->regs->bcr);
+
+	return 0;
 }
 
 static void rcar_can_start(struct net_device *ndev)
@@ -809,6 +811,7 @@ static int rcar_can_probe(struct platform_device *pdev)
 	priv->clock_select = clock_select;
 	priv->can.clock.freq = clk_get_rate(priv->can_clk);
 	priv->can.bittiming_const = &rcar_can_bittiming_const;
+	priv->can.do_set_bittiming = &rcar_can_set_bittiming;
 	priv->can.do_set_mode = rcar_can_do_set_mode;
 	priv->can.do_get_berr_counter = rcar_can_get_berr_counter;
 	priv->can.ctrlmode_supported = CAN_CTRLMODE_BERR_REPORTING;
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 6+ messages in thread

* Re: [PATCH] Enabling rcar_can changelink support
  2017-04-29 19:48 ` Bogdan Mirea
  (?)
@ 2017-04-29 21:26 ` Marc Kleine-Budde
  2017-04-30 11:33   ` Mirea, Bogdan-Stefan
  -1 siblings, 1 reply; 6+ messages in thread
From: Marc Kleine-Budde @ 2017-04-29 21:26 UTC (permalink / raw)
  To: Bogdan Mirea, linux-can, linux-renesas-soc, socketcan; +Cc: Eugen Hristev


[-- Attachment #1.1: Type: text/plain, Size: 676 bytes --]

On 04/29/2017 09:48 PM, Bogdan Mirea wrote:
> Added rcar_can_set_bittiming as can.do_set_bittiming callback that will
> be called from can_changelink generic callback when link state is
> changed.
> 
> This enables set bittiming support:
> 	ip link set can0 type can bitrate 500000 triple-sampling on

Why is this needed? rcar_can_set_bittiming() is called during
rcar_can_open().

Marc

-- 
Pengutronix e.K.                  | Marc Kleine-Budde           |
Industrial Linux Solutions        | Phone: +49-231-2826-924     |
Vertretung West/Dortmund          | Fax:   +49-5121-206917-5555 |
Amtsgericht Hildesheim, HRA 2686  | http://www.pengutronix.de   |


[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 488 bytes --]

^ permalink raw reply	[flat|nested] 6+ messages in thread

* RE: [PATCH] Enabling rcar_can changelink support
  2017-04-29 21:26 ` Marc Kleine-Budde
@ 2017-04-30 11:33   ` Mirea, Bogdan-Stefan
  2017-04-30 19:30     ` Marc Kleine-Budde
  0 siblings, 1 reply; 6+ messages in thread
From: Mirea, Bogdan-Stefan @ 2017-04-30 11:33 UTC (permalink / raw)
  To: Marc Kleine-Budde, linux-can, linux-renesas-soc, socketcan

Hello Marc,

> On 04/29/2017 09:48 PM, Bogdan Mirea wrote:
> > Added rcar_can_set_bittiming as can.do_set_bittiming callback that
> > will be called from can_changelink generic callback when link state
> > is 
> > changed.
> > 
> > This enables set bittiming support:
> >     ip link set can0 type can bitrate 500000 triple-sampling on
> 
> Why is this needed? rcar_can_set_bittiming() is called during
> rcar_can_open().

I know that rcar_can_set_bittiming() is called during rcar_can_open()
and setting bittiming works fine when setting can up with a command
like:
(1st approah)
    $ip link set can0 up type can bitrate 500000

But most of tutorials online[1] are presenting as a TODO the following
pair of commands:
(2nd approah)
    $ip link set can0 type can bitrate 500000
    $ip link set up can0

And in this 2nd approah, the first command will fail since it will call
can_changelink which on its turn will try calling .do_set_bittiming
callback and the former callback is not defined for rcar_can.

I don't say this is a must-have feature, since calling iproute2 with
"set bitrate" and "set can up"  as in 1st approach will work just fine,
will work just fine, but it is a nice to have feature for the second
approach of setting bitrate.
Also peak_usb pcan[2] uses this second approach (the changelink one) and
this patch updates rcar_can for it.

Best Regards,
Bogdan

[1] http://elinux.org/Bringing_CAN_interface_up
[2]
http://lxr.free-electrons.com/source/drivers/net/can/usb/peak_usb/pcan_usb.c#L900

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [PATCH] Enabling rcar_can changelink support
  2017-04-30 11:33   ` Mirea, Bogdan-Stefan
@ 2017-04-30 19:30     ` Marc Kleine-Budde
  2017-05-02 10:09       ` Mirea, Bogdan-Stefan
  0 siblings, 1 reply; 6+ messages in thread
From: Marc Kleine-Budde @ 2017-04-30 19:30 UTC (permalink / raw)
  To: Mirea, Bogdan-Stefan, linux-can, linux-renesas-soc, socketcan


[-- Attachment #1.1: Type: text/plain, Size: 2728 bytes --]

On 04/30/2017 01:33 PM, Mirea, Bogdan-Stefan wrote:
> Hello Marc,
> 
>> On 04/29/2017 09:48 PM, Bogdan Mirea wrote:
>>> Added rcar_can_set_bittiming as can.do_set_bittiming callback that
>>> will be called from can_changelink generic callback when link state
>>> is 
>>> changed.
>>>
>>> This enables set bittiming support:
>>>     ip link set can0 type can bitrate 500000 triple-sampling on
>>
>> Why is this needed? rcar_can_set_bittiming() is called during
>> rcar_can_open().
> 
> I know that rcar_can_set_bittiming() is called during rcar_can_open()
> and setting bittiming works fine when setting can up with a command
> like:
> (1st approah)
>     $ip link set can0 up type can bitrate 500000
> 
> But most of tutorials online[1] are presenting as a TODO the following
> pair of commands:
> (2nd approah)
>     $ip link set can0 type can bitrate 500000
>     $ip link set up can0
> 
> And in this 2nd approah, the first command will fail since it will call
> can_changelink which on its turn will try calling .do_set_bittiming
> callback and the former callback is not defined for rcar_can.

Why should it fail?

>                 memcpy(&bt, nla_data(data[IFLA_CAN_BITTIMING]), sizeof(bt));
>                 err = can_get_bittiming(dev, &bt,
>                                         priv->bittiming_const,
>                                         priv->bitrate_const,
>                                         priv->bitrate_const_cnt);
>                 if (err)
>                         return err;
>                 memcpy(&priv->bittiming, &bt, sizeof(bt));

Here the bittiming settings are copied to priv->bittiming
> 
>                 if (priv->do_set_bittiming) {
>                         /* Finally, set the bit-timing registers */
>                         err = priv->do_set_bittiming(dev);
>                         if (err)
>                                 return err;
>                 }

and it will only call the set_bittiming if it's defined.

> I don't say this is a must-have feature, since calling iproute2 with
> "set bitrate" and "set can up"  as in 1st approach will work just fine,
> will work just fine, but it is a nice to have feature for the second
> approach of setting bitrate.
> Also peak_usb pcan[2] uses this second approach (the changelink one) and
> this patch updates rcar_can for it.

Sorry I still don't get why this is necessary.

Marc

-- 
Pengutronix e.K.                  | Marc Kleine-Budde           |
Industrial Linux Solutions        | Phone: +49-231-2826-924     |
Vertretung West/Dortmund          | Fax:   +49-5121-206917-5555 |
Amtsgericht Hildesheim, HRA 2686  | http://www.pengutronix.de   |


[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 488 bytes --]

^ permalink raw reply	[flat|nested] 6+ messages in thread

* RE: [PATCH] Enabling rcar_can changelink support
  2017-04-30 19:30     ` Marc Kleine-Budde
@ 2017-05-02 10:09       ` Mirea, Bogdan-Stefan
  0 siblings, 0 replies; 6+ messages in thread
From: Mirea, Bogdan-Stefan @ 2017-05-02 10:09 UTC (permalink / raw)
  To: Marc Kleine-Budde, linux-can, linux-renesas-soc, socketcan

On April 30, 2017 10:31 PM Marc Kleine-Budde wrote:
> >                 memcpy(&priv->bittiming, &bt, sizeof(bt));
>
> Here the bittiming settings are copied to priv->bittiming

Yes Marc, you are right, I don't know how did I noticed an error which it isn't
since the bittiming structure is filled here, in can_changelink function...
My bad. 

Best Regards,
Bogdan

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2017-05-02 10:09 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2017-04-29 19:48 [PATCH] Enabling rcar_can changelink support Bogdan Mirea
2017-04-29 19:48 ` Bogdan Mirea
2017-04-29 21:26 ` Marc Kleine-Budde
2017-04-30 11:33   ` Mirea, Bogdan-Stefan
2017-04-30 19:30     ` Marc Kleine-Budde
2017-05-02 10:09       ` Mirea, Bogdan-Stefan

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.