diff options
| author | Kurt Van Dijck <kurt.van.dijck@eia.be> | 2011-05-02 00:50:48 -0400 |
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2011-05-05 14:02:22 -0400 |
| commit | 87e9af6cc67d842cd92b52b81f3f14e665e7ab05 (patch) | |
| tree | 965631795b4d21356a8d9a1935000fe9361c6ec5 /drivers | |
| parent | 75bd0cbdc21d80859c80bdd5dd00125c1a3ccbca (diff) | |
can: fix SJA1000 dlc for RTR packets
RTR frames do have a valid data length code on CAN.
The driver for SJA1000 did not handle that situation properly.
Signed-off-by: Kurt Van Dijck <kurt.van.dijck@eia.be>
Acked-by: Marc Kleine-Budde <mkl@pengutronix.de>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers')
| -rw-r--r-- | drivers/net/can/sja1000/sja1000.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/net/can/sja1000/sja1000.c b/drivers/net/can/sja1000/sja1000.c index a358ea9445a2..f501bba1fc6f 100644 --- a/drivers/net/can/sja1000/sja1000.c +++ b/drivers/net/can/sja1000/sja1000.c | |||
| @@ -346,10 +346,10 @@ static void sja1000_rx(struct net_device *dev) | |||
| 346 | | (priv->read_reg(priv, REG_ID2) >> 5); | 346 | | (priv->read_reg(priv, REG_ID2) >> 5); |
| 347 | } | 347 | } |
| 348 | 348 | ||
| 349 | cf->can_dlc = get_can_dlc(fi & 0x0F); | ||
| 349 | if (fi & FI_RTR) { | 350 | if (fi & FI_RTR) { |
| 350 | id |= CAN_RTR_FLAG; | 351 | id |= CAN_RTR_FLAG; |
| 351 | } else { | 352 | } else { |
| 352 | cf->can_dlc = get_can_dlc(fi & 0x0F); | ||
| 353 | for (i = 0; i < cf->can_dlc; i++) | 353 | for (i = 0; i < cf->can_dlc; i++) |
| 354 | cf->data[i] = priv->read_reg(priv, dreg++); | 354 | cf->data[i] = priv->read_reg(priv, dreg++); |
| 355 | } | 355 | } |
