diff options
author | Michael Brown <mcb30@ipxe.org> | 2015-07-28 15:05:44 +0100 |
---|---|---|
committer | Michael Brown <mcb30@ipxe.org> | 2015-07-28 15:14:40 +0100 |
commit | b20d4a1522646f71ec22b541d95f9d603760a58d (patch) | |
tree | 7b3313e57278b9d0371b011c3218685c2087da12 /src/net/vlan.c | |
parent | 76338543f9e48833e7c634d947a7ae278f38aef9 (diff) | |
download | ipxe-b20d4a1522646f71ec22b541d95f9d603760a58d.tar.gz |
[netdevice] Allow network devices to disclaim IRQ support at runtime
VLAN and 802.11 devices use a network device operations structure that
wraps an underlying structure. For example, the vlan_operations
structure wraps the network device operations structure of the
underlying trunk device. This can cause false positives from the
current implementation of netdev_irq_supported(), which will always
report that VLAN devices support interrupts since it has no visibility
into the support provided by the underlying trunk device.
Fix by allowing network devices to explicitly flag that interrupts are
not supported, despite the presence of an irq() method.
Originally-fixed-by: Wissam Shoukair <wissams@mellanox.com>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
Diffstat (limited to 'src/net/vlan.c')
-rw-r--r-- | src/net/vlan.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/src/net/vlan.c b/src/net/vlan.c index 49e3257a0..f515c2dc9 100644 --- a/src/net/vlan.c +++ b/src/net/vlan.c @@ -389,6 +389,10 @@ int vlan_create ( struct net_device *trunk, unsigned int tag, snprintf ( netdev->name, sizeof ( netdev->name ), "%s-%d", trunk->name, vlan->tag ); + /* Mark device as not supporting interrupts, if applicable */ + if ( ! netdev_irq_supported ( trunk ) ) + netdev->state |= NETDEV_IRQ_UNSUPPORTED; + /* Register VLAN device */ if ( ( rc = register_netdev ( netdev ) ) != 0 ) { DBGC ( netdev, "VLAN %s could not register: %s\n", |