Den 21.11.2022 13.41, skrev Thomas Zimmermann: > Hi > > Am 21.11.22 um 13:27 schrieb Noralf Trønnes: >> >> >> Den 21.11.2022 11.45, skrev Thomas Zimmermann: >>> Convert the MIPI-DBI-based drivers to shadow-plane helpers. The >>> drivers vmap/vunmap GEM buffer memory during the atomic commit. >>> Shadow-plane helpers automate this process. >>> >>> Patches 1 to 4 prepare the MIPI code for the change and simplify >>> the restof the patchset. >>> >>> Patches 5 to 7 rework the vmap code in the MIPI-DBI drivers and add >>> shadow-plane helpers. Most of the affected drivers call MIPI-DBI >>> helpers and get the update automatically. Only ili9225 and st7586 >>> require changes to their source code. >>> >>> Patch 8 simplifies drm_dev_enter() and _exit(). It's not strictly >>> needed, but streamlines the driver code and make sense overall. >>> >>> Testing is welcome, as I don't have any hardware to test these >>> changes myself. >>> >> >> I can do a test this weekend. > > Thanks a lot. > >> >> Btw I've converted drm/gud to the shadow plane helper, I just need to >> solve an smtp problem[1] so I can send out the patchset. > > How so? When I looked at it, the vmap/vunmap happened on a separate > worker than the commit IIRC. > Yes you're right, originally the driver only did flushing asynchronously in a worker which meant it could access the framebuffer at the same time as userspace. Later when GNOME got support for one rendering loop per display, I added a module parameter to enable synchronous flushing during the commit, it also uses the worker for this but waits for it to complete. What I've done in the patchset is to inline the sync flushing and use a shadow buffer for the async path which still uses the worker, but now it won't risk reading the framebuffer while userspace writes to it, instead it reads from the shadow buffer. Noralf. > Best regards > Thomas > >> >> [1] >> https://lore.kernel.org/dri-devel/1bc45775-0667-01f8-36e1-9f65d3081092@xxxxxxxxxxx/T/#u >> >> Noralf. >