diff options
author | Amit Shah <amitshah@gmx.net> | 2008-02-29 05:54:50 -0500 |
---|---|---|
committer | Rusty Russell <rusty@rustcorp.com.au> | 2008-03-17 07:58:20 -0400 |
commit | da74e89d40995600b3b07ac500084920247687ce (patch) | |
tree | ee38d53aa14ed15f0fc1474426210e8a89485ad0 /drivers/net | |
parent | bdc1681cdf1ab6a65fa935a2b3f8fc63b20c54ea (diff) |
virtio: Enable netpoll interface for netconsole logging
Add a new poll_controller handler that the netpoll interface needs.
This enables netconsole logging from a kvm guest over the virtio
net interface.
Signed-off-by: Amit Shah <amitshah@gmx.net>
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/virtio_net.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/drivers/net/virtio_net.c b/drivers/net/virtio_net.c index 19fd4cb0ddf8..e575df83e5c2 100644 --- a/drivers/net/virtio_net.c +++ b/drivers/net/virtio_net.c | |||
@@ -294,6 +294,15 @@ again: | |||
294 | return 0; | 294 | return 0; |
295 | } | 295 | } |
296 | 296 | ||
297 | #ifdef CONFIG_NET_POLL_CONTROLLER | ||
298 | static void virtnet_netpoll(struct net_device *dev) | ||
299 | { | ||
300 | struct virtnet_info *vi = netdev_priv(dev); | ||
301 | |||
302 | napi_schedule(&vi->napi); | ||
303 | } | ||
304 | #endif | ||
305 | |||
297 | static int virtnet_open(struct net_device *dev) | 306 | static int virtnet_open(struct net_device *dev) |
298 | { | 307 | { |
299 | struct virtnet_info *vi = netdev_priv(dev); | 308 | struct virtnet_info *vi = netdev_priv(dev); |
@@ -336,6 +345,9 @@ static int virtnet_probe(struct virtio_device *vdev) | |||
336 | dev->stop = virtnet_close; | 345 | dev->stop = virtnet_close; |
337 | dev->hard_start_xmit = start_xmit; | 346 | dev->hard_start_xmit = start_xmit; |
338 | dev->features = NETIF_F_HIGHDMA; | 347 | dev->features = NETIF_F_HIGHDMA; |
348 | #ifdef CONFIG_NET_POLL_CONTROLLER | ||
349 | dev->poll_controller = virtnet_netpoll; | ||
350 | #endif | ||
339 | SET_NETDEV_DEV(dev, &vdev->dev); | 351 | SET_NETDEV_DEV(dev, &vdev->dev); |
340 | 352 | ||
341 | /* Do we support "hardware" checksums? */ | 353 | /* Do we support "hardware" checksums? */ |