summaryrefslogtreecommitdiffstats
path: root/drivers/memstick
diff options
context:
space:
mode:
authorMaíra Canal <mcanal@igalia.com>2023-05-23 09:32:08 -0300
committerMaíra Canal <mairacanal@riseup.net>2023-07-27 20:32:50 -0300
commita0e6a017ab56936c0405fe914a793b241ed25ee0 (patch)
tree60450645d132b8c64bef8b4d1896293481dda54c /drivers/memstick
parentdb1f254f2cfaf0510ae34fa2311a8d749e95179a (diff)
downloadlinux-stable-a0e6a017ab56936c0405fe914a793b241ed25ee0.tar.gz
linux-stable-a0e6a017ab56936c0405fe914a793b241ed25ee0.tar.bz2
linux-stable-a0e6a017ab56936c0405fe914a793b241ed25ee0.zip
drm/vkms: Fix race-condition between the hrtimer and the atomic commit
Currently, it is possible for the composer to be set as enabled and then as disabled without a proper call for the vkms_vblank_simulate(). This is problematic, because the driver would skip one CRC output, causing CRC tests to fail. Therefore, we need to make sure that, for each time the composer is set as enabled, a composer job is added to the queue. In order to provide this guarantee, add a mutex that will lock before the composer is set as enabled and will unlock only after the composer job is added to the queue. This way, we can have a guarantee that the driver won't skip a CRC entry. This race-condition is affecting the IGT test "writeback-check-output", making the test fail and also, leaking writeback framebuffers, as the writeback job is queued, but it is not signaled. This patch avoids both problems. [v2]: * Create a new mutex and keep the spinlock across the atomic commit in order to avoid interrupts that could result in deadlocks. Signed-off-by: Maíra Canal <mcanal@igalia.com> Reviewed-by: Arthur Grillo <arthurgrillo@riseup.net> Signed-off-by: Maíra Canal <mairacanal@riseup.net> Link: https://patchwork.freedesktop.org/patch/msgid/20230523123207.173976-1-mcanal@igalia.com
Diffstat (limited to 'drivers/memstick')
0 files changed, 0 insertions, 0 deletions