mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-05-08 17:48:10 +02:00
rusticl/gl: only flush objects on import if we get a valid fd
If no context is current we might not get anything to wait on. Cc: mesa-stable Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/36249>
This commit is contained in:
parent
4d8b08e7ec
commit
f6b844e239
1 changed files with 18 additions and 12 deletions
|
|
@ -255,16 +255,19 @@ impl GLCtxManager {
|
|||
&mut export_in,
|
||||
&mut flush_out,
|
||||
);
|
||||
// TODO: use fence_server_sync in ctx inside the queue thread
|
||||
let fence_fd = FenceFd { fd };
|
||||
cl_ctx.devs.iter().for_each(|dev| {
|
||||
let fence = dev.helper_ctx().import_fence(&fence_fd);
|
||||
fence.wait();
|
||||
});
|
||||
|
||||
if err_flush != 0 {
|
||||
err_flush
|
||||
} else {
|
||||
if fd != -1 {
|
||||
// TODO: use fence_server_sync in ctx inside the queue thread
|
||||
let fence_fd = FenceFd { fd };
|
||||
cl_ctx.devs.iter().for_each(|dev| {
|
||||
let fence = dev.helper_ctx().import_fence(&fence_fd);
|
||||
fence.wait();
|
||||
});
|
||||
}
|
||||
|
||||
egl_export_object_func(
|
||||
disp.cast(),
|
||||
ctx.cast(),
|
||||
|
|
@ -289,16 +292,19 @@ impl GLCtxManager {
|
|||
&mut export_in,
|
||||
&mut flush_out,
|
||||
);
|
||||
// TODO: use fence_server_sync in ctx inside the queue thread
|
||||
let fence_fd = FenceFd { fd };
|
||||
cl_ctx.devs.iter().for_each(|dev| {
|
||||
let fence = dev.helper_ctx().import_fence(&fence_fd);
|
||||
fence.wait();
|
||||
});
|
||||
|
||||
if err_flush != 0 {
|
||||
err_flush
|
||||
} else {
|
||||
if fd != -1 {
|
||||
// TODO: use fence_server_sync in ctx inside the queue thread
|
||||
let fence_fd = FenceFd { fd };
|
||||
cl_ctx.devs.iter().for_each(|dev| {
|
||||
let fence = dev.helper_ctx().import_fence(&fence_fd);
|
||||
fence.wait();
|
||||
});
|
||||
}
|
||||
|
||||
glx_export_object_func(
|
||||
disp.cast(),
|
||||
ctx.cast(),
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue