> Hi, 
> 
> The following patch addresses two issues:
> 
> 
> - Buffer cache pages in the inactive lists are not getting their age
> increased if they get touched by getblk (which will set the referenced bit
> on the page).  page_launder() simply cleans the referenced bit on such
> pages and moves them to the active list. To resume: buffercache pages
> suffer more pressure from VM than pagecache pages. That is horrible for
> performance.
> 
> 
> - When there is no memory available on the system for normal allocations
> (GFP_KERNEL), the tasks may loop in try_to_free_pages() (which is here
> called by __alloc_pages()) without blocking:
> 
> 	- GFP_BUFFER allocations will _never_ block on IO inside
> 	try_to_free_pages(). They will keep looping inside __alloc_pages() 
> 	until they get a free page. 
> 	
> 	- __GFP_IO|__GFP_WAIT allocations may not find any way to block on
> 	IO inside try_to_free_pages() in case we already have other tasks
> 	inside there (kswapd will be there in such condition, for sure).
Ah, one subtle issue here: if they loop, they'll probably bump
memory_pressure a lot.  
That will result in a bigger inactive target, which means aggressive
aging. 
 
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/