]> www.infradead.org Git - users/hch/misc.git/commitdiff
drm/xe: defer free of NVM auxiliary container to device release callback
authorNitin Gote <nitin.r.gote@intel.com>
Thu, 11 Sep 2025 05:28:23 +0000 (10:58 +0530)
committerLucas De Marchi <lucas.demarchi@intel.com>
Fri, 12 Sep 2025 19:02:23 +0000 (12:02 -0700)
Do not kfree the intel_dg_nvm_dev in xe_nvm_fini() right after
auxiliary_device_delete/uninit. The auxiliary_device embeds the
device/kobject (and its name); freeing it too early can race
with asynchronous device_del/udev processing and cause a use-after-free.

Signed-off-by: Nitin Gote <nitin.r.gote@intel.com>
Fixes: c28bfb107dac ("drm/xe/nvm: add on-die non-volatile memory device")
Reviewed-by: Lucas De Marchi <lucas.demarchi@intel.com>
Link: https://lore.kernel.org/r/20250911052823.226696-1-nitin.r.gote@intel.com
Signed-off-by: Lucas De Marchi <lucas.demarchi@intel.com>
drivers/gpu/drm/xe/xe_nvm.c

index 9ca4a5ae1693ad7616a5e428f83ee0b9570a220b..33f4ac82fc80ab517ec3732da176d59e15e82d9c 100644 (file)
@@ -35,6 +35,10 @@ static const struct intel_dg_nvm_region regions[INTEL_DG_NVM_REGIONS] = {
 
 static void xe_nvm_release_dev(struct device *dev)
 {
+       struct auxiliary_device *aux = container_of(dev, struct auxiliary_device, dev);
+       struct intel_dg_nvm_dev *nvm = container_of(aux, struct intel_dg_nvm_dev, aux_dev);
+
+       kfree(nvm);
 }
 
 static bool xe_nvm_non_posted_erase(struct xe_device *xe)
@@ -162,6 +166,5 @@ void xe_nvm_fini(struct xe_device *xe)
 
        auxiliary_device_delete(&nvm->aux_dev);
        auxiliary_device_uninit(&nvm->aux_dev);
-       kfree(nvm);
        xe->nvm = NULL;
 }