]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
Drivers: hv: vmbus: Fix rescind handling in uio_hv_generic
authorNaman Jain <namjain@linux.microsoft.com>
Thu, 29 Aug 2024 07:13:12 +0000 (12:43 +0530)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 3 Sep 2024 10:37:38 +0000 (12:37 +0200)
Rescind offer handling relies on rescind callbacks for some of the
resources cleanup, if they are registered. It does not unregister
vmbus device for the primary channel closure, when callback is
registered. Without it, next onoffer does not come, rescind flag
remains set and device goes to unusable state.

Add logic to unregister vmbus for the primary channel in rescind callback
to ensure channel removal and relid release, and to ensure that next
onoffer can be received and handled properly.

Cc: stable@vger.kernel.org
Fixes: ca3cda6fcf1e ("uio_hv_generic: add rescind support")
Signed-off-by: Naman Jain <namjain@linux.microsoft.com>
Reviewed-by: Saurabh Sengar <ssengar@linux.microsoft.com>
Link: https://lore.kernel.org/r/20240829071312.1595-3-namjain@linux.microsoft.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/hv/vmbus_drv.c
drivers/uio/uio_hv_generic.c

index c857dc3975be77ab003972f49edfcbbcc77672cc..4bae382a3eb43825b45fbc567c03b784dbd06aa9 100644 (file)
@@ -1952,6 +1952,7 @@ void vmbus_device_unregister(struct hv_device *device_obj)
         */
        device_unregister(&device_obj->device);
 }
+EXPORT_SYMBOL_GPL(vmbus_device_unregister);
 
 #ifdef CONFIG_ACPI
 /*
index e3e66a3e85a813b11dac145bcc6ab162be64f100..8704095994118c2660f345c504b5ea466d053efb 100644 (file)
@@ -121,6 +121,14 @@ static void hv_uio_rescind(struct vmbus_channel *channel)
 
        /* Wake up reader */
        uio_event_notify(&pdata->info);
+
+       /*
+        * With rescind callback registered, rescind path will not unregister the device
+        * from vmbus when the primary channel is rescinded.
+        * Without it, rescind handling is incomplete and next onoffer msg does not come.
+        * Unregister the device from vmbus here.
+        */
+       vmbus_device_unregister(channel->device_obj);
 }
 
 /* Sysfs API to allow mmap of the ring buffers