<div dir="ltr"><div dir="ltr"><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Wed, Dec 18, 2024 at 5:32 AM Brian Starkey <<a href="mailto:brian.starkey@arm.com" target="_blank">brian.starkey@arm.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 Wed, Dec 18, 2024 at 11:24:58AM +0000, Simona Vetter wrote:<br>
> <br>
> For that reason I think linear modifiers with explicit pitch/size<br>
> alignment constraints is a sound concept and fits into how modifiers work<br>
> overall.<br>
> -Sima<br>
<br>
Could we make it (more) clear that pitch alignment is a "special"<br>
constraint (in that it's really a description of the buffer layout),<br>
and that constraints in-general shouldn't be exposed via modifiers?<br></blockquote><div><br></div>Modifiers uniquely identify image layouts. That's why they exist and it's their only purpose.</div><div class="gmail_quote"><br></div><div class="gmail_quote">It doesn't matter how many modifiers we have. No app should ever parse the modifier bits. All apps must treat modifiers as opaque numbers. Likewise, documentation of all modifiers in drm_fourcc.h is only meant for driver developers. No developers of apps should ever use the documentation. There can be a million modifiers and a million different devices, and the whole system of modifiers would fall apart if every app developer had to learn all of them.<br></div><div class="gmail_quote"><br></div><div class="gmail_quote">The only thing applications are allowed to do is query modifier lists from all clients, compute their intersection, and pass it to one of the clients for allocation. All clients must allocate the exact same layout, otherwise the whole system of modifiers would fall apart. If the modifier dictates that the pitch and alignment are not variables, but fixed values derived from width/height/bpp, then that's what all clients must allocate.</div><div class="gmail_quote"><br></div><div class="gmail_quote">If any app uses DRM_FORMAT_MOD_LINEAR directly instead of querying supported modifiers from clients, it's a misuse of the API.<br></div><div class="gmail_quote"><br></div><div class="gmail_quote">DRM_FORMAT_MOD_LINEAR will be deprecated because it's the only modifier that is generally non-functional (it's only functional in special cases). After new linear modifiers land, drivers will stop supporting DRM_FORMAT_MOD_LINEAR if they can't support all pitches and alignments because we only want to have functional software.</div><div class="gmail_quote"><br></div><div class="gmail_quote">Marek<br></div></div>
</div>