diff options
| author | Vlastimil Babka <vbabka@suse.cz> | 2021-05-08 02:28:02 +0200 | 
|---|---|---|
| committer | Vlastimil Babka <vbabka@suse.cz> | 2021-09-04 01:12:21 +0200 | 
| commit | 0b303fb402862dcb7948eeeed2439bd8c99948b5 (patch) | |
| tree | cf582cf0547f8120a341b4e56cda547e0fac0d1d /lib/dump_stack.c | |
| parent | e500059ba55268e1c5212632e4f21e45f54dc6d9 (diff) | |
mm, slub: do initial checks in ___slab_alloc() with irqs enabled
As another step of shortening irq disabled sections in ___slab_alloc(), delay
disabling irqs until we pass the initial checks if there is a cached percpu
slab and it's suitable for our allocation.
Now we have to recheck c->page after actually disabling irqs as an allocation
in irq handler might have replaced it.
Because we call pfmemalloc_match() as one of the checks, we might hit
VM_BUG_ON_PAGE(!PageSlab(page)) in PageSlabPfmemalloc in case we get
interrupted and the page is freed. Thus introduce a pfmemalloc_match_unsafe()
variant that lacks the PageSlab check.
Signed-off-by: Vlastimil Babka <vbabka@suse.cz>
Acked-by: Mel Gorman <mgorman@techsingularity.net>
Diffstat (limited to 'lib/dump_stack.c')
0 files changed, 0 insertions, 0 deletions
