Patches resend with Linux Kernel Mailing List added correctly this time. This patch series adds cache coloring mechanism that works along buddy allocator. The solution is opt-in, disabled by default minimally interferes with default allocation paths due to added if statements. Why would such patches be needed? Big caches with low associativity (direct mapped caches, 2-way associative) will benefit from the solution the most - it allows for near constant performance through the lifetime of a system, despite the allocations and deallocations happening and reordering buddy lists. On KNL system, the STREAM benchmark with problem size resulting in its internal arrays being of 16GB size will yield bandwidth performance of 336GB/s after fresh boot. With cache coloring patches applied and enabled, this performance stays near constant (most 1.5% drop observed), despite running benchmark multiple times with varying sizes over course of days. Without these patches however, the bandwidth when using such allocations drops to 117GB/s - over 65% of irrecoverable performance penalty. Workloads that exceed set cache size suffer from decreased randomization of allocations with cache coloring enabled, but effect of cache usage disappears roughly at the same allocation size. Solution is divided into three patches. First patch is a preparatory one that provides interface for retrieving (information about) free lists contained by particular free_area structure. Second one (parallel structure keeping separate list_heads for each cache color in a given context) shows general solution overview and is working as it is. However, it has serious performance implications with bigger caches due to linear search for next color to be used during allocations. Third patch (sorting list_heads using RB trees) aims to improve solution's performance by replacing linear search for next color with searching in RB tree. While improving computational performance, it imposes increased memory cost of the solution. Łukasz Daniluk (3): mm: move free_list selection to dedicated functions mm: Add page colored allocation path mm: Add helper rbtree to search for next cache color Documentation/admin-guide/kernel-parameters.txt | 8 + include/linux/mmzone.h | 12 +- mm/compaction.c | 4 +- mm/page_alloc.c | 381 ++++++++++++++++++++++-- mm/vmstat.c | 10 +- 5 files changed, 383 insertions(+), 32 deletions(-) -- 2.13.3 -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>