diff options
Diffstat (limited to 'mm')
-rw-r--r-- | mm/mempolicy.c | 30 |
1 files changed, 29 insertions, 1 deletions
diff --git a/mm/mempolicy.c b/mm/mempolicy.c index 4c1c8d83ac6a..fd20e28fd2ad 100644 --- a/mm/mempolicy.c +++ b/mm/mempolicy.c | |||
@@ -2317,9 +2317,37 @@ int mpol_misplaced(struct page *page, struct vm_area_struct *vma, unsigned long | |||
2317 | } | 2317 | } |
2318 | 2318 | ||
2319 | /* Migrate the page towards the node whose CPU is referencing it */ | 2319 | /* Migrate the page towards the node whose CPU is referencing it */ |
2320 | if (pol->flags & MPOL_F_MORON) | 2320 | if (pol->flags & MPOL_F_MORON) { |
2321 | int last_nid; | ||
2322 | |||
2321 | polnid = numa_node_id(); | 2323 | polnid = numa_node_id(); |
2322 | 2324 | ||
2325 | /* | ||
2326 | * Multi-stage node selection is used in conjunction | ||
2327 | * with a periodic migration fault to build a temporal | ||
2328 | * task<->page relation. By using a two-stage filter we | ||
2329 | * remove short/unlikely relations. | ||
2330 | * | ||
2331 | * Using P(p) ~ n_p / n_t as per frequentist | ||
2332 | * probability, we can equate a task's usage of a | ||
2333 | * particular page (n_p) per total usage of this | ||
2334 | * page (n_t) (in a given time-span) to a probability. | ||
2335 | * | ||
2336 | * Our periodic faults will sample this probability and | ||
2337 | * getting the same result twice in a row, given these | ||
2338 | * samples are fully independent, is then given by | ||
2339 | * P(n)^2, provided our sample period is sufficiently | ||
2340 | * short compared to the usage pattern. | ||
2341 | * | ||
2342 | * This quadric squishes small probabilities, making | ||
2343 | * it less likely we act on an unlikely task<->page | ||
2344 | * relation. | ||
2345 | */ | ||
2346 | last_nid = page_xchg_last_nid(page, polnid); | ||
2347 | if (last_nid != polnid) | ||
2348 | goto out; | ||
2349 | } | ||
2350 | |||
2323 | if (curnid != polnid) | 2351 | if (curnid != polnid) |
2324 | ret = polnid; | 2352 | ret = polnid; |
2325 | out: | 2353 | out: |