return net_eq(nf_ct_net(i), data);
 }
 
-void nf_ct_free_hashtable(void *hash, unsigned int size)
-{
-       if (is_vmalloc_addr(hash))
-               vfree(hash);
-       else
-               free_pages((unsigned long)hash,
-                          get_order(sizeof(struct hlist_head) * size));
-}
-EXPORT_SYMBOL_GPL(nf_ct_free_hashtable);
-
 void nf_conntrack_cleanup_start(void)
 {
        conntrack_gc_work.exiting = true;
 {
        RCU_INIT_POINTER(nf_ct_hook, NULL);
        cancel_delayed_work_sync(&conntrack_gc_work.dwork);
-       nf_ct_free_hashtable(nf_conntrack_hash, nf_conntrack_htable_size);
+       kvfree(nf_conntrack_hash);
 
        nf_conntrack_proto_fini();
        nf_conntrack_seqadj_fini();
 {
        struct hlist_nulls_head *hash;
        unsigned int nr_slots, i;
-       size_t sz;
 
        if (*sizep > (UINT_MAX / sizeof(struct hlist_nulls_head)))
                return NULL;
        BUILD_BUG_ON(sizeof(struct hlist_nulls_head) != sizeof(struct hlist_head));
        nr_slots = *sizep = roundup(*sizep, PAGE_SIZE / sizeof(struct hlist_nulls_head));
 
-       if (nr_slots > (UINT_MAX / sizeof(struct hlist_nulls_head)))
-               return NULL;
-
-       sz = nr_slots * sizeof(struct hlist_nulls_head);
-       hash = (void *)__get_free_pages(GFP_KERNEL | __GFP_NOWARN | __GFP_ZERO,
-                                       get_order(sz));
-       if (!hash)
-               hash = vzalloc(sz);
+       hash = kvmalloc_array(nr_slots, sizeof(struct hlist_nulls_head),
+                             GFP_KERNEL | __GFP_ZERO);
 
        if (hash && nulls)
                for (i = 0; i < nr_slots; i++)
 
        old_size = nf_conntrack_htable_size;
        if (old_size == hashsize) {
-               nf_ct_free_hashtable(hash, hashsize);
+               kvfree(hash);
                return 0;
        }
 
        local_bh_enable();
 
        synchronize_net();
-       nf_ct_free_hashtable(old_hash, old_size);
+       kvfree(old_hash);
        return 0;
 }
 
 err_expect:
        kmem_cache_destroy(nf_conntrack_cachep);
 err_cachep:
-       nf_ct_free_hashtable(nf_conntrack_hash, nf_conntrack_htable_size);
+       kvfree(nf_conntrack_hash);
        return ret;
 }
 
 
 
        ret = nf_ct_extend_register(&nat_extend);
        if (ret < 0) {
-               nf_ct_free_hashtable(nf_nat_bysource, nf_nat_htable_size);
+               kvfree(nf_nat_bysource);
                pr_err("Unable to register extension\n");
                return ret;
        }
        for (i = 0; i < NFPROTO_NUMPROTO; i++)
                kfree(nf_nat_l4protos[i]);
        synchronize_net();
-       nf_ct_free_hashtable(nf_nat_bysource, nf_nat_htable_size);
+       kvfree(nf_nat_bysource);
        unregister_pernet_subsys(&nat_net_ops);
 }