return err;
 }
 
-static int __init init_huge_zero_page(void)
+static int init_huge_zero_pfn(void)
 {
        struct page *hpage;
+       unsigned long pfn;
 
        hpage = alloc_pages((GFP_TRANSHUGE | __GFP_ZERO) & ~__GFP_MOVABLE,
                        HPAGE_PMD_ORDER);
        if (!hpage)
                return -ENOMEM;
-
-       huge_zero_pfn = page_to_pfn(hpage);
+       pfn = page_to_pfn(hpage);
+       if (cmpxchg(&huge_zero_pfn, 0, pfn))
+               __free_page(hpage);
        return 0;
 }
 
 static inline bool is_huge_zero_pfn(unsigned long pfn)
 {
-       return pfn == huge_zero_pfn;
+       return huge_zero_pfn && pfn == huge_zero_pfn;
 }
 
 static inline bool is_huge_zero_pmd(pmd_t pmd)
        if (err)
                return err;
 
-       err = init_huge_zero_page();
-       if (err)
-               goto out;
-
        err = khugepaged_slab_init();
        if (err)
                goto out;
 
        return 0;
 out:
-       if (huge_zero_pfn)
-               __free_page(pfn_to_page(huge_zero_pfn));
        hugepage_exit_sysfs(hugepage_kobj);
        return err;
 }
                        return VM_FAULT_OOM;
                if (!(flags & FAULT_FLAG_WRITE)) {
                        pgtable_t pgtable;
+                       if (unlikely(!huge_zero_pfn && init_huge_zero_pfn())) {
+                               count_vm_event(THP_FAULT_FALLBACK);
+                               goto out;
+                       }
                        pgtable = pte_alloc_one(mm, haddr);
                        if (unlikely(!pgtable))
                                return VM_FAULT_OOM;