Our 'struct domain' has when lock profiling is enabled is bigger than
one page.
We can't use vmap nor vzalloc as both of those stash the
physical address in struct page which makes the assumptions
in 'arch_init_memory' trip over ASSERTs.
Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Signed-off-by: David Vrabel <david.vrabel@citrix.com>
struct domain *alloc_domain_struct(void)
{
struct domain *d;
+ unsigned int order = get_order_from_bytes(sizeof(*d));
#ifdef CONFIG_BIGMEM
const unsigned int bits = 0;
#else
bits = _domain_struct_bits();
#endif
+
+#ifndef LOCK_PROFILE
BUILD_BUG_ON(sizeof(*d) > PAGE_SIZE);
- d = alloc_xenheap_pages(0, MEMF_bits(bits));
+#endif
+ d = alloc_xenheap_pages(order, MEMF_bits(bits));
if ( d != NULL )
- clear_page(d);
+ {
+ unsigned int sz;
+
+ for ( sz = 0; sz < (PAGE_SIZE << order); sz += PAGE_SIZE )
+ clear_page((void *)d + sz);
+ }
return d;
}