netdev->name);
                break;
 
-       case OCTNET_CMD_ENABLE_VLAN_FILTER:
-               dev_info(&oct->pci_dev->dev, "%s VLAN filter enabled\n",
-                        netdev->name);
+       case OCTNET_CMD_VLAN_FILTER_CTL:
+               if (nctrl->ncmd.s.param1)
+                       dev_info(&oct->pci_dev->dev,
+                                "%s VLAN filter enabled\n", netdev->name);
+               else
+                       dev_info(&oct->pci_dev->dev,
+                                "%s VLAN filter disabled\n", netdev->name);
                break;
 
        case OCTNET_CMD_ADD_VLAN_FILTER:
 
            (lio->dev_capability & NETIF_F_LRO))
                request &= ~NETIF_F_LRO;
 
+       if ((request & NETIF_F_HW_VLAN_CTAG_FILTER) &&
+           !(lio->dev_capability & NETIF_F_HW_VLAN_CTAG_FILTER))
+               request &= ~NETIF_F_HW_VLAN_CTAG_FILTER;
+
        return request;
 }
 
 {
        struct lio *lio = netdev_priv(netdev);
 
-       if (!((netdev->features ^ features) & NETIF_F_LRO))
-               return 0;
-
-       if ((features & NETIF_F_LRO) && (lio->dev_capability & NETIF_F_LRO))
+       if ((features & NETIF_F_LRO) &&
+           (lio->dev_capability & NETIF_F_LRO) &&
+           !(netdev->features & NETIF_F_LRO))
                liquidio_set_feature(netdev, OCTNET_CMD_LRO_ENABLE,
                                     OCTNIC_LROIPV4 | OCTNIC_LROIPV6);
        else if (!(features & NETIF_F_LRO) &&
-                (lio->dev_capability & NETIF_F_LRO))
+                (lio->dev_capability & NETIF_F_LRO) &&
+                (netdev->features & NETIF_F_LRO))
                liquidio_set_feature(netdev, OCTNET_CMD_LRO_DISABLE,
                                     OCTNIC_LROIPV4 | OCTNIC_LROIPV6);
 
                liquidio_set_rxcsum_command(netdev, OCTNET_CMD_TNL_RX_CSUM_CTL,
                                            OCTNET_CMD_RXCSUM_DISABLE);
 
+       if ((features & NETIF_F_HW_VLAN_CTAG_FILTER) &&
+           (lio->dev_capability & NETIF_F_HW_VLAN_CTAG_FILTER) &&
+           !(netdev->features & NETIF_F_HW_VLAN_CTAG_FILTER))
+               liquidio_set_feature(netdev, OCTNET_CMD_VLAN_FILTER_CTL,
+                                    OCTNET_CMD_VLAN_FILTER_ENABLE);
+       else if (!(features & NETIF_F_HW_VLAN_CTAG_FILTER) &&
+                (lio->dev_capability & NETIF_F_HW_VLAN_CTAG_FILTER) &&
+                (netdev->features & NETIF_F_HW_VLAN_CTAG_FILTER))
+               liquidio_set_feature(netdev, OCTNET_CMD_VLAN_FILTER_CTL,
+                                    OCTNET_CMD_VLAN_FILTER_DISABLE);
+
        return 0;
 }
 
                        liquidio_set_feature(netdev, OCTNET_CMD_LRO_ENABLE,
                                             OCTNIC_LROIPV4 | OCTNIC_LROIPV6);
 
-               liquidio_set_feature(netdev, OCTNET_CMD_ENABLE_VLAN_FILTER, 0);
+               liquidio_set_feature(netdev, OCTNET_CMD_VLAN_FILTER_CTL,
+                                    OCTNET_CMD_VLAN_FILTER_ENABLE);
 
                if ((debug != -1) && (debug & NETIF_MSG_HW))
                        liquidio_set_feature(netdev,
 
 #define   OCTNET_CMD_VERBOSE_ENABLE   0x14
 #define   OCTNET_CMD_VERBOSE_DISABLE  0x15
 
-#define   OCTNET_CMD_ENABLE_VLAN_FILTER 0x16
+#define   OCTNET_CMD_VLAN_FILTER_CTL 0x16
 #define   OCTNET_CMD_ADD_VLAN_FILTER  0x17
 #define   OCTNET_CMD_DEL_VLAN_FILTER  0x18
 #define   OCTNET_CMD_VXLAN_PORT_CONFIG 0x19
 #define   OCTNET_CMD_RXCSUM_DISABLE    0x1
 #define   OCTNET_CMD_TXCSUM_ENABLE     0x0
 #define   OCTNET_CMD_TXCSUM_DISABLE    0x1
+#define   OCTNET_CMD_VLAN_FILTER_ENABLE 0x1
+#define   OCTNET_CMD_VLAN_FILTER_DISABLE 0x0
 
 /* RX(packets coming from wire) Checksum verification flags */
 /* TCP/UDP csum */