<div dir="ltr"><div dir="ltr"><br></div><div>Inline..</div><div><br></div><div><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Mon, Jun 1, 2020 at 2:19 PM Pekka Paalanen <<a href="mailto:ppaalanen@gmail.com">ppaalanen@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">On Mon, 1 Jun 2020 09:22:27 +0530<br>
Yogish Kulkarni <<a href="mailto:yogishkulkarni@gmail.com" target="_blank">yogishkulkarni@gmail.com</a>> wrote:<br>
<br>
> Hi,<br>
> <br>
> For letting DRM clients to select output encoding:<br>
> Sink can support certain display timings with high output bit-depths using<br>
> multiple output encodings, e.g. sink can support a particular timing with<br>
> RGB 10-bit, YCbCr422 10-bit and YCbCr420 10-bit. So DRM client may want to<br>
> select YCbCr422 10-bit over RBG 10-bit output to reduce the link bandwidth<br>
> (and in turn reduce power/voltage). If DRM driver automatically selects<br>
> output encoding then we are restricting DRM clients from making appropriate<br>
> choice.<br>
<br>
Hi,<br>
<br>
right, that seems to be another reason.<br>
<br>
> For selectable output color range:<br>
> Certain applications (typically graphics) usually rendered in full range<br>
> while some applications (typically video) have limited range content. Since<br>
> content can change dynamically, DRM driver does not have enough information<br>
> to choose correct quantization. Only DRM client can correctly select which<br>
> quantization to set (to preserve artist's intent).<br>
<br>
Now this is an interesting topic for me. As far as I know, there is no<br>
window system protocol to tell the display server whether the<br>
application provided content is using full or limited range. This means<br>
that the display server cannot tell DRM about full vs. limited range<br>
either. It also means that when not fullscreen, the display server<br>
cannot show the limited range video content correctly, because it would<br>
have to be converted to full-range (or vice versa).<br>
<br></blockquote><div>Right, but there could be DRM client which doesn't use window system (e.g. Gstreamer video sink) and wants to select between full/limited color range. I agree that there is no window system protocol yet but maybe Wayland protocol could be added/extended for this purpose once we finalize things that needs to be done in DRM.<br></div><div></div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
But why would an application produce limited range pixels anyway? Is it<br>
common that hardware video decoders are unable to produce full-range<br>
pixels?<br></blockquote><div><br></div><div>The primary reason for why content producer masters video/gfx content as limited range is for compatibility with sinks which only support limited range, and not because video decoders are not capable of decoding full-range content. Also, certain cinema-related content (e.g., movies) may be better suited for limited range encoding due to the level of detail that they need to present/hide (see "Why does limited RGB even exist?" section in <a href="https://www.benq.com/en-us/knowledge-center/knowledge/full-rgb-vs-limited-rgb-is-there-a-difference.html#:~:text=Full%20RGB%20means%20the%20ability,less%20dark)%20than%20full%20RGB">https://www.benq.com/en-us/knowledge-center/knowledge/full-rgb-vs-limited-rgb-is-there-a-difference.html#:~:text=Full%20RGB%20means%20the%20ability,less%20dark)%20than%20full%20RGB</a>).<br></div><div> <br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
I am asking, because I have a request to add limited vs. full range<br>
information to Wayland.<br>
<br>
What about video sinks, including monitors? Are there devices that<br>
accept limited-range only, full-range only, or switchable?<br></blockquote><div> </div><div>Yes, there are sinks which support selectable quantization range and there are sinks which don't. If the quantization range is not selectable, then in general, sources should output full-range for IT timings, and output limited for CE timings. At a high-level, IT timings are part of a standard developed by VESA for computer monitor-like displays. CE (Consumer Electronics) timings are a separate standard for timings more applicable to sinks like consumer TVs, etc. <br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
Why not just always use full-range everywhere?<br>
<br>
Or if a sink supports only limited-range, have the display chip<br>
automatically convert from full-range, so that software doesn't have to<br>
convert in software.<br></blockquote><div><br></div><div>I think it is ok to convert from limited range to full range in display HW pipeline. By "automatically" if you mean display HW or DRM driver should look at the content to figure out whether it is limited range content and then program display pipeline to do the conversion, I don't think that is a good idea since we would need to inspect each pixel. Also, there may be some post-processing done to full-range content that happens to cause the pixel component values to fall within the limited quantization range. How about adding a new DRM KMS plane property to let client convey the driver about input content range? More details on this below.<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
If you actually have a DRM KMS property for the range, does it mean that:<br>
- the sink is configured to accept that range, and the pixels in the<br>
  framebuffer need to comply, or<br>
- the display chip converts to that range while framebuffer remains in<br>
  full-range?<br></blockquote><div><br></div><div>I would imagine this as:</div><div>(1) Add new read DRM KMS connector property which DRM client will read to know whether sink support selectable quantization range.</div><div>(2) Add new read/write DRM KMS connector property which DRM client will write to set output quantization range and read to know the current output quantization range.</div><div>(3) Add new read/write DRM KMS plane property which DRM client will write to set input quantization range and read to know the current input quantization range.<br></div><div><br></div><div>Now lets say if client has limited range content that it wants to display using limited range, it will perform below steps:</div><div>(A) Set plane's input range property to LIMITED.</div><div>(B) Set connector's output range property to LIMITED.<br></div><div>(C) Read connector property to know whether sink support selectable quantization range:</div><div>       (i) If no, validate HW timing + output range (LIMITED) using atomic test commit, if validation doesn't pass, client should choose another HW timing and revalidate.</div><div>       (ii) if yes, it is not necessary to validate HW timing + output range.</div><div><br></div><div>Now lets say if client has limited range content that it wants to display using full range, it will perform below steps:</div><div>(A) Set plane's input range property to LIMITED</div><div>(B) Set connector's output range property to FULL</div><div>(C) Read connector property to know whether sink support selectable quantization range:</div><div>       (i) if no, validate HW timing + output range (FULL) using atomic test commit, if validation doesn't pass, client should choose another HW timing and revalidate</div><div>       (ii)  if yes, it is not necessary to validate HW timing + output range.</div><div>In this example DRM driver will automatically set up display pipeline to do limited to full-range conversion.<br></div><div></div><div><br></div><div>Out of the three new properties mentioned above there is another choice for property (1): Instead of expecting client to read whether sink support selectable quantization range and perform validations as mentioned above when quantization range is not selectable, how about adding new flags to<span style="font-family:Calibri,Arial,Helvetica,sans-serif;background-color:white"> drmModeModeInfo->flags and let DRM driver to inform client using this flag whether given HW timing is supported with full range, limited range or both? This will avoid validation step mentioned in (C)(i). <br></span></div><div><span style="font-family:Calibri,Arial,Helvetica,sans-serif;background-color:white"><br></span></div><div><span style="font-family:Calibri,Arial,Helvetica,sans-serif;background-color:white">Let me know what you think about the overall proposal mentioned above. If there is no strong disagreement about adding new DRM KMS properties for output quantization range (and output encoding), I'll plan to start working on the changes.<br></span></div><div><span style="font-family:Calibri,Arial,Helvetica,sans-serif;background-color:white"><br></span></div><div><span style="font-family:Calibri,Arial,Helvetica,sans-serif;background-color:white">Thanks,</span></div><div><span style="font-family:Calibri,Arial,Helvetica,sans-serif;background-color:white">-Yogish<br></span></div><div></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
If we look at I915 driver's "Broadcast RGB" property, it seems to say<br>
to me that the framebuffer is always primarily assumed to be in<br>
full-range, and the conversion to limited-range happens in the scanout<br>
circuitry. So that property would not help with video content that is<br>
already in limited-range.<br>
<br>
To recap, there are two orthogonal things: application content or<br>
framebuffer range, and video sink / monitor range. The display server<br>
between the two, at last if it is a Wayland compositor, would be able to<br>
convert as necessary.<br>
<br>
> For how to use selectable output encoding with Weston:<br>
> I was thinking that DRM should have separate property to list the encodings<br>
> supported by sink and Weston will present this list to its client. Your<br>
<br>
Not client. A configuration tool perhaps, but not generically to all<br>
Wayland clients, not as a directly settable knob at least.<br>
<br>
> idea to validate encodings using TEST_ONLY commit and present a list of<br>
> timings along with encodings supported by particular timing seems better.<br>
> Instead of validating all possible encodings, does it make sense to<br>
> validate  only those supported by sink? Irrespective of this we would<br>
<br>
Yes, having a list of what the sink actually supports would be nice.<br>
<br>
As for Wayland clients, there is an extension brewing at<br>
<a href="https://gitlab.freedesktop.org/wayland/wayland-protocols/-/merge_requests/8" rel="noreferrer" target="_blank">https://gitlab.freedesktop.org/wayland/wayland-protocols/-/merge_requests/8</a><br>
that would allow suggesting the optimal encoding (pixel format and<br>
modifier really) in flight.<br>
<br>
That said, we are talking about the two different things here:<br>
framebuffer format vs. encoding on the wire. Whether making them match<br>
has benefits is another matter.<br>
<br>
> anyway need some mechanism which will allow user to select particular<br>
> encoding for a particular mode. I was thinking to allow this using new DRM<br>
> property "Encoding". Do you have anything better in mind?<br>
<br>
I think that is a reasonable and useful goal and idea. Just remember to<br>
document it when proposing, even if it seems obvious. The details on<br>
how to formulate that into UAPI is up for debate.<br>
<br>
As said, changing KMS properties after they have been exposed to<br>
userspace won't really work from either kernel or userspace point of<br>
view. So you'd probably need to expose one blob type property listing<br>
the encodings that may work as an array, and another property for<br>
setting the one to use. IN_FORMATS property is somewhat similar,<br>
although more complicated because it is the combination of format and<br>
modifier.<br>
<br>
> (Since I am using my Gmail Id, I feel I should mention that I work at<br>
> Nvidia)<br>
<br>
Nice to know the source of interest. :-)<br>
<br>
<br>
Thanks,<br>
pq<br>
<br>
> <br>
> Thanks,<br>
> -Yogish<br>
> <br>
> On Thu, May 28, 2020 at 6:18 PM Pekka Paalanen <<a href="mailto:ppaalanen@gmail.com" target="_blank">ppaalanen@gmail.com</a>> wrote:<br>
> <br>
> > On Thu, 28 May 2020 17:38:59 +0530<br>
> > Yogish Kulkarni <<a href="mailto:yogishkulkarni@gmail.com" target="_blank">yogishkulkarni@gmail.com</a>> wrote:<br>
> >  <br>
> > > I am trying to find a way through Weston which will allow setting  <br>
> > specific  <br>
> > > encoding at display output.  <br>
> ><br>
> > Hi,<br>
> ><br>
> > why do *you* want to control that?<br>
> ><br>
> > Why not let the driver always choose the highest possible encoding<br>
> > given the video mode and hardware capability?<br>
> ><br>
> > I can understand userspace wanting to know what it got, but why should<br>
> > userspace be able to control it?<br>
> ><br>
> > Would people want to pick the encoding first, and then go for the<br>
> > highest possible video mode?<br>
> >  <br>
> > > Could you please elaborate on  why it is best<br>
> > > to let DRM driver automatically configure which encoding to choose rather<br>
> > > than making it selectable by DRM client ? I am not able to find reference<br>
> > > to past discussion about this. I was only able to find a proposed change  <br>
> > -  <br>
> > > <a href="https://lists.freedesktop.org/archives/intel-gfx/2017-April/125451.html" rel="noreferrer" target="_blank">https://lists.freedesktop.org/archives/intel-gfx/2017-April/125451.html</a>  <br>
> > but  <br>
> > > am not able to find why it got rejected.<br>
> > ><br>
> > > Alternatively, is there existing way through which DRM clients can  <br>
> > specify  <br>
> > > preference for output encoding ? Or currently it's all up to the DRM  <br>
> > driver  <br>
> > > to choose what output encoding to use.  <br>
> ><br>
> > There must be some reason why userspace needs to be able to control it.<br>
> > I'm also asking as a Weston maintainer, since I'm interested in how<br>
> > this affects e.g. color reproduction or HDR support.<br>
> ><br>
> > One thing that comes to my mind is using atomic TEST_ONLY commits to<br>
> > probe all the possible video modes × encodings for presenting a list to<br>
> > the user to choose from, if you have a display configuration GUI. E.g<br>
> > with some TV use cases, maybe the user wants to avoid sub-sampling, use<br>
> > the native resolution, but limit refresh rate to what's actually<br>
> > possible. Or any other combination of the three.<br>
> ><br>
> ><br>
> > Thanks,<br>
> > pq<br>
> >  <br>
> > ><br>
> > > Thanks,<br>
> > > -Yogish<br>
> > ><br>
> > > On Thu, May 28, 2020 at 1:54 PM Daniel Vetter <<a href="mailto:daniel@ffwll.ch" target="_blank">daniel@ffwll.ch</a>> wrote:<br>
> > >  <br>
> > > > On Thu, May 28, 2020 at 12:29:43PM +0530, Yogish Kulkarni wrote:  <br>
> > > > > For creating new source property, is it good to follow<br>
> > > > > "drm_mode_create_hdmi_colorspace_property()"  as an example ? It  <br>
> > seems  <br>
> > > > that  <br>
> > > > > currently there is no standard DRM property which allows DRM client  <br>
> > to  <br>
> > > > set  <br>
> > > > > a specific output encoding (like YUV420, YUV422 etc). Also, there is  <br>
> > no  <br>
> > > > > standard property for letting client select YUV/RGB color range. I  <br>
> > see  <br>
> > > > > there are two ways to introduce new properties, 1. do something like<br>
> > > > > drm_mode_create_hdmi_colorspace_property 2. create custom property  <br>
> > > > similar  <br>
> > > > > to "Broadcast RGB". Is there opinion on which is a preferable way  <br>
> > to  <br>
> > > > expose  <br>
> > > > > encoding and color rage selection property ?  <br>
> > > ><br>
> > > > I guess first question is "why?" Thus far we've gone with the opinion  <br>
> > that  <br>
> > > > automatically configuring output stuff as much as possible is best.  <br>
> > What's  <br>
> > > > the use-case where the driver can't select this?<br>
> > > > -Daniel  <br>
> >  <br>
<br>
</blockquote></div></div></div>