Le 03/11/2025 à 18:45, Marius Vlad a écrit :
vkms is missing any kind of HPD (polling/irq), so add polling to handle
hotplug events.

Hi,

I am a bit surprised by this addition, we currently have hotplug/unplug in VKMS using configFS, and it seems to work. The current "irq" system is writing in configFS the status and call drm_kms_helper_hotplug_event after the status is updated [1].

I think the polling will not work, I read in the drm_kms_helper_poll_init documentation that the connector is not polled if some connector flags are not set [2]/[3].

If the polling works, I don't think it will be enough for the current VKMS implementation. Currently setting status using configFS will do everything synchronously: - Set the connector status (next call to connector->detect will have the new value)
- Call drm_kms_helper_hotplug_event

With your implementation, I think you expect something to update connector->status_changed in between, using polling if I understood correctly, which will probably happen after the call to drm_kms_helper_hotplug_event.

[1]:https://gitlab.freedesktop.org/drm/misc/kernel/-/blob/drm-misc-next/drivers/gpu/drm/vkms/vkms_connector.c?ref_type=heads#L91-96
[2]:https://elixir.bootlin.com/linux/v6.17.7/source/drivers/gpu/drm/drm_probe_helper.c#L917-L918
[3]:https://elixir.bootlin.com/linux/v6.17.7/source/drivers/gpu/drm/drm_probe_helper.c#L793

Signed-off-by: Marius Vlad <[email protected]>
---
  drivers/gpu/drm/vkms/vkms_drv.c | 4 ++++
  1 file changed, 4 insertions(+)

diff --git a/drivers/gpu/drm/vkms/vkms_drv.c b/drivers/gpu/drm/vkms/vkms_drv.c
index e8472d9b6e3b..ec815c42ef04 100644
--- a/drivers/gpu/drm/vkms/vkms_drv.c
+++ b/drivers/gpu/drm/vkms/vkms_drv.c
@@ -198,6 +198,9 @@ static int vkms_create(struct vkms_config *config)
        if (ret)
                goto out_devres;
+ /* init kms poll for handling hpd */
+       drm_kms_helper_poll_init(&vkms_device->drm);
+
        drm_client_setup(&vkms_device->drm, NULL);
return 0;
@@ -240,6 +243,7 @@ static void vkms_destroy(struct vkms_config *config)
fdev = config->dev->faux_dev; + drm_kms_helper_poll_fini(&config->dev->drm);
        drm_dev_unregister(&config->dev->drm);
        drm_atomic_helper_shutdown(&config->dev->drm);
        devres_release_group(&fdev->dev, NULL);

--
--
Louis Chauvet, Bootlin
Embedded Linux and Kernel engineering
https://bootlin.com

Reply via email to