igc: Refactor igc_del_mac_filter()
authorAndre Guedes <andre.guedes@intel.com>
Wed, 18 Mar 2020 23:01:01 +0000 (16:01 -0700)
committerJeff Kirsher <jeffrey.t.kirsher@intel.com>
Sun, 19 Apr 2020 19:21:49 +0000 (12:21 -0700)
This patch does a code refactoring in igc_del_mac_filter() so it uses
the new helper igc_find_mac_filter() and improves the comment about the
special handling when deleting the default filter.

Signed-off-by: Andre Guedes <andre.guedes@intel.com>
Tested-by: Aaron Brown <aaron.f.brown@intel.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
drivers/net/ethernet/intel/igc/igc_main.c

index 79a9875e07672ceabb780bcc4fae39e393990692..78753f12b8a0ab4c6cfb6cedcc2565d2a9b7458d 100644 (file)
@@ -2267,40 +2267,33 @@ update_queue_assignment:
 int igc_del_mac_filter(struct igc_adapter *adapter, const u8 *addr,
                       const u8 flags)
 {
-       struct igc_hw *hw = &adapter->hw;
-       int rar_entries = hw->mac.rar_entry_count;
-       int i;
+       struct igc_mac_addr *entry;
+       int index;
 
        if (!is_valid_ether_addr(addr))
                return -EINVAL;
 
-       for (i = 0; i < rar_entries; i++) {
-               if (!(adapter->mac_table[i].state & IGC_MAC_STATE_IN_USE))
-                       continue;
-               if (flags && (adapter->mac_table[i].state & flags) != flags)
-                       continue;
-               if (!ether_addr_equal(adapter->mac_table[i].addr, addr))
-                       continue;
+       index = igc_find_mac_filter(adapter, addr, flags);
+       if (index < 0)
+               return -ENOENT;
 
-               /* When a filter for the default address is "deleted",
-                * we return it to its initial configuration
-                */
-               if (adapter->mac_table[i].state & IGC_MAC_STATE_DEFAULT) {
-                       adapter->mac_table[i].state =
-                               IGC_MAC_STATE_DEFAULT | IGC_MAC_STATE_IN_USE;
-                       adapter->mac_table[i].queue = -1;
-                       igc_set_mac_filter_hw(adapter, 0, addr, -1);
-               } else {
-                       adapter->mac_table[i].state = 0;
-                       adapter->mac_table[i].queue = -1;
-                       memset(adapter->mac_table[i].addr, 0, ETH_ALEN);
-                       igc_clear_mac_filter_hw(adapter, i);
-               }
+       entry = &adapter->mac_table[index];
 
-               return 0;
+       if (entry->state & IGC_MAC_STATE_DEFAULT) {
+               /* If this is the default filter, we don't actually delete it.
+                * We just reset to its default value i.e. disable queue
+                * assignment.
+                */
+               entry->queue = -1;
+               igc_set_mac_filter_hw(adapter, 0, addr, entry->queue);
+       } else {
+               entry->state = 0;
+               entry->queue = -1;
+               memset(entry->addr, 0, ETH_ALEN);
+               igc_clear_mac_filter_hw(adapter, index);
        }
 
-       return -ENOENT;
+       return 0;
 }
 
 static int igc_uc_sync(struct net_device *netdev, const unsigned char *addr)