gbm: Try to re-create resources and commit if restarting the rendering loop fails
This commit is contained in:
parent
d30bd4555e
commit
d3b8563f65
|
@ -56,13 +56,23 @@ impl<
|
||||||
for (crtc, backend) in backends.borrow().iter() {
|
for (crtc, backend) in backends.borrow().iter() {
|
||||||
if let Some(backend) = backend.upgrade() {
|
if let Some(backend) = backend.upgrade() {
|
||||||
// restart rendering loop, if it was previously running
|
// restart rendering loop, if it was previously running
|
||||||
if let Some(Err(err)) = backend
|
if let Some(fb) = backend.current_frame_buffer.get() {
|
||||||
.current_frame_buffer
|
if let Err(_) = backend.crtc.page_flip(fb) {
|
||||||
.get()
|
// Try more!
|
||||||
.map(|fb| backend.crtc.page_flip(fb))
|
if let Err(err) = backend.recreate() {
|
||||||
{
|
error!(
|
||||||
warn!(self.logger, "Failed to restart rendering loop. Error: {}", err);
|
self.logger,
|
||||||
|
"Failed to re-create gbm surface, is the device gone?\n\t{}", err
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
if let Err(err) = unsafe { backend.page_flip() } {
|
||||||
|
warn!(self.logger, "Failed to restart rendering loop. Error: {}", err);
|
||||||
|
// TODO bubble this up the user somehow
|
||||||
|
// maybe expose a "running" state from a surface?
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// reset cursor
|
// reset cursor
|
||||||
{
|
{
|
||||||
use ::drm::control::Device;
|
use ::drm::control::Device;
|
||||||
|
|
|
@ -91,11 +91,15 @@ impl<D: RawDevice + 'static> GbmSurfaceInternal<D> {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn recreate(&self) -> Result<(), Error<<<D as Device>::Surface as Surface>::Error>> {
|
pub fn recreate(&self) -> Result<(), Error<<<D as Device>::Surface as Surface>::Error>> {
|
||||||
let (w, h) = self.pending_mode().ok_or(Error::NoModeSet)?.size();
|
let (w, h) = self
|
||||||
|
.pending_mode()
|
||||||
|
.or(self.current_mode())
|
||||||
|
.ok_or(Error::NoModeSet)?
|
||||||
|
.size();
|
||||||
|
|
||||||
// Recreate the surface and the related resources to match the new
|
// Recreate the surface and the related resources to match the new
|
||||||
// resolution.
|
// resolution.
|
||||||
debug!(self.logger, "(Re-)Initializing surface for mode: {}:{}", w, h);
|
debug!(self.logger, "(Re-)Initializing surface (with mode: {}:{})", w, h);
|
||||||
let surface = self
|
let surface = self
|
||||||
.dev
|
.dev
|
||||||
.borrow_mut()
|
.borrow_mut()
|
||||||
|
|
Loading…
Reference in New Issue