|
@@ -5466,30 +5466,34 @@ static void mmu_destroy_caches(void)
|
|
|
|
|
|
int kvm_mmu_module_init(void)
|
|
|
{
|
|
|
+ int ret = -ENOMEM;
|
|
|
+
|
|
|
kvm_mmu_clear_all_pte_masks();
|
|
|
|
|
|
pte_list_desc_cache = kmem_cache_create("pte_list_desc",
|
|
|
sizeof(struct pte_list_desc),
|
|
|
0, SLAB_ACCOUNT, NULL);
|
|
|
if (!pte_list_desc_cache)
|
|
|
- goto nomem;
|
|
|
+ goto out;
|
|
|
|
|
|
mmu_page_header_cache = kmem_cache_create("kvm_mmu_page_header",
|
|
|
sizeof(struct kvm_mmu_page),
|
|
|
0, SLAB_ACCOUNT, NULL);
|
|
|
if (!mmu_page_header_cache)
|
|
|
- goto nomem;
|
|
|
+ goto out;
|
|
|
|
|
|
if (percpu_counter_init(&kvm_total_used_mmu_pages, 0, GFP_KERNEL))
|
|
|
- goto nomem;
|
|
|
+ goto out;
|
|
|
|
|
|
- register_shrinker(&mmu_shrinker);
|
|
|
+ ret = register_shrinker(&mmu_shrinker);
|
|
|
+ if (ret)
|
|
|
+ goto out;
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
-nomem:
|
|
|
+out:
|
|
|
mmu_destroy_caches();
|
|
|
- return -ENOMEM;
|
|
|
+ return ret;
|
|
|
}
|
|
|
|
|
|
/*
|