提交 f6e63cfb 编写于 作者: L Linus Torvalds

Merge master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6

...@@ -286,6 +286,8 @@ static inline void check_tnode(const struct tnode *tn) ...@@ -286,6 +286,8 @@ static inline void check_tnode(const struct tnode *tn)
static int halve_threshold = 25; static int halve_threshold = 25;
static int inflate_threshold = 50; static int inflate_threshold = 50;
static int halve_threshold_root = 15;
static int inflate_threshold_root = 25;
static void __alias_free_mem(struct rcu_head *head) static void __alias_free_mem(struct rcu_head *head)
...@@ -449,6 +451,8 @@ static struct node *resize(struct trie *t, struct tnode *tn) ...@@ -449,6 +451,8 @@ static struct node *resize(struct trie *t, struct tnode *tn)
int i; int i;
int err = 0; int err = 0;
struct tnode *old_tn; struct tnode *old_tn;
int inflate_threshold_use;
int halve_threshold_use;
if (!tn) if (!tn)
return NULL; return NULL;
...@@ -541,10 +545,17 @@ static struct node *resize(struct trie *t, struct tnode *tn) ...@@ -541,10 +545,17 @@ static struct node *resize(struct trie *t, struct tnode *tn)
check_tnode(tn); check_tnode(tn);
/* Keep root node larger */
if(!tn->parent)
inflate_threshold_use = inflate_threshold_root;
else
inflate_threshold_use = inflate_threshold;
err = 0; err = 0;
while ((tn->full_children > 0 && while ((tn->full_children > 0 &&
50 * (tn->full_children + tnode_child_length(tn) - tn->empty_children) >= 50 * (tn->full_children + tnode_child_length(tn) - tn->empty_children) >=
inflate_threshold * tnode_child_length(tn))) { inflate_threshold_use * tnode_child_length(tn))) {
old_tn = tn; old_tn = tn;
tn = inflate(t, tn); tn = inflate(t, tn);
...@@ -564,10 +575,18 @@ static struct node *resize(struct trie *t, struct tnode *tn) ...@@ -564,10 +575,18 @@ static struct node *resize(struct trie *t, struct tnode *tn)
* node is above threshold. * node is above threshold.
*/ */
/* Keep root node larger */
if(!tn->parent)
halve_threshold_use = halve_threshold_root;
else
halve_threshold_use = halve_threshold;
err = 0; err = 0;
while (tn->bits > 1 && while (tn->bits > 1 &&
100 * (tnode_child_length(tn) - tn->empty_children) < 100 * (tnode_child_length(tn) - tn->empty_children) <
halve_threshold * tnode_child_length(tn)) { halve_threshold_use * tnode_child_length(tn)) {
old_tn = tn; old_tn = tn;
tn = halve(t, tn); tn = halve(t, tn);
......
...@@ -99,7 +99,7 @@ static int udp_v6_get_port(struct sock *sk, unsigned short snum) ...@@ -99,7 +99,7 @@ static int udp_v6_get_port(struct sock *sk, unsigned short snum)
next:; next:;
} }
result = best; result = best;
for(;; result += UDP_HTABLE_SIZE) { for(i = 0; i < (1 << 16) / UDP_HTABLE_SIZE; i++, result += UDP_HTABLE_SIZE) {
if (result > sysctl_local_port_range[1]) if (result > sysctl_local_port_range[1])
result = sysctl_local_port_range[0] result = sysctl_local_port_range[0]
+ ((result - sysctl_local_port_range[0]) & + ((result - sysctl_local_port_range[0]) &
...@@ -107,6 +107,8 @@ static int udp_v6_get_port(struct sock *sk, unsigned short snum) ...@@ -107,6 +107,8 @@ static int udp_v6_get_port(struct sock *sk, unsigned short snum)
if (!udp_lport_inuse(result)) if (!udp_lport_inuse(result))
break; break;
} }
if (i >= (1 << 16) / UDP_HTABLE_SIZE)
goto fail;
gotit: gotit:
udp_port_rover = snum = result; udp_port_rover = snum = result;
} else { } else {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册