hardware/intel/common/libva
修订版 | 9ca99eb84cdb6ea638af567f6074c53fa51a416c (tree) |
---|---|
时间 | 2017-08-17 12:06:29 |
作者 | Philipp Kerling <pkerling@casi...> |
Commiter | Xiang, Haihao |
wayland: Add wl_drm listener immediately upon bind
Events on wl_drm could get lost if the listener is bound only after
the roundtrip is complete. While it is correct that to get all wl_drm
events at most two roundtrips are required, in fact one roundtrip may
be enough if another thread flushes and reads from the connection
in parallel to the initial libva wl_registry roundtrip. It is thus too
late to call wl_drm_add_listener after the roundtrip.
Fixes: #101
@@ -154,7 +154,8 @@ registry_handle_global( | ||
154 | 154 | uint32_t version |
155 | 155 | ) |
156 | 156 | { |
157 | - struct va_wayland_drm_context *wl_drm_ctx = data; | |
157 | + VADisplayContextP const pDisplayContext = data; | |
158 | + struct va_wayland_drm_context * const wl_drm_ctx = pDisplayContext->opaque; | |
158 | 159 | |
159 | 160 | if (strcmp(interface, "wl_drm") == 0) { |
160 | 161 | /* bind to at most version 2, but also support version 1 if |
@@ -164,6 +165,13 @@ registry_handle_global( | ||
164 | 165 | wl_drm_ctx->drm = |
165 | 166 | wl_registry_bind(wl_drm_ctx->registry, name, &wl_drm_interface, |
166 | 167 | (version < 2) ? version : 2); |
168 | + | |
169 | + if (wl_drm_ctx->drm | |
170 | + && wl_drm_add_listener(wl_drm_ctx->drm, &drm_listener, pDisplayContext) != 0) { | |
171 | + va_wayland_error("could not add listener to wl_drm"); | |
172 | + wl_drm_destroy(wl_drm_ctx->drm); | |
173 | + wl_drm_ctx->drm = NULL; | |
174 | + } | |
167 | 175 | } |
168 | 176 | } |
169 | 177 |
@@ -259,7 +267,7 @@ va_wayland_drm_create(VADisplayContextP pDisplayContext) | ||
259 | 267 | va_wayland_error("could not create wl_registry"); |
260 | 268 | goto end; |
261 | 269 | } |
262 | - if (wl_registry_add_listener(wl_drm_ctx->registry, ®istry_listener, wl_drm_ctx) != 0) { | |
270 | + if (wl_registry_add_listener(wl_drm_ctx->registry, ®istry_listener, pDisplayContext) != 0) { | |
263 | 271 | va_wayland_error("could not add listener to wl_registry"); |
264 | 272 | goto end; |
265 | 273 | } |
@@ -273,11 +281,6 @@ va_wayland_drm_create(VADisplayContextP pDisplayContext) | ||
273 | 281 | /* Do not print an error, the compositor might just not support wl_drm */ |
274 | 282 | if (!wl_drm_ctx->drm) |
275 | 283 | goto end; |
276 | - | |
277 | - if (wl_drm_add_listener(wl_drm_ctx->drm, &drm_listener, pDisplayContext) != 0) { | |
278 | - va_wayland_error("could not add listener to wl_drm"); | |
279 | - goto end; | |
280 | - } | |
281 | 284 | if (!wayland_roundtrip_queue(ctx->native_dpy, wl_drm_ctx->queue)) |
282 | 285 | goto end; |
283 | 286 | if (drm_state->fd < 0) { |