diff options
Diffstat (limited to 'drivers/misc/sgi-xp/xpnet.c')
-rw-r--r-- | drivers/misc/sgi-xp/xpnet.c | 30 |
1 files changed, 13 insertions, 17 deletions
diff --git a/drivers/misc/sgi-xp/xpnet.c b/drivers/misc/sgi-xp/xpnet.c index e41cb93b8c89..a9543c65814d 100644 --- a/drivers/misc/sgi-xp/xpnet.c +++ b/drivers/misc/sgi-xp/xpnet.c | |||
@@ -21,6 +21,7 @@ | |||
21 | */ | 21 | */ |
22 | 22 | ||
23 | #include <linux/module.h> | 23 | #include <linux/module.h> |
24 | #include <linux/types.h> | ||
24 | #include <linux/kernel.h> | 25 | #include <linux/kernel.h> |
25 | #include <linux/init.h> | 26 | #include <linux/init.h> |
26 | #include <linux/ioport.h> | 27 | #include <linux/ioport.h> |
@@ -34,7 +35,6 @@ | |||
34 | #include <asm/sn/bte.h> | 35 | #include <asm/sn/bte.h> |
35 | #include <asm/sn/io.h> | 36 | #include <asm/sn/io.h> |
36 | #include <asm/sn/sn_sal.h> | 37 | #include <asm/sn/sn_sal.h> |
37 | #include <asm/types.h> | ||
38 | #include <asm/atomic.h> | 38 | #include <asm/atomic.h> |
39 | #include "xp.h" | 39 | #include "xp.h" |
40 | 40 | ||
@@ -87,8 +87,8 @@ struct xpnet_message { | |||
87 | #define XPNET_VERSION_MAJOR(_v) ((_v) >> 4) | 87 | #define XPNET_VERSION_MAJOR(_v) ((_v) >> 4) |
88 | #define XPNET_VERSION_MINOR(_v) ((_v) & 0xf) | 88 | #define XPNET_VERSION_MINOR(_v) ((_v) & 0xf) |
89 | 89 | ||
90 | #define XPNET_VERSION _XPNET_VERSION(1,0) /* version 1.0 */ | 90 | #define XPNET_VERSION _XPNET_VERSION(1, 0) /* version 1.0 */ |
91 | #define XPNET_VERSION_EMBED _XPNET_VERSION(1,1) /* version 1.1 */ | 91 | #define XPNET_VERSION_EMBED _XPNET_VERSION(1, 1) /* version 1.1 */ |
92 | #define XPNET_MAGIC 0x88786984 /* "XNET" */ | 92 | #define XPNET_MAGIC 0x88786984 /* "XNET" */ |
93 | 93 | ||
94 | #define XPNET_VALID_MSG(_m) \ | 94 | #define XPNET_VALID_MSG(_m) \ |
@@ -236,9 +236,11 @@ xpnet_receive(partid_t partid, int channel, struct xpnet_message *msg) | |||
236 | msg->size, (BTE_NOTIFY | BTE_WACQUIRE), NULL); | 236 | msg->size, (BTE_NOTIFY | BTE_WACQUIRE), NULL); |
237 | 237 | ||
238 | if (bret != BTE_SUCCESS) { | 238 | if (bret != BTE_SUCCESS) { |
239 | // >>> Need better way of cleaning skb. Currently skb | 239 | /* |
240 | // >>> appears in_use and we can't just call | 240 | * >>> Need better way of cleaning skb. Currently skb |
241 | // >>> dev_kfree_skb. | 241 | * >>> appears in_use and we can't just call |
242 | * >>> dev_kfree_skb. | ||
243 | */ | ||
242 | dev_err(xpnet, "bte_copy(0x%p, 0x%p, 0x%hx) returned " | 244 | dev_err(xpnet, "bte_copy(0x%p, 0x%p, 0x%hx) returned " |
243 | "error=0x%x\n", (void *)msg->buf_pa, | 245 | "error=0x%x\n", (void *)msg->buf_pa, |
244 | (void *)__pa((u64)skb->data & | 246 | (void *)__pa((u64)skb->data & |
@@ -314,9 +316,8 @@ xpnet_connection_activity(enum xpc_retval reason, partid_t partid, int channel, | |||
314 | bp = xpnet_broadcast_partitions; | 316 | bp = xpnet_broadcast_partitions; |
315 | spin_unlock_bh(&xpnet_broadcast_lock); | 317 | spin_unlock_bh(&xpnet_broadcast_lock); |
316 | 318 | ||
317 | if (bp == 0) { | 319 | if (bp == 0) |
318 | netif_carrier_off(xpnet_device); | 320 | netif_carrier_off(xpnet_device); |
319 | } | ||
320 | 321 | ||
321 | dev_dbg(xpnet, "%s disconnected from partition %d; " | 322 | dev_dbg(xpnet, "%s disconnected from partition %d; " |
322 | "xpnet_broadcast_partitions=0x%lx\n", | 323 | "xpnet_broadcast_partitions=0x%lx\n", |
@@ -527,9 +528,8 @@ xpnet_dev_hard_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
527 | 528 | ||
528 | ret = xpc_allocate(dest_partid, XPC_NET_CHANNEL, | 529 | ret = xpc_allocate(dest_partid, XPC_NET_CHANNEL, |
529 | XPC_NOWAIT, (void **)&msg); | 530 | XPC_NOWAIT, (void **)&msg); |
530 | if (unlikely(ret != xpcSuccess)) { | 531 | if (unlikely(ret != xpcSuccess)) |
531 | continue; | 532 | continue; |
532 | } | ||
533 | 533 | ||
534 | msg->embedded_bytes = embedded_bytes; | 534 | msg->embedded_bytes = embedded_bytes; |
535 | if (unlikely(embedded_bytes != 0)) { | 535 | if (unlikely(embedded_bytes != 0)) { |
@@ -561,7 +561,6 @@ xpnet_dev_hard_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
561 | atomic_dec(&queued_msg->use_count); | 561 | atomic_dec(&queued_msg->use_count); |
562 | continue; | 562 | continue; |
563 | } | 563 | } |
564 | |||
565 | } | 564 | } |
566 | 565 | ||
567 | if (atomic_dec_return(&queued_msg->use_count) == 0) { | 566 | if (atomic_dec_return(&queued_msg->use_count) == 0) { |
@@ -599,9 +598,8 @@ xpnet_init(void) | |||
599 | u32 license_num; | 598 | u32 license_num; |
600 | int result = -ENOMEM; | 599 | int result = -ENOMEM; |
601 | 600 | ||
602 | if (!ia64_platform_is("sn2")) { | 601 | if (!ia64_platform_is("sn2")) |
603 | return -ENODEV; | 602 | return -ENODEV; |
604 | } | ||
605 | 603 | ||
606 | dev_info(xpnet, "registering network device %s\n", XPNET_DEVICE_NAME); | 604 | dev_info(xpnet, "registering network device %s\n", XPNET_DEVICE_NAME); |
607 | 605 | ||
@@ -611,9 +609,8 @@ xpnet_init(void) | |||
611 | */ | 609 | */ |
612 | xpnet_device = alloc_netdev(sizeof(struct xpnet_dev_private), | 610 | xpnet_device = alloc_netdev(sizeof(struct xpnet_dev_private), |
613 | XPNET_DEVICE_NAME, ether_setup); | 611 | XPNET_DEVICE_NAME, ether_setup); |
614 | if (xpnet_device == NULL) { | 612 | if (xpnet_device == NULL) |
615 | return -ENOMEM; | 613 | return -ENOMEM; |
616 | } | ||
617 | 614 | ||
618 | netif_carrier_off(xpnet_device); | 615 | netif_carrier_off(xpnet_device); |
619 | 616 | ||
@@ -654,9 +651,8 @@ xpnet_init(void) | |||
654 | xpnet_device->features = NETIF_F_NO_CSUM; | 651 | xpnet_device->features = NETIF_F_NO_CSUM; |
655 | 652 | ||
656 | result = register_netdev(xpnet_device); | 653 | result = register_netdev(xpnet_device); |
657 | if (result != 0) { | 654 | if (result != 0) |
658 | free_netdev(xpnet_device); | 655 | free_netdev(xpnet_device); |
659 | } | ||
660 | 656 | ||
661 | return result; | 657 | return result; |
662 | } | 658 | } |