<div dir="ltr">I don't think you are paying enough attention to the main points. Ir is not simply a case of extending the fourcc values to include more. If I didn't make it clear enough, the whole fourcc system is obscure, inadequate, ambiguous. The only reason ever to use it would be when you don't have meta data and you are forced to encode the format in the first 4 bytes.<div><br><div>Colorimetry is only relevant when displaying on a monitor. In the video world we just have red, green and blue (plus alpha, y, u and v). These are just labels for the colour channels, mapping them to bit formats.</div><div><br></div><div>The values I mentioned are all necessary if you want to convert from one colourspace to another. For example if I decode a video frame and the pix format is YUV420P then to convert it to RGBA to display via openGL, I need to know the YUV subspace (bt709 or itu601) and whether the values are clamped or full range. Then I apply the standard conversion factors (Kr = 0.2126, Kb = 0.0722 for bt709). This cannot be derived from the fourcc (generally). No doubt there is a standard definition of definition of the R,G,B primaries, but that isnr a concern. I just feed the values into an openGL texture buffer, and SDL buffer, a gdkpixbuf, QImage or whatever and ask for it to be displayed. Now in an application I may optionally offer the user filters to adjust the white balance, contrast, display gamma etc. but that is outside of the scope of what I am proposing.</div><div><br></div><div>And no, it is not a case of "adding another standard" and confusing things, there is no standard.</div><div><br></div><div>I just had a look at pipewire, there is nothing bad about it per se, they mention their palette values are based on gstreamer. So fine, we have yet another library specific set of definitions.</div><div><br></div><div>It's like I am trying to invent Esperanto, and all you can say is...."oh you don't like English, well have you considered speaking German instead ?"</div><div><br></div><div>Well that is it, I am done. I was asked how XDG video could be useful. I explained the shortcomings of what exists currently, and outlined various ways in which having a standard could be useful.</div><div><br></div><div>But if there is no will for this, then I am not going to waste any more of my time on this. My own standards work very well for my own purposes, and if I ever wanted to use pipewire for example, I can simply add the constants to my compatibility header.</div><div><br></div><div><br></div><div>Cheers.</div><div>G,</div><div><br></div><div> </div><div><br></div></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, 5 Apr 2024 at 06:34, Pekka Paalanen <<a href="mailto:pekka.paalanen@haloniitty.fi">pekka.paalanen@haloniitty.fi</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 Thu, 4 Apr 2024 17:13:40 -0300<br>
salsaman <<a href="mailto:salsaman@gmail.com" target="_blank">salsaman@gmail.com</a>> wrote:<br>
<br>
> Hi,<br>
> the problem with the drm.h header is, it is complicated, still needs<br>
> interpretation, and it lacks some commonly used formats, (e.g YUVA4444p)<br>
<br>
They accept additions, if the additions serve userspace<br>
interoperability. There is no requirement to actually use the format in<br>
the kernel.<br>
<br>
Pixel formats are complicated, yes. There are too many pixel format<br>
enumerations, every one differently defined, sure. I wouldn't add yet<br>
another system of definitions.<br>
<br>
> Also it doesn't address the gamma value (linear, sRGB, bt701), or the yuv<br>
> subspace, (eg Y'CbCr vs bt701), the yuv ramge (16 - 240. 16 - 235 = clamped<br>
> / mpeg. 0 - 255 unclamped, full, jpeg range) or uv sampling position, e.g<br>
> center, top_left)<br>
<br>
My opinion is that that none of that is relevant to a pixel format.<br>
These are additional information that must be decoupled from the pixel<br>
format to avoid a combinatorial explosion of the format enumeration,<br>
which is already massive even without them. A pixel format only<br>
describes a part of the memory layout: which set of bits forms a raw<br>
channel value of a pixel, and what are the channel names. Giving any<br>
further meaning to those raw values is for other metadata.<br>
<br>
What about colorimetry? Primaries and white point, dynamic range, plus<br>
the difference between encoding colorimetry (container color volume)<br>
and the usable/used colorimetry (target color volume, which is present<br>
in e.g. HDR static metadata typical for BT.2100/PQ signals in the form<br>
of the Mastering Display Color Volume).<br>
<br>
What about the assumed viewing environment, if we want to go from just<br>
stimulus towards appearance?<br>
<br>
> I can see that having some common definitions would be useful for<br>
> exchanging data between applications. Eg my app gets a frame buffer and<br>
> metadata XDG_VIDEO_PALETTE_RGB24, XDG_VIDEO_GAMMA_LINEAR<br>
> then I know unambiguously that this is planar RGB 8:8:8 (so forget little /<br>
> big endian) and that the values are encoded with linear (not sRGB) gamma.<br>
<br>
> If you want to be more specific with palettes, then you could do so, but it<br>
> might require defining metadata structs,<br>
<br>
> I'll try to explain the rationale a bit. In the audio world it is quite<br>
> common for apps to send audio from one to another. Generally speaking they<br>
> would send or receive via an audio server, e.g pulseaudio, jack.<br>
> Now imagine the same for video, <br>
<br>
This sounds like Pipewire. One would develop Pipewire API to carry the<br>
necessary metadata. One could choose to follow something massive like<br>
ITU-T H.274, or maybe follow what we are brewing for Wayland.<br>
<br>
To my understanding, Pipewire is already becoming very common among<br>
desktop environments for routing audio and video streams between<br>
applications and system components and devices.<br>
<br>
<br>
Thanks,<br>
pq<br>
</blockquote></div>