| .. _gfp_mask_from_fs_io: | 
 |  | 
 | ================================= | 
 | GFP masks used from FS/IO context | 
 | ================================= | 
 |  | 
 | :Date: May, 2018 | 
 | :Author: Michal Hocko <mhocko@kernel.org> | 
 |  | 
 | Introduction | 
 | ============ | 
 |  | 
 | Code paths in the filesystem and IO stacks must be careful when | 
 | allocating memory to prevent recursion deadlocks caused by direct | 
 | memory reclaim calling back into the FS or IO paths and blocking on | 
 | already held resources (e.g. locks - most commonly those used for the | 
 | transaction context). | 
 |  | 
 | The traditional way to avoid this deadlock problem is to clear __GFP_FS | 
 | respectively __GFP_IO (note the latter implies clearing the first as well) in | 
 | the gfp mask when calling an allocator. GFP_NOFS respectively GFP_NOIO can be | 
 | used as shortcut. It turned out though that above approach has led to | 
 | abuses when the restricted gfp mask is used "just in case" without a | 
 | deeper consideration which leads to problems because an excessive use | 
 | of GFP_NOFS/GFP_NOIO can lead to memory over-reclaim or other memory | 
 | reclaim issues. | 
 |  | 
 | New API | 
 | ======== | 
 |  | 
 | Since 4.12 we do have a generic scope API for both NOFS and NOIO context | 
 | ``memalloc_nofs_save``, ``memalloc_nofs_restore`` respectively ``memalloc_noio_save``, | 
 | ``memalloc_noio_restore`` which allow to mark a scope to be a critical | 
 | section from a filesystem or I/O point of view. Any allocation from that | 
 | scope will inherently drop __GFP_FS respectively __GFP_IO from the given | 
 | mask so no memory allocation can recurse back in the FS/IO. | 
 |  | 
 | .. kernel-doc:: include/linux/sched/mm.h | 
 |    :functions: memalloc_nofs_save memalloc_nofs_restore | 
 | .. kernel-doc:: include/linux/sched/mm.h | 
 |    :functions: memalloc_noio_save memalloc_noio_restore | 
 |  | 
 | FS/IO code then simply calls the appropriate save function before | 
 | any critical section with respect to the reclaim is started - e.g. | 
 | lock shared with the reclaim context or when a transaction context | 
 | nesting would be possible via reclaim. The restore function should be | 
 | called when the critical section ends. All that ideally along with an | 
 | explanation what is the reclaim context for easier maintenance. | 
 |  | 
 | Please note that the proper pairing of save/restore functions | 
 | allows nesting so it is safe to call ``memalloc_noio_save`` or | 
 | ``memalloc_noio_restore`` respectively from an existing NOIO or NOFS | 
 | scope. | 
 |  | 
 | What about __vmalloc(GFP_NOFS) | 
 | ============================== | 
 |  | 
 | vmalloc doesn't support GFP_NOFS semantic because there are hardcoded | 
 | GFP_KERNEL allocations deep inside the allocator which are quite non-trivial | 
 | to fix up. That means that calling ``vmalloc`` with GFP_NOFS/GFP_NOIO is | 
 | almost always a bug. The good news is that the NOFS/NOIO semantic can be | 
 | achieved by the scope API. | 
 |  | 
 | In the ideal world, upper layers should already mark dangerous contexts | 
 | and so no special care is required and vmalloc should be called without | 
 | any problems. Sometimes if the context is not really clear or there are | 
 | layering violations then the recommended way around that is to wrap ``vmalloc`` | 
 | by the scope API with a comment explaining the problem. |