diff options
author | Lyude Paul <lyude@redhat.com> | 2020-08-26 21:24:48 +0300 |
---|---|---|
committer | Lyude Paul <lyude@redhat.com> | 2020-09-01 02:10:08 +0300 |
commit | d297ce4b5d490eab60bede36bfd5da6fbcd416cf (patch) | |
tree | 7bef3320d1ad9505e4fa7d297283b08895307029 /include/drm/drm_dp_helper.h | |
parent | 02bb7fe2d3eacb5ca1cec597ad16eff93ae8d769 (diff) | |
download | linux-d297ce4b5d490eab60bede36bfd5da6fbcd416cf.tar.xz |
drm/nouveau/kms: Only use hpd_work for reprobing in HPD paths
Currently we perform both short IRQ handling for DP, and connector
reprobing in the HPD IRQ handler. However since we need to grab
connection_mutex in order to reprobe a connector, in theory we could
accidentally block ourselves from handling any short IRQs until after a
modeset completes if a connector hotplug happens to occur in parallel
with a modeset.
I haven't seen this actually happen yet, but since we're cleaning up
nouveau's hotplug handling code anyway and we already have a hpd worker,
we can simply fix this by only relying on the HPD worker to actually
reprobe connectors when we receive a HPD IRQ. We also add a mask to
nouveau_drm to keep track of which connectors are waiting to be reprobed
in response to an HPD IRQ.
Signed-off-by: Lyude Paul <lyude@redhat.com>
Reviewed-by: Ben Skeggs <bskeggs@redhat.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20200826182456.322681-13-lyude@redhat.com
Diffstat (limited to 'include/drm/drm_dp_helper.h')
0 files changed, 0 insertions, 0 deletions