return ret;
 }
 
+#define BOND_VLAN_PROTO_NONE cpu_to_be16(0xffff)
+
 static bool bond_handle_vlan(struct slave *slave, struct bond_vlan_tag *tags,
                             struct sk_buff *skb)
 {
        struct net_device *slave_dev = slave->dev;
        struct bond_vlan_tag *outer_tag = tags;
 
-       if (!tags || tags->vlan_proto == VLAN_N_VID)
+       if (!tags || tags->vlan_proto == BOND_VLAN_PROTO_NONE)
                return true;
 
        tags++;
 
        /* Go through all the tags backwards and add them to the packet */
-       while (tags->vlan_proto != VLAN_N_VID) {
+       while (tags->vlan_proto != BOND_VLAN_PROTO_NONE) {
                if (!tags->vlan_id) {
                        tags++;
                        continue;
                tags = kcalloc(level + 1, sizeof(*tags), GFP_ATOMIC);
                if (!tags)
                        return ERR_PTR(-ENOMEM);
-               tags[level].vlan_proto = VLAN_N_VID;
+               tags[level].vlan_proto = BOND_VLAN_PROTO_NONE;
                return tags;
        }