mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-26 18:43:33 -05:00
netpoll queue cleanup
The beast had a long and not very happy history. At one point, a friend (netdump) had asked that he open up a little. Well, the friend was long gone now, and the beast had this dangling piece hanging (netpoll_queue). It wasn't hard to stitch the netpoll_queue back in where it belonged and make everything tidy. Signed-off-by: Stephen Hemminger <shemminger@osdl.org>
This commit is contained in:
parent
2bdfe0baec
commit
5de4a473bd
3 changed files with 5 additions and 23 deletions
|
@ -60,7 +60,6 @@ static struct netpoll np = {
|
||||||
.local_port = 6665,
|
.local_port = 6665,
|
||||||
.remote_port = 6666,
|
.remote_port = 6666,
|
||||||
.remote_mac = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff},
|
.remote_mac = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff},
|
||||||
.drop = netpoll_queue,
|
|
||||||
};
|
};
|
||||||
static int configured = 0;
|
static int configured = 0;
|
||||||
|
|
||||||
|
|
|
@ -18,7 +18,7 @@ struct netpoll {
|
||||||
struct net_device *dev;
|
struct net_device *dev;
|
||||||
char dev_name[16], *name;
|
char dev_name[16], *name;
|
||||||
void (*rx_hook)(struct netpoll *, int, char *, int);
|
void (*rx_hook)(struct netpoll *, int, char *, int);
|
||||||
void (*drop)(struct sk_buff *skb);
|
|
||||||
u32 local_ip, remote_ip;
|
u32 local_ip, remote_ip;
|
||||||
u16 local_port, remote_port;
|
u16 local_port, remote_port;
|
||||||
unsigned char local_mac[6], remote_mac[6];
|
unsigned char local_mac[6], remote_mac[6];
|
||||||
|
@ -44,7 +44,7 @@ int netpoll_trap(void);
|
||||||
void netpoll_set_trap(int trap);
|
void netpoll_set_trap(int trap);
|
||||||
void netpoll_cleanup(struct netpoll *np);
|
void netpoll_cleanup(struct netpoll *np);
|
||||||
int __netpoll_rx(struct sk_buff *skb);
|
int __netpoll_rx(struct sk_buff *skb);
|
||||||
void netpoll_queue(struct sk_buff *skb);
|
|
||||||
|
|
||||||
#ifdef CONFIG_NETPOLL
|
#ifdef CONFIG_NETPOLL
|
||||||
static inline int netpoll_rx(struct sk_buff *skb)
|
static inline int netpoll_rx(struct sk_buff *skb)
|
||||||
|
|
|
@ -77,19 +77,6 @@ static void queue_process(void *p)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void netpoll_queue(struct sk_buff *skb)
|
|
||||||
{
|
|
||||||
struct net_device *dev = skb->dev;
|
|
||||||
struct netpoll_info *npinfo = dev->npinfo;
|
|
||||||
|
|
||||||
if (!npinfo)
|
|
||||||
kfree_skb(skb);
|
|
||||||
else {
|
|
||||||
skb_queue_tail(&npinfo->txq, skb);
|
|
||||||
schedule_work(&npinfo->tx_work);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static int checksum_udp(struct sk_buff *skb, struct udphdr *uh,
|
static int checksum_udp(struct sk_buff *skb, struct udphdr *uh,
|
||||||
unsigned short ulen, u32 saddr, u32 daddr)
|
unsigned short ulen, u32 saddr, u32 daddr)
|
||||||
{
|
{
|
||||||
|
@ -256,7 +243,7 @@ static void netpoll_send_skb(struct netpoll *np, struct sk_buff *skb)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* don't get messages out of order, and no recursion */
|
/* don't get messages out of order, and no recursion */
|
||||||
if ( !(np->drop == netpoll_queue && skb_queue_len(&npinfo->txq))
|
if ( skb_queue_len(&npinfo->txq) == 0
|
||||||
&& npinfo->poll_owner != smp_processor_id()
|
&& npinfo->poll_owner != smp_processor_id()
|
||||||
&& netif_tx_trylock(dev)) {
|
&& netif_tx_trylock(dev)) {
|
||||||
|
|
||||||
|
@ -277,11 +264,8 @@ static void netpoll_send_skb(struct netpoll *np, struct sk_buff *skb)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (status != NETDEV_TX_OK) {
|
if (status != NETDEV_TX_OK) {
|
||||||
/* requeue for later */
|
skb_queue_tail(&npinfo->txq, skb);
|
||||||
if (np->drop)
|
schedule_work(&npinfo->tx_work);
|
||||||
np->drop(skb);
|
|
||||||
else
|
|
||||||
__kfree_skb(skb);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -809,4 +793,3 @@ EXPORT_SYMBOL(netpoll_setup);
|
||||||
EXPORT_SYMBOL(netpoll_cleanup);
|
EXPORT_SYMBOL(netpoll_cleanup);
|
||||||
EXPORT_SYMBOL(netpoll_send_udp);
|
EXPORT_SYMBOL(netpoll_send_udp);
|
||||||
EXPORT_SYMBOL(netpoll_poll);
|
EXPORT_SYMBOL(netpoll_poll);
|
||||||
EXPORT_SYMBOL(netpoll_queue);
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue