Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit caeab084 authored by Christoph Lameter's avatar Christoph Lameter
Browse files

slub page alloc fallback: Enable interrupts for GFP_WAIT.



The fallback path needs to enable interrupts like done for
the other page allocator calls. This was not necessary with
the alternate fast path since we handled irq enable/disable in
the slow path. The regular fastpath handles irq enable/disable
around calls to the slow path so we need to restore the proper
status before calling the page allocator from the slowpath.

Signed-off-by: default avatarChristoph Lameter <clameter@sgi.com>
parent bde4f8fa
Loading
Loading
Loading
Loading
+9 −3
Original line number Diff line number Diff line
@@ -1536,9 +1536,15 @@ static void *__slab_alloc(struct kmem_cache *s,
	 * That is only possible if certain conditions are met that are being
	 * checked when a slab is created.
	 */
	if (!(gfpflags & __GFP_NORETRY) && (s->flags & __PAGE_ALLOC_FALLBACK))
		return kmalloc_large(s->objsize, gfpflags);

	if (!(gfpflags & __GFP_NORETRY) &&
				(s->flags & __PAGE_ALLOC_FALLBACK)) {
		if (gfpflags & __GFP_WAIT)
			local_irq_enable();
		object = kmalloc_large(s->objsize, gfpflags);
		if (gfpflags & __GFP_WAIT)
			local_irq_disable();
		return object;
	}
	return NULL;
debug:
	if (!alloc_debug_processing(s, c->page, object, addr))