Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 11319
b: refs/heads/master
c: ba56e91
h: refs/heads/master
i:
  11317: c35e044
  11315: 6343f85
  11311: ff3e0f9
v: v3
  • Loading branch information
Seth, Rohit authored and Linus Torvalds committed Oct 30, 2005
1 parent 1c2cea9 commit ff38810
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 13 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: fcdae29aa7a5c79f245110f6680afdc1858d3626
refs/heads/master: ba56e91c940146e99ac694c4c7cd7f2b4aaa565d
24 changes: 12 additions & 12 deletions trunk/mm/page_alloc.c
Original file line number Diff line number Diff line change
Expand Up @@ -1721,29 +1721,29 @@ static int __devinit zone_batchsize(struct zone *zone)

/*
* The per-cpu-pages pools are set to around 1000th of the
* size of the zone. But no more than 1/4 of a meg - there's
* no point in going beyond the size of L2 cache.
* size of the zone. But no more than 1/2 of a meg.
*
* OK, so we don't know how big the cache is. So guess.
*/
batch = zone->present_pages / 1024;
if (batch * PAGE_SIZE > 256 * 1024)
batch = (256 * 1024) / PAGE_SIZE;
if (batch * PAGE_SIZE > 512 * 1024)
batch = (512 * 1024) / PAGE_SIZE;
batch /= 4; /* We effectively *= 4 below */
if (batch < 1)
batch = 1;

/*
* Clamp the batch to a 2^n - 1 value. Having a power
* of 2 value was found to be more likely to have
* suboptimal cache aliasing properties in some cases.
* We will be trying to allcoate bigger chunks of contiguous
* memory of the order of fls(batch). This should result in
* better cache coloring.
*
* 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.
* A sanity check also to ensure that batch is still in limits.
*/
batch = (1 << fls(batch + batch/2)) - 1;
batch = (1 << fls(batch + batch/2));

if (fls(batch) >= (PAGE_SHIFT + MAX_ORDER - 2))
batch = PAGE_SHIFT + ((MAX_ORDER - 1 - PAGE_SHIFT)/2);

return batch;
}

Expand Down

0 comments on commit ff38810

Please sign in to comment.