{
        void *ret = NULL;
        struct ptdesc *ptdesc;
+       gfp_t gfp = PGALLOC_GFP;
 
-       if (!kernel) {
-               ptdesc = pagetable_alloc(PGALLOC_GFP | __GFP_ACCOUNT, 0);
-               if (!ptdesc)
-                       return NULL;
-               if (!pagetable_pte_ctor(mm, ptdesc)) {
-                       pagetable_free(ptdesc);
-                       return NULL;
-               }
-       } else {
-               ptdesc = pagetable_alloc(PGALLOC_GFP, 0);
-               if (!ptdesc)
-                       return NULL;
+       if (!kernel)
+               gfp |= __GFP_ACCOUNT;
+
+       ptdesc = pagetable_alloc(gfp, 0);
+       if (!ptdesc)
+               return NULL;
+       if (!pagetable_pte_ctor(mm, ptdesc)) {
+               pagetable_free(ptdesc);
+               return NULL;
        }
 
        atomic_set(&ptdesc->pt_frag_refcount, 1);
 
        BUG_ON(atomic_read(&ptdesc->pt_frag_refcount) <= 0);
        if (atomic_dec_and_test(&ptdesc->pt_frag_refcount)) {
-               if (kernel)
-                       pagetable_free(ptdesc);
-               else if (folio_test_clear_active(ptdesc_folio(ptdesc)))
-                       call_rcu(&ptdesc->pt_rcu_head, pte_free_now);
-               else
+               if (kernel || !folio_test_clear_active(ptdesc_folio(ptdesc)))
                        pte_free_now(&ptdesc->pt_rcu_head);
+               else
+                       call_rcu(&ptdesc->pt_rcu_head, pte_free_now);
        }
 }