Re: framebuffer corruption due to overlapping stp instructions on arm64
From: Ard Biesheuvel
Date: Tue Aug 07 2018 - 10:40:43 EST
On 7 August 2018 at 16:14, Mikulas Patocka <mpatocka@xxxxxxxxxx> wrote:
>
>
> On Mon, 6 Aug 2018, Ard Biesheuvel wrote:
>
>> No that works fine for me. VDPAU acceleration works as well, but it
>> depends on your chromium build whether it can actually use it, I
>> think? In any case, mplayer can use vdpau to play 1080p h264 without
>> breaking a sweat on this system.
>>
>> Note that the VDPAU driver also relies on memory semantics, i.e., it
>> may use DC ZVA (zero cacheline) instructions which are not permitted
>> on device mappings. This is probably just glibc's memset() being
>> invoked, but I remember hitting this on another PCIe-impaired arm64
>> system with Synopsys PCIe IP
>
> DC ZVA can be disabled with the SCTRL_EL1.DZE bit, so that neither kernel
> nor userspace will use it.
Of course, but only the OS can do that, and only system wide unless
we're eager to create infrastructure for managing this per process.
But it is also beside the point: I mentioned it to illustrate that
even use cases like libvdpau that don't operate on the 'framebuffer'
abstraction make assumptions about VRAM having true memory semantics.
> If the mapping didn't support unaligned writes,
> it would be worse.
>
> Mikulas