From 28c93e352cb1ab20af1f7a4f1376c41c29a13461 Mon Sep 17 00:00:00 2001 From: Simon Hausmann Date: Wed, 20 Mar 2024 12:49:43 +0100 Subject: [PATCH] Fix Surface::lock_front_buffer failing when ffi::gbm_surface_lock_front_buffer succeeds With the proprietary vivante driver it's been observed that gbm_surface_has_free_buffers() fails even though gbm_surface_lock_front_buffer() succeeds. Since C/C++ based programs like Weston, kmscube, mutter, or Qt's eglfs renderer don't check for has_free_buffers() before lock_front_buffer() and they work with said drivers, work around it by removing the check. Fixes #36 --- src/surface.rs | 35 ++++++++++++++--------------------- 1 file changed, 14 insertions(+), 21 deletions(-) diff --git a/src/surface.rs b/src/surface.rs index f8040d2..d420cc2 100644 --- a/src/surface.rs +++ b/src/surface.rs @@ -22,8 +22,6 @@ impl fmt::Debug for Surface { /// Errors that may happen when locking the front buffer #[derive(Debug, Clone, Copy, PartialEq, Eq)] pub enum FrontBufferError { - /// No free buffers are currently available - NoFreeBuffers, /// An unknown error happened Unknown, /// Device was already released @@ -33,7 +31,6 @@ pub enum FrontBufferError { impl fmt::Display for FrontBufferError { fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { match *self { - FrontBufferError::NoFreeBuffers => write!(f, "No free buffers remaining"), FrontBufferError::Unknown => write!(f, "Unknown error"), FrontBufferError::Destroyed(ref err) => write!(f, "Buffer was destroyed: {}", err), } @@ -81,25 +78,21 @@ impl Surface { pub unsafe fn lock_front_buffer(&self) -> Result, FrontBufferError> { let device = self._device.upgrade(); if device.is_some() { - if ffi::gbm_surface_has_free_buffers(*self.ffi) != 0 { - let buffer_ptr = ffi::gbm_surface_lock_front_buffer(*self.ffi); - if !buffer_ptr.is_null() { - let surface_ptr = self.ffi.downgrade(); - let buffer = BufferObject { - ffi: Ptr::new(buffer_ptr, move |ptr| { - if let Some(surface) = surface_ptr.upgrade() { - ffi::gbm_surface_release_buffer(*surface, ptr); - } - }), - _device: self._device.clone(), - _userdata: std::marker::PhantomData, - }; - Ok(buffer) - } else { - Err(FrontBufferError::Unknown) - } + let buffer_ptr = ffi::gbm_surface_lock_front_buffer(*self.ffi); + if !buffer_ptr.is_null() { + let surface_ptr = self.ffi.downgrade(); + let buffer = BufferObject { + ffi: Ptr::new(buffer_ptr, move |ptr| { + if let Some(surface) = surface_ptr.upgrade() { + ffi::gbm_surface_release_buffer(*surface, ptr); + } + }), + _device: self._device.clone(), + _userdata: std::marker::PhantomData, + }; + Ok(buffer) } else { - Err(FrontBufferError::NoFreeBuffers) + Err(FrontBufferError::Unknown) } } else { Err(FrontBufferError::Destroyed(DeviceDestroyedError))