return alloc_migrate_hugetlb_folio(h, gfp_mask, preferred_nid, nmask);
 }
 
+static nodemask_t *policy_mbind_nodemask(gfp_t gfp)
+{
+#ifdef CONFIG_NUMA
+       struct mempolicy *mpol = get_task_policy(current);
+
+       /*
+        * Only enforce MPOL_BIND policy which overlaps with cpuset policy
+        * (from policy_nodemask) specifically for hugetlb case
+        */
+       if (mpol->mode == MPOL_BIND &&
+               (apply_policy_zone(mpol, gfp_zone(gfp)) &&
+                cpuset_nodemask_valid_mems_allowed(&mpol->nodes)))
+               return &mpol->nodes;
+#endif
+       return NULL;
+}
+
 /*
  * Increase the hugetlb pool such that it can accommodate a reservation
  * of size 'delta'.
        long i;
        long needed, allocated;
        bool alloc_ok = true;
+       int node;
+       nodemask_t *mbind_nodemask = policy_mbind_nodemask(htlb_alloc_mask(h));
 
        lockdep_assert_held(&hugetlb_lock);
        needed = (h->resv_huge_pages + delta) - h->free_huge_pages;
 retry:
        spin_unlock_irq(&hugetlb_lock);
        for (i = 0; i < needed; i++) {
-               folio = alloc_surplus_hugetlb_folio(h, htlb_alloc_mask(h),
-                               NUMA_NO_NODE, NULL);
+               folio = NULL;
+               for_each_node_mask(node, cpuset_current_mems_allowed) {
+                       if (!mbind_nodemask || node_isset(node, *mbind_nodemask)) {
+                               folio = alloc_surplus_hugetlb_folio(h, htlb_alloc_mask(h),
+                                               node, NULL);
+                               if (folio)
+                                       break;
+                       }
+               }
                if (!folio) {
                        alloc_ok = false;
                        break;
 }
 __setup("default_hugepagesz=", default_hugepagesz_setup);
 
-static nodemask_t *policy_mbind_nodemask(gfp_t gfp)
-{
-#ifdef CONFIG_NUMA
-       struct mempolicy *mpol = get_task_policy(current);
-
-       /*
-        * Only enforce MPOL_BIND policy which overlaps with cpuset policy
-        * (from policy_nodemask) specifically for hugetlb case
-        */
-       if (mpol->mode == MPOL_BIND &&
-               (apply_policy_zone(mpol, gfp_zone(gfp)) &&
-                cpuset_nodemask_valid_mems_allowed(&mpol->nodes)))
-               return &mpol->nodes;
-#endif
-       return NULL;
-}
-
 static unsigned int allowed_mems_nr(struct hstate *h)
 {
        int node;