提交 0ceaacc9 编写于 作者: N Nick Piggin 提交者: Linus Torvalds

[PATCH] Fix up per-cpu page batch sizes

The code to clamp batch sizes to 2^n - 1 went missing and an extra
check got added, which must have been a hunk of the "higer order pcp
batch refills" work sneaking in.
Signed-off-by: NNick Piggin <npiggin@suse.de>
Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
上级 9a405257
...@@ -1772,16 +1772,16 @@ static int __devinit zone_batchsize(struct zone *zone) ...@@ -1772,16 +1772,16 @@ static int __devinit zone_batchsize(struct zone *zone)
batch = 1; batch = 1;
/* /*
* We will be trying to allcoate bigger chunks of contiguous * Clamp the batch to a 2^n - 1 value. Having a power
* memory of the order of fls(batch). This should result in * of 2 value was found to be more likely to have
* better cache coloring. * suboptimal cache aliasing properties in some cases.
* *
* A sanity check also to ensure that batch is still in limits. * For example if 2 tasks are alternately allocating
* batches of pages, one task can end up with a lot
* of pages of one half of the possible page colors
* and the other with pages of the other colors.
*/ */
batch = (1 << fls(batch + batch/2)); batch = (1 << (fls(batch + batch/2)-1)) - 1;
if (fls(batch) >= (PAGE_SHIFT + MAX_ORDER - 2))
batch = PAGE_SHIFT + ((MAX_ORDER - 1 - PAGE_SHIFT)/2);
return batch; return batch;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册