• Sagi Grimberg's avatar
    mm: move all mmu notifier invocations to be done outside the PT lock · 2ec74c3e
    Sagi Grimberg authored
    In order to allow sleeping during mmu notifier calls, we need to avoid
    invoking them under the page table spinlock.  This patch solves the
    problem by calling invalidate_page notification after releasing the lock
    (but before freeing the page itself), or by wrapping the page invalidation
    with calls to invalidate_range_begin and invalidate_range_end.
    
    To prevent accidental changes to the invalidate_range_end arguments after
    the call to invalidate_range_begin, the patch introduces a convention of
    saving the arguments in consistently named locals:
    
    	unsigned long mmun_start;	/* For mmu_notifiers */
    	unsigned long mmun_end;	/* For mmu_notifiers */
    
    	...
    
    	mmun_start = ...
    	mmun_end = ...
    	mmu_notifier_invalidate_range_start(mm, mmun_start, mmun_end);
    
    	...
    
    	mmu_notifier_invalidate_range_end(mm, mmun_start, mmun_end);
    
    The patch changes code to use this convention for all calls to
    mmu_notifier_invalidate_range_start/end, except those where the...
    2ec74c3e
filemap_xip.c 11.3 KB