Use GFP_KERNEL_ACCOUNT for userspace persistent allocations.
The GFP_KERNEL_ACCOUNT option lets the memory allocator know that this
is untrusted allocation triggered from userspace and should be a subject
of kmem accounting, and as such it is controlled by the cgroup
mechanism.
Signed-off-by: Yishai Hadas <yishaih@nvidia.com>
Reviewed-by: Jason Gunthorpe <jgg@nvidia.com>
Link: https://lore.kernel.org/r/20230108154427.32609-6-yishaih@nvidia.com
Signed-off-by: Alex Williamson <alex.williamson@redhat.com>
        int i;
 
        vdev->regions = kcalloc(count, sizeof(struct vfio_fsl_mc_region),
-                               GFP_KERNEL);
+                               GFP_KERNEL_ACCOUNT);
        if (!vdev->regions)
                return -ENOMEM;
 
 
 
        irq_count = mc_dev->obj_desc.irq_count;
 
-       mc_irq = kcalloc(irq_count, sizeof(*mc_irq), GFP_KERNEL);
+       mc_irq = kcalloc(irq_count, sizeof(*mc_irq), GFP_KERNEL_ACCOUNT);
        if (!mc_irq)
                return -ENOMEM;
 
        if (fd < 0) /* Disable only */
                return 0;
 
-       irq->name = kasprintf(GFP_KERNEL, "vfio-irq[%d](%s)",
+       irq->name = kasprintf(GFP_KERNEL_ACCOUNT, "vfio-irq[%d](%s)",
                            hwirq, dev_name(&vdev->mc_dev->dev));
        if (!irq->name)
                return -ENOMEM;