On Wed, Jul 23, 2014 at 10:03 AM, Peter Zijlstra <pet...@infradead.org> wrote: > On Wed, Jul 23, 2014 at 09:54:23AM -0700, Linus Torvalds wrote: >> >> And I wonder if I have a clue. Look, load_balance_mask is a >> "cpumask_var_t", but I don't see a "alloc_cpumask_var()" for it. >> That's broken with CONFIG_CPUMASK_OFFSTACK. > > kernel/sched/core.c:sched_init() > > plays horrible allocation tricks..
No it does not. It allocates a cpumask. Nothing more. If you think it allocates a "cpumask_var()", you are wrong. I agree that the code is an unreadable mess, but that's what "cpumask_size()" is: the minimum required size of the bitmask in a cpumask. A cpumask_var is TOTALLY DIFFERENT. It's *either* a cpumask _or_ just a pointer to an externally allocated cpumask. sched_init() definitely does _not_ allocate a cpumask_var. Linus -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/