kms: Don't join on DrmSurface drop

This commit is contained in:
Victoria Brekenfeld 2025-09-10 15:52:41 +02:00 committed by Victoria Brekenfeld
parent 458f5f4dcf
commit cd1117080c
3 changed files with 22 additions and 9 deletions

View file

@ -494,8 +494,9 @@ impl State {
if let Some(mut leasing_global) = device.inner.leasing_global.take() {
leasing_global.disable_global::<State>();
}
for surface in device.inner.surfaces.values_mut() {
for (_, surface) in device.inner.surfaces.drain() {
outputs_removed.push(surface.output.clone());
surface.drop_and_join();
}
if let Some(token) = device.event_token.take() {
self.common.event_loop_handle.remove(token);

View file

@ -705,11 +705,9 @@ impl<'a> KmsGuard<'a> {
.crtcs()
.iter()
.filter(|crtc| {
!device
.inner
.surfaces
.get(crtc)
.is_some_and(|surface| surface.output.is_enabled())
!device.inner.surfaces.get(crtc).is_some()
// TODO: We can't do this. See https://github.com/Smithay/smithay/pull/1820
//.is_some_and(|surface| surface.output.is_enabled())
})
.copied()
.collect::<HashSet<crtc::Handle>>();

View file

@ -468,6 +468,16 @@ impl Surface {
}
}
}
pub fn drop_and_join(mut self) {
let thread = self.thread.take();
let _ = self;
if let Some(thread) = thread {
let name = thread.thread().name().unwrap().to_string();
let _ = thread.join();
info!("Thread {} terminated.", name)
}
}
}
impl Drop for Surface {
@ -475,9 +485,13 @@ impl Drop for Surface {
let _ = self.thread_command.send(ThreadCommand::End);
self.loop_handle.remove(self.thread_token);
if let Some(thread) = self.thread.take() {
let name = thread.thread().name().unwrap().to_string();
let _ = thread.join();
info!("Thread {} terminated.", name)
let _ = thread;
// We want to do this, but this currently deadlocks on `apply_config_for_outputs`.
/*
let name = thread.thread().name().unwrap().to_string();
let _ = thread.join();
info!("Thread {} terminated.", name)
*/
}
}
}