diff options
Diffstat (limited to 'drivers/net/sgiseeq.c')
-rw-r--r-- | drivers/net/sgiseeq.c | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/drivers/net/sgiseeq.c b/drivers/net/sgiseeq.c index f4dfd1f679a9..c8fc896fc460 100644 --- a/drivers/net/sgiseeq.c +++ b/drivers/net/sgiseeq.c | |||
@@ -8,6 +8,7 @@ | |||
8 | 8 | ||
9 | #include <linux/kernel.h> | 9 | #include <linux/kernel.h> |
10 | #include <linux/module.h> | 10 | #include <linux/module.h> |
11 | #include <linux/slab.h> | ||
11 | #include <linux/errno.h> | 12 | #include <linux/errno.h> |
12 | #include <linux/init.h> | 13 | #include <linux/init.h> |
13 | #include <linux/types.h> | 14 | #include <linux/types.h> |
@@ -365,11 +366,10 @@ static inline void sgiseeq_rx(struct net_device *dev, struct sgiseeq_private *sp | |||
365 | } | 366 | } |
366 | skb_reserve(newskb, 2); | 367 | skb_reserve(newskb, 2); |
367 | } else { | 368 | } else { |
368 | skb = netdev_alloc_skb(dev, len + 2); | 369 | skb = netdev_alloc_skb_ip_align(dev, len); |
369 | if (skb) { | 370 | if (skb) |
370 | skb_reserve(skb, 2); | ||
371 | skb_copy_to_linear_data(skb, rd->skb->data, len); | 371 | skb_copy_to_linear_data(skb, rd->skb->data, len); |
372 | } | 372 | |
373 | newskb = rd->skb; | 373 | newskb = rd->skb; |
374 | } | 374 | } |
375 | memory_squeeze: | 375 | memory_squeeze: |
@@ -593,8 +593,10 @@ static int sgiseeq_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
593 | /* Setup... */ | 593 | /* Setup... */ |
594 | len = skb->len; | 594 | len = skb->len; |
595 | if (len < ETH_ZLEN) { | 595 | if (len < ETH_ZLEN) { |
596 | if (skb_padto(skb, ETH_ZLEN)) | 596 | if (skb_padto(skb, ETH_ZLEN)) { |
597 | spin_unlock_irqrestore(&sp->tx_lock, flags); | ||
597 | return NETDEV_TX_OK; | 598 | return NETDEV_TX_OK; |
599 | } | ||
598 | len = ETH_ZLEN; | 600 | len = ETH_ZLEN; |
599 | } | 601 | } |
600 | 602 | ||
@@ -661,7 +663,7 @@ static void sgiseeq_set_multicast(struct net_device *dev) | |||
661 | 663 | ||
662 | if(dev->flags & IFF_PROMISC) | 664 | if(dev->flags & IFF_PROMISC) |
663 | sp->mode = SEEQ_RCMD_RANY; | 665 | sp->mode = SEEQ_RCMD_RANY; |
664 | else if ((dev->flags & IFF_ALLMULTI) || dev->mc_count) | 666 | else if ((dev->flags & IFF_ALLMULTI) || !netdev_mc_empty(dev)) |
665 | sp->mode = SEEQ_RCMD_RBMCAST; | 667 | sp->mode = SEEQ_RCMD_RBMCAST; |
666 | else | 668 | else |
667 | sp->mode = SEEQ_RCMD_RBCAST; | 669 | sp->mode = SEEQ_RCMD_RBCAST; |