mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-10 07:00:48 +00:00
net_sched: sch_fq: use hash_ptr()
When I wrote sch_fq.c, hash_ptr() on 64bit arches was awful, and I chose hash_32(). Linus Torvalds and George Spelvin fixed this issue, so we can use hash_ptr() to get more entropy on 64bit arches with Terabytes of memory, and avoid the cast games. Signed-off-by: Eric Dumazet <edumazet@google.com> Cc: Hugh Dickins <hughd@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
d30d9ccbfa
commit
29c58472ec
@ -245,7 +245,7 @@ static struct fq_flow *fq_classify(struct sk_buff *skb, struct fq_sched_data *q)
|
||||
skb_orphan(skb);
|
||||
}
|
||||
|
||||
root = &q->fq_root[hash_32((u32)(long)sk, q->fq_trees_log)];
|
||||
root = &q->fq_root[hash_ptr(sk, q->fq_trees_log)];
|
||||
|
||||
if (q->flows >= (2U << q->fq_trees_log) &&
|
||||
q->inactive_flows > q->flows/2)
|
||||
@ -599,7 +599,7 @@ static void fq_rehash(struct fq_sched_data *q,
|
||||
kmem_cache_free(fq_flow_cachep, of);
|
||||
continue;
|
||||
}
|
||||
nroot = &new_array[hash_32((u32)(long)of->sk, new_log)];
|
||||
nroot = &new_array[hash_ptr(of->sk, new_log)];
|
||||
|
||||
np = &nroot->rb_node;
|
||||
parent = NULL;
|
||||
|
Loading…
x
Reference in New Issue
Block a user