aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/core/dev.c23
1 files changed, 14 insertions, 9 deletions
diff --git a/net/core/dev.c b/net/core/dev.c
index d0e23d8310ff..d0d2675aaed6 100644
--- a/net/core/dev.c
+++ b/net/core/dev.c
@@ -150,8 +150,11 @@
150 * 86DD IPv6 150 * 86DD IPv6
151 */ 151 */
152 152
153#define PTYPE_HASH_SIZE (16)
154#define PTYPE_HASH_MASK (PTYPE_HASH_SIZE - 1)
155
153static DEFINE_SPINLOCK(ptype_lock); 156static DEFINE_SPINLOCK(ptype_lock);
154static struct list_head ptype_base[16] __read_mostly; /* 16 way hashed list */ 157static struct list_head ptype_base[PTYPE_HASH_SIZE] __read_mostly;
155static struct list_head ptype_all __read_mostly; /* Taps */ 158static struct list_head ptype_all __read_mostly; /* Taps */
156 159
157#ifdef CONFIG_NET_DMA 160#ifdef CONFIG_NET_DMA
@@ -362,7 +365,7 @@ void dev_add_pack(struct packet_type *pt)
362 if (pt->type == htons(ETH_P_ALL)) 365 if (pt->type == htons(ETH_P_ALL))
363 list_add_rcu(&pt->list, &ptype_all); 366 list_add_rcu(&pt->list, &ptype_all);
364 else { 367 else {
365 hash = ntohs(pt->type) & 15; 368 hash = ntohs(pt->type) & PTYPE_HASH_MASK;
366 list_add_rcu(&pt->list, &ptype_base[hash]); 369 list_add_rcu(&pt->list, &ptype_base[hash]);
367 } 370 }
368 spin_unlock_bh(&ptype_lock); 371 spin_unlock_bh(&ptype_lock);
@@ -391,7 +394,7 @@ void __dev_remove_pack(struct packet_type *pt)
391 if (pt->type == htons(ETH_P_ALL)) 394 if (pt->type == htons(ETH_P_ALL))
392 head = &ptype_all; 395 head = &ptype_all;
393 else 396 else
394 head = &ptype_base[ntohs(pt->type) & 15]; 397 head = &ptype_base[ntohs(pt->type) & PTYPE_HASH_MASK];
395 398
396 list_for_each_entry(pt1, head, list) { 399 list_for_each_entry(pt1, head, list) {
397 if (pt == pt1) { 400 if (pt == pt1) {
@@ -1420,7 +1423,8 @@ struct sk_buff *skb_gso_segment(struct sk_buff *skb, int features)
1420 } 1423 }
1421 1424
1422 rcu_read_lock(); 1425 rcu_read_lock();
1423 list_for_each_entry_rcu(ptype, &ptype_base[ntohs(type) & 15], list) { 1426 list_for_each_entry_rcu(ptype,
1427 &ptype_base[ntohs(type) & PTYPE_HASH_MASK], list) {
1424 if (ptype->type == type && !ptype->dev && ptype->gso_segment) { 1428 if (ptype->type == type && !ptype->dev && ptype->gso_segment) {
1425 if (unlikely(skb->ip_summed != CHECKSUM_PARTIAL)) { 1429 if (unlikely(skb->ip_summed != CHECKSUM_PARTIAL)) {
1426 err = ptype->gso_send_check(skb); 1430 err = ptype->gso_send_check(skb);
@@ -2077,7 +2081,8 @@ ncls:
2077 goto out; 2081 goto out;
2078 2082
2079 type = skb->protocol; 2083 type = skb->protocol;
2080 list_for_each_entry_rcu(ptype, &ptype_base[ntohs(type)&15], list) { 2084 list_for_each_entry_rcu(ptype,
2085 &ptype_base[ntohs(type) & PTYPE_HASH_MASK], list) {
2081 if (ptype->type == type && 2086 if (ptype->type == type &&
2082 (!ptype->dev || ptype->dev == skb->dev)) { 2087 (!ptype->dev || ptype->dev == skb->dev)) {
2083 if (pt_prev) 2088 if (pt_prev)
@@ -2525,7 +2530,7 @@ static void *ptype_get_idx(loff_t pos)
2525 ++i; 2530 ++i;
2526 } 2531 }
2527 2532
2528 for (t = 0; t < 16; t++) { 2533 for (t = 0; t < PTYPE_HASH_SIZE; t++) {
2529 list_for_each_entry_rcu(pt, &ptype_base[t], list) { 2534 list_for_each_entry_rcu(pt, &ptype_base[t], list) {
2530 if (i == pos) 2535 if (i == pos)
2531 return pt; 2536 return pt;
@@ -2559,10 +2564,10 @@ static void *ptype_seq_next(struct seq_file *seq, void *v, loff_t *pos)
2559 hash = 0; 2564 hash = 0;
2560 nxt = ptype_base[0].next; 2565 nxt = ptype_base[0].next;
2561 } else 2566 } else
2562 hash = ntohs(pt->type) & 15; 2567 hash = ntohs(pt->type) & PTYPE_HASH_MASK;
2563 2568
2564 while (nxt == &ptype_base[hash]) { 2569 while (nxt == &ptype_base[hash]) {
2565 if (++hash >= 16) 2570 if (++hash >= PTYPE_HASH_SIZE)
2566 return NULL; 2571 return NULL;
2567 nxt = ptype_base[hash].next; 2572 nxt = ptype_base[hash].next;
2568 } 2573 }
@@ -4398,7 +4403,7 @@ static int __init net_dev_init(void)
4398 goto out; 4403 goto out;
4399 4404
4400 INIT_LIST_HEAD(&ptype_all); 4405 INIT_LIST_HEAD(&ptype_all);
4401 for (i = 0; i < 16; i++) 4406 for (i = 0; i < PTYPE_HASH_SIZE; i++)
4402 INIT_LIST_HEAD(&ptype_base[i]); 4407 INIT_LIST_HEAD(&ptype_base[i]);
4403 4408
4404 if (register_pernet_subsys(&netdev_net_ops)) 4409 if (register_pernet_subsys(&netdev_net_ops))