can: bfin_can: simplify xmit id1 setup
authorMike Frysinger <vapier@gentoo.org>
Fri, 24 Jun 2011 04:33:01 +0000 (04:33 +0000)
committerDavid S. Miller <davem@davemloft.net>
Tue, 28 Jun 2011 03:42:24 +0000 (20:42 -0700)
If we look closely, the 4 writes to TRANSMIT_CHL.id1 can be collapsed
down into much simpler code.  So do just that.

This also fixes a build failure due to the I/O macros no longer
getting pulled in.  Their minor (and accidental) usage here gets
dropped as part of the unification.

Signed-off-by: Mike Frysinger <vapier@gentoo.org>
Acked-by: Wolfgang Grandegger <wg@grandegger.com>
Acked-by: Kurt Van Dijck <kurt.van.dijck@eia.be>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/can/bfin_can.c

index b6e890d28366c68bf2ae078b4a73f688dfe75962..dc6ef4a9e02acc3eadc997e6332c9fb11e2e4723 100644 (file)
@@ -243,21 +243,12 @@ static int bfin_can_start_xmit(struct sk_buff *skb, struct net_device *dev)
        /* fill id */
        if (id & CAN_EFF_FLAG) {
                bfin_write16(&reg->chl[TRANSMIT_CHL].id0, id);
-               if (id & CAN_RTR_FLAG)
-                       writew(((id & 0x1FFF0000) >> 16) | IDE | AME | RTR,
-                                       &reg->chl[TRANSMIT_CHL].id1);
-               else
-                       writew(((id & 0x1FFF0000) >> 16) | IDE | AME,
-                                       &reg->chl[TRANSMIT_CHL].id1);
-
-       } else {
-               if (id & CAN_RTR_FLAG)
-                       writew((id << 2) | AME | RTR,
-                               &reg->chl[TRANSMIT_CHL].id1);
-               else
-                       bfin_write16(&reg->chl[TRANSMIT_CHL].id1,
-                                       (id << 2) | AME);
-       }
+               val = ((id & 0x1FFF0000) >> 16) | IDE;
+       } else
+               val = (id << 2);
+       if (id & CAN_RTR_FLAG)
+               val |= RTR;
+       bfin_write16(&reg->chl[TRANSMIT_CHL].id1, val | AME);
 
        /* fill payload */
        for (i = 0; i < 8; i += 2) {