<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Fri, Apr 15, 2016 at 3:03 AM, Emil Velikov <span dir="ltr"><<a href="mailto:emil.l.velikov@gmail.com" target="_blank">emil.l.velikov@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div class=""><div class="h5">On 15 April 2016 at 03:32, Michel Dänzer <<a href="mailto:michel@daenzer.net">michel@daenzer.net</a>> wrote:<br>
> On 15.04.2016 11:14, Michel Dänzer wrote:<br>
>> On 14.04.2016 22:16, Emil Velikov wrote:<br>
>>> On 14 April 2016 at 09:23, Michel Dänzer <<a href="mailto:michel@daenzer.net">michel@daenzer.net</a>> wrote:<br>
>>>> From: Michel Dänzer <<a href="mailto:michel.daenzer@amd.com">michel.daenzer@amd.com</a>><br>
>>>><br>
>>>> Fixes build failure due to wl_proxy_marshal_constructor_versioned being<br>
>>>> unresolved when building against current wayland.<br>
>>>><br>
>>>> This API was introduced in wayland 1.9.91 by commit 557032e3 ("Track<br>
>>>> protocol object versions inside wl_proxy."). The waffle code doesn't<br>
>>>> reference wl_proxy_marshal_constructor_versioned directly but<br>
>>>> indirectly via wayland-scanner.<br>
>>>><br>
>>>> v2:<br>
>>>> * Add paragraph about how wl_proxy_marshal_constructor_versioned was<br>
>>>> introduced. (Emil Velikov)<br>
>>>> * Only resolve wl_proxy_marshal_constructor_versioned with wayland >=<br>
>>>> 1.9.91.<br>
>>>><br>
>>>> Signed-off-by: Michel Dänzer <<a href="mailto:michel.daenzer@amd.com">michel.daenzer@amd.com</a>><br>
>>>> ---<br>
>>>> src/waffle/wayland/wayland_wrapper.c | 5 +++++<br>
>>>> src/waffle/wayland/wayland_wrapper.h | 8 ++++++++<br>
>>>> 2 files changed, 13 insertions(+)<br>
>>>><br>
>>>> diff --git a/src/waffle/wayland/wayland_wrapper.c b/src/waffle/wayland/wayland_wrapper.c<br>
>>>> index 6ffd5a9..fb66f9a 100644<br>
>>>> --- a/src/waffle/wayland/wayland_wrapper.c<br>
>>>> +++ b/src/waffle/wayland/wayland_wrapper.c<br>
>>>> @@ -106,6 +106,11 @@ wayland_wrapper_init(void)<br>
>>>> RETRIEVE_WL_CLIENT_SYMBOL(wl_proxy_add_listener);<br>
>>>> RETRIEVE_WL_CLIENT_SYMBOL(wl_proxy_marshal);<br>
>>>> RETRIEVE_WL_CLIENT_SYMBOL(wl_proxy_marshal_constructor);<br>
>>>> +#if WAYLAND_VERSION_MAJOR == 1 && \<br>
>>>> + (WAYLAND_VERSION_MINOR > 9 || \<br>
>>>> + (WAYLAND_VERSION_MINOR == 9 && WAYLAND_VERSION_MICRO >= 91))<br>
>>>> + RETRIEVE_WL_CLIENT_SYMBOL(wl_proxy_marshal_constructor_versioned);<br>
>>>> +#endif<br>
>>>> #undef RETRIEVE_WL_CLIENT_SYMBOL<br>
>>>><br>
>>> I am slightly worried about this approach. It adds a so called 'hidden<br>
>>> dependency' and with it a possibility of things going horribly wrong.<br>
>>> It is something that we try to avoid with mesa as the deps version at<br>
>>> build time != run-time one. Or in other words, one might build against<br>
>>> wayland 1.9 and things will go crazy as you run wayland 1.10, or vice<br>
>>> versa.<br></div></div></blockquote><div><br></div><div>Sorry for the late reply. I tried to reply yesterday but wasn't a list member yet so it ended up in the moderation bitbucket.<br><br><div>I think this is actually mostly ok. In the Wayland project, we
were very careful to ensure that anything built against 1.9 would work
when linked against 1.10. This should continue to be the case even with
waffle's shim-layer.<br><br>The problem is not that libwayland added a new symbol nor is it a problem that wayland-protocol.h was updated to use that new symbol. The problem is that waffle sticks a shim layer in
between wayland-protocol.h and libwayland. This makes the wayland-protocol.h file effectively internal to waffle but still updatable by the distro. This is a layering violation. To keep this from happening in the
future, you probably want to just check a version of
wayland-client-protocol.h into the waffle repo so that it doesn't change
out from under you and make waffle just use wayland-client-core.h. You can even check in the version from libwayland 1.9 if you'd like to keep waffle building against older versions.<br><br></div><div>Another option would be to add a wrapper around wl_proxy_marshal_constructor_versioned that calls wl_proxy_marshal_constructor_versioned if it's available and falls back to wl_proxy_marshal_constructor it it's not. Then pull in the header from wayland 1.10. That way it will build and even link against any libwayland version but will use the new versioned constructor function when it's available.<br><br></div><div>In either case, I think checking wayland-client-protocol.h into the repo is a must.<br></div><div> <br></div></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div class=""><div class="h5">
>>> Obviously that's not perfect, although unavoidable. Why ? As distros<br>
>>> do not know about the requirement (i.e. it's not mandated at configure<br>
>>> time) they won't rebuild and things won't work. At the same time if<br>
>>> they do rebuild (again without the explicit requirement), things will<br>
>>> break if one needs to revert to older (yet still in version range as<br>
>>> per the deps list) wayland.<br>
>><br>
>> That's not true at least for Debian and derivatives, which keep track of<br>
>> which symbols were added in which version and generate accordingly<br>
>> versioned dependencies.<br>
><br>
> It occurred to me (just after sending out the previous post, sigh...)<br>
> that this automatic mechanism might not work for waffle's dependency on<br>
> wayland if we don't link the wayland libraries directly. Even so, IME<br>
> this is a common issue distro maintainers of libraries have to deal<br>
> with, nothing particularly tricky.<br>
><br>
</div></div>Interesting - last time I've played around with Debian/derivatives, it<br>
did track the symbols exposed by the libraries although it did not<br>
check if anyone that depends on the new symbol needs to be rebuild and<br>
more importantly the versions need to be bumped. Sadly other<br>
distributions do not do that to this moment (afaict) - Arch, Gentoo,<br>
Fedora (?), Suse (?).<br>
<br>
To put it bluntly - with one approach things will eventually break<br>
[and get fixed by distro maintainers], while with the other things<br>
will just work.<br>
<br>
Afaict the latter does add much more code/complexity over the former, right ?<br>
<span class=""><font color="#888888"><br>
-Emil<br>
</font></span><div class=""><div class="h5">_______________________________________________<br>
waffle mailing list<br>
<a href="mailto:waffle@lists.freedesktop.org">waffle@lists.freedesktop.org</a><br>
<a href="https://lists.freedesktop.org/mailman/listinfo/waffle" rel="noreferrer" target="_blank">https://lists.freedesktop.org/mailman/listinfo/waffle</a><br>
</div></div></blockquote></div><br></div></div>