|
@@ -581,17 +581,21 @@ void drain_zonestat(struct zone *zone, struct per_cpu_pageset *pset)
|
|
|
*/
|
|
|
void zone_statistics(struct zone *preferred_zone, struct zone *z, gfp_t flags)
|
|
|
{
|
|
|
- if (z->zone_pgdat == preferred_zone->zone_pgdat) {
|
|
|
+ int local_nid = numa_node_id();
|
|
|
+ enum zone_stat_item local_stat = NUMA_LOCAL;
|
|
|
+
|
|
|
+ if (unlikely(flags & __GFP_OTHER_NODE)) {
|
|
|
+ local_stat = NUMA_OTHER;
|
|
|
+ local_nid = preferred_zone->node;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (z->node == local_nid) {
|
|
|
__inc_zone_state(z, NUMA_HIT);
|
|
|
+ __inc_zone_state(z, local_stat);
|
|
|
} else {
|
|
|
__inc_zone_state(z, NUMA_MISS);
|
|
|
__inc_zone_state(preferred_zone, NUMA_FOREIGN);
|
|
|
}
|
|
|
- if (z->node == ((flags & __GFP_OTHER_NODE) ?
|
|
|
- preferred_zone->node : numa_node_id()))
|
|
|
- __inc_zone_state(z, NUMA_LOCAL);
|
|
|
- else
|
|
|
- __inc_zone_state(z, NUMA_OTHER);
|
|
|
}
|
|
|
|
|
|
/*
|