diff options
author | Ethan Jackson <ethan@nicira.com> | 2011-07-21 17:41:58 -0700 |
---|---|---|
committer | Ethan Jackson <ethan@nicira.com> | 2011-07-22 11:31:30 -0700 |
commit | 8ea45fdc0f5100487d40e501a0946b7dc3cac38a (patch) | |
tree | 4152add734b2d7931df119c091924aa3f6c9a9ca /lib/mac-learning.h | |
parent | 7bbe0453f5c6321c410149755de60324c186a71a (diff) | |
download | openvswitch-8ea45fdc0f5100487d40e501a0946b7dc3cac38a.tar.gz |
mac-learning: Convert to hmap.
The mac-learning code predates the hmap data structure in OVS. For
this reason, it rolled it's own hmap-like bucket concept. This
patch converts it to use an hmap which makes the code slightly
simpler and easier to understand.
Diffstat (limited to 'lib/mac-learning.h')
-rw-r--r-- | lib/mac-learning.h | 9 |
1 files changed, 3 insertions, 6 deletions
diff --git a/lib/mac-learning.h b/lib/mac-learning.h index d9fa433cd..d2f28744f 100644 --- a/lib/mac-learning.h +++ b/lib/mac-learning.h @@ -18,15 +18,12 @@ #define MAC_LEARNING_H 1 #include <time.h> +#include "hmap.h" #include "list.h" #include "packets.h" #include "tag.h" #include "timeval.h" -#define MAC_HASH_BITS 10 -#define MAC_HASH_MASK (MAC_HASH_SIZE - 1) -#define MAC_HASH_SIZE (1u << MAC_HASH_BITS) - #define MAC_MAX 2048 /* Time, in seconds, before expiring a mac_entry due to inactivity. */ @@ -38,7 +35,7 @@ /* A MAC learning table entry. */ struct mac_entry { - struct list hash_node; /* Element in a mac_learning 'table' list. */ + struct hmap_node hmap_node; /* Node in a mac_learning hmap. */ struct list lru_node; /* Element in 'lrus' or 'free' list. */ time_t expires; /* Expiration time. */ time_t grat_arp_lock; /* Gratuitous ARP lock expiration time. */ @@ -78,10 +75,10 @@ static inline bool mac_entry_is_grat_arp_locked(const struct mac_entry *mac) /* MAC learning table. */ struct mac_learning { + struct hmap table; /* Learning table. */ struct list free; /* Not-in-use entries. */ struct list lrus; /* In-use entries, least recently used at the front, most recently used at the back. */ - struct list table[MAC_HASH_SIZE]; /* Hash table. */ struct mac_entry entries[MAC_MAX]; /* All entries. */ uint32_t secret; /* Secret for randomizing hash table. */ unsigned long *flood_vlans; /* Bitmap of learning disabled VLANs. */ |