}
 EXPORT_SYMBOL_GPL(stack_depot_init);
 
-static bool depot_init_pool(void **prealloc)
+static void depot_init_pool(void **prealloc)
 {
-       if (!*prealloc)
-               return false;
        /*
         * This smp_load_acquire() pairs with smp_store_release() to
         * |next_pool_inited| below and in depot_alloc_stack().
         */
        if (smp_load_acquire(&next_pool_inited))
-               return true;
+               return;
        if (stack_pools[pool_index] == NULL) {
                stack_pools[pool_index] = *prealloc;
                *prealloc = NULL;
                 */
                smp_store_release(&next_pool_inited, 1);
        }
-       return true;
 }
 
 /* Allocation of a new stack in raw storage */
                if (pool_index + 1 < DEPOT_MAX_POOLS)
                        smp_store_release(&next_pool_inited, 0);
        }
-       depot_init_pool(prealloc);
+       if (*prealloc)
+               depot_init_pool(prealloc);
        if (stack_pools[pool_index] == NULL)
                return NULL;
 
                 * We didn't need to store this stack trace, but let's keep
                 * the preallocated memory for the future.
                 */
-               WARN_ON(!depot_init_pool(&prealloc));
+               depot_init_pool(&prealloc);
        }
 
        raw_spin_unlock_irqrestore(&pool_lock, flags);