<div dir="ltr"><div>Daniel,</div><div><br></div>I agree. <span style="font-size:12.8px">GLX_OML_sync_control fulfils all our requirements apart from being available for EGL. It would be great to have it available for EGL. In regard to Wayland this is really important. For the time being Kodi stopped supporting Wayland because a/v sync is not possible on that platform.</span><div><span style="font-size:12.8px"><br></span></div><div><span style="font-size:12.8px">Rainer</span></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Jun 16, 2016 at 6:17 PM, Daniel Vetter <span dir="ltr"><<a href="mailto:daniel.vetter@ffwll.ch" target="_blank">daniel.vetter@ffwll.ch</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">On Thu, Jun 16, 2016 at 3:02 PM, Rainer Hochecker <<a href="mailto:fernetmenta@kodi.tv">fernetmenta@kodi.tv</a>> wrote:<br>
> Daniel,<br>
><br>
> Peter posted me some snippets about your discussion around vblank that<br>
> confused me. Our use case is as follows:<br>
> We synchronise our video player clock to the pace of the display. Assume we<br>
> play some 23.976 content and the actual refresh rate is 24hz. We increment<br>
> the clock every vblank, that makes the clock run faster. Audio is resampled<br>
> to the faster running clock.<br>
> For this we just need an event fired for vblank.<br>
><br>
> Another requirement not directly related to 1)<br>
> We would like to know when a frame in actually presented on screen. Now this<br>
> is only guessing.<br>
<br>
<br>
</span>If you do vblank support right (which means GLX_OML_sync_control, it<br>
should work on mesa/glx but not anywhere else unfortunately) you get<br>
both. That's what I mean with calling the vblank ioctl directly is a<br>
hack: It's only really one half of correctly done a/v sync, you get<br>
the clock source but still have no idea when the frames actually show<br>
up. GLX_OML_sync_control (and a port to EGL/wayland, if someone<br>
bothers with that) gives you that control, plus ofc still a clock<br>
source which is as accurate as the current one (since it's the same).<br>
<br>
Note that DRI2/DRI3 and wayland all support this already, it's just a<br>
matter of wiring it up as an EGL extension. And of course it won't<br>
work on nvidia blobs because they just suck at this and don't want to<br>
let apps control all the double/triple buffering and whatever else<br>
they have in their driver.<br>
<br>
Note that the only reason this works on mesa is because Mario Kleiner<br>
really cares about it, and fixed up all the bugs across the entire<br>
stack (meas, X, kernel drivers). Mario might be interested in an EGL<br>
version of all this, not sure. Adding him.<br>
<br>
Oh and: Please feel free to add other video players and folks<br>
interested in this, I don't know them really at all.<br>
<br>
Cheers, Daniel<br>
<div class="HOEnZb"><div class="h5"><br>
><br>
> Rainer<br>
><br>
> On Wed, Jun 15, 2016 at 10:57 AM, Daniel Vetter <<a href="mailto:daniel.vetter@ffwll.ch">daniel.vetter@ffwll.ch</a>><br>
> wrote:<br>
>><br>
>> On Wed, Jun 15, 2016 at 9:29 AM, Michel Dänzer <<a href="mailto:michel@daenzer.net">michel@daenzer.net</a>> wrote:<br>
>> > On 14.06.2016 18:35, Daniel Vetter wrote:<br>
>> >> On Tue, Jun 14, 2016 at 11:09 AM, Michel Dänzer <<a href="mailto:michel@daenzer.net">michel@daenzer.net</a>><br>
>> >> wrote:<br>
>> >>> On 14.06.2016 18:03, Daniel Vetter wrote:<br>
>> >>>> Somehow this escaped us, this is a KMS ioctl which should only be<br>
>> >>>> used<br>
>> >>>> by the master (which is the thing that's also in control of kms<br>
>> >>>> resources). Everything else is bound to result in fail.<br>
>> >>>><br>
>> >>>> Clients shouldn't have a trouble coping with this, since a pile of<br>
>> >>>> drivers don't support vblank waits (or just randomly fall over when<br>
>> >>>> using them). Note that the big motivation for abusing this like mad<br>
>> >>>> seems to be that EGL doesn't have OML_sync, but somehow it didn't<br>
>> >>>> cross anyone's mind that adding OML_sync to EGL would be useful.<br>
>> >>><br>
>> >>> That may be one motivation, but it's certainly not the only one.<br>
>> >>> DRM_IOCTL_WAIT_VBLANK is used by apps which don't use EGL or any<br>
>> >>> similar<br>
>> >>> API at all.<br>
>> >><br>
>> >> Hm, what else?<br>
>> ><br>
>> > Off the top of my head, I know specifically about compton and xfwm4.<br>
>> > There's certainly more.<br>
>><br>
>> But do they anything more fancy than what could be achieved with<br>
>> OML_sync too? Or is the issue that they don't want to use EGL/GLX? In<br>
>> that case I think it's reasonable to ask them to use bare-metal<br>
>> Present, since that's not any less portable than using the vblank<br>
>> ioctl.<br>
>><br>
>> > Note that as I mentioned before in the other thread, I absolutely agree<br>
>> > that DRM_IOCTL_WAIT_VBLANK isn't supposed to be used directly. But the<br>
>> > fact of the matter is that it is being used like that (possibly has been<br>
>> > since before the DRM master concept even existed), and presumably it<br>
>> > actually works with simple setups (which might be the majority). So<br>
>> > there might be some backlash if it suddenly stops working.<br>
>><br>
>> Fully agreed. Hence just RFC, and yes we need to get the EGL extension<br>
>> in place first, and at least kick most of the popular apps to have<br>
>> their code ready, and wait a bit, and wait some more, before we can<br>
>> nuke the ioctl from the kernel for non-master. It'll probably take 5<br>
>> years if we're fast :( I do think that we should be ok with breaking<br>
>> the last few hold-outs, but we definitely need to have an alternate<br>
>> solution for EGL ready. Hence why I want to know whether there's<br>
>> anyone who's using this outside of EGL.<br>
>><br>
>> Really this was just drive-by that I spotted while looking around at<br>
>> stuff for our other discussion around vblanks.<br>
>> -Daniel<br>
>> --<br>
>> Daniel Vetter<br>
>> Software Engineer, Intel Corporation<br>
>> <a href="tel:%2B41%20%280%29%2079%20365%2057%2048" value="+41793655748">+41 (0) 79 365 57 48</a> - <a href="http://blog.ffwll.ch" rel="noreferrer" target="_blank">http://blog.ffwll.ch</a><br>
><br>
><br>
<br>
<br>
<br>
--<br>
Daniel Vetter<br>
Software Engineer, Intel Corporation<br>
<a href="tel:%2B41%20%280%29%2079%20365%2057%2048" value="+41793655748">+41 (0) 79 365 57 48</a> - <a href="http://blog.ffwll.ch" rel="noreferrer" target="_blank">http://blog.ffwll.ch</a><br>
</div></div></blockquote></div><br></div>