Hello, On Wed, Jul 27, 2016 at 01:33:35PM +0300, Kirill A. Shutemov wrote: > I guess you can get work 64k blocks with 4k pages if you *always* allocate > order-4 pages for page cache of the filesystem. But I don't think it's > sustainable. It's significant pressure on buddy allocator and compaction. Agreed. To guarantee compaction to succeed for a certain percentage of the RAM kernelcore= would need to be used, but the bigger the movable zone is, the bigger the imbalance will be, because the memory used by the kernel cannot use the RAM that is in the movable zone. If the movable zone is too big, early OOM failures may materialize where the kernel hits OOM despite there's plenty of free memory in the movable zone. So it's not ideal. > I guess the right approach would a mechanism to scatter one block to > multiple order-0 pages. At least for fallback. That would be ideal to avoid having to mess with kernelcore=, because no matter what direct compaction does (and current direction compaction defaults wouldn't be aggressive enough anyway), without kernelcore= the THP (or order4) allocation can fail at times. THP always requires a fallback so that a compaction failure isn't fatal and it can actually be fixed up later by khugepaged as more free memory becomes available at runtime. Thanks, Andrea -- 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>