summaryrefslogtreecommitdiff
path: root/drivers/ipoe/ipoe.c
diff options
context:
space:
mode:
authorDmitry Kozlov <xeb@mail.ru>2013-09-04 15:59:15 +0400
committerDmitry Kozlov <xeb@mail.ru>2013-09-04 15:59:15 +0400
commit61d2782551b0f90cd8c3611a0781f029e7fcd2a7 (patch)
tree2ddae0566ce6ea2c3a4606f6da81e3efe7bb74fa /drivers/ipoe/ipoe.c
parent0f59114d1b05f9f039471eb6d23f614ac104aa64 (diff)
downloadaccel-ppp-xebd-61d2782551b0f90cd8c3611a0781f029e7fcd2a7.tar.gz
accel-ppp-xebd-61d2782551b0f90cd8c3611a0781f029e7fcd2a7.zip
ipoe: fixed compilation on 3.10 kernel
Diffstat (limited to 'drivers/ipoe/ipoe.c')
-rw-r--r--drivers/ipoe/ipoe.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/drivers/ipoe/ipoe.c b/drivers/ipoe/ipoe.c
index 12d5f1b..fc944a8 100644
--- a/drivers/ipoe/ipoe.c
+++ b/drivers/ipoe/ipoe.c
@@ -1631,12 +1631,21 @@ static int ipoe_nl_cmd_add_vlan_mon(struct sk_buff *skb, struct genl_info *info)
if (info->attrs[IPOE_ATTR_VLAN_MASK]) {
memcpy(d->vid, nla_data(info->attrs[IPOE_ATTR_VLAN_MASK]), min((int)nla_len(info->attrs[IPOE_ATTR_VLAN_MASK]), (int)sizeof(d->vid)));
+#if LINUX_VERSION_CODE < KERNEL_VERSION(3,10,0)
if (dev->features & NETIF_F_HW_VLAN_FILTER) {
for (i = 1; i < 4096; i++) {
if (!(d->vid[i / (8*sizeof(long))] & (1 << (i % (8*sizeof(long))))))
dev->netdev_ops->ndo_vlan_rx_add_vid(dev, i);
}
}
+#else
+ if (dev->features & NETIF_F_HW_VLAN_CTAG_FILTER) {
+ for (i = 1; i < 4096; i++) {
+ if (!(d->vid[i / (8*sizeof(long))] & (1 << (i % (8*sizeof(long))))))
+ dev->netdev_ops->ndo_vlan_rx_add_vid(dev, htons(ETH_P_8021Q), i);
+ }
+ }
+#endif
}
dev_put(dev);
@@ -1675,8 +1684,13 @@ static int ipoe_nl_cmd_add_vlan_mon_vid(struct sk_buff *skb, struct genl_info *i
list_for_each_entry(d, &vlan_devices, entry) {
if (d->ifindex == ifindex) {
d->vid[vid / (8*sizeof(long))] &= ~(1 << (vid % (8*sizeof(long))));
+#if LINUX_VERSION_CODE < KERNEL_VERSION(3,10,0)
if (dev->features & NETIF_F_HW_VLAN_FILTER)
dev->netdev_ops->ndo_vlan_rx_add_vid(dev, vid);
+#else
+ if (dev->features & NETIF_F_HW_VLAN_CTAG_FILTER)
+ dev->netdev_ops->ndo_vlan_rx_add_vid(dev, htons(ETH_P_8021Q), vid);
+#endif
break;
}
}