Fix crash on hotplugging displays while switched to another TTY

Currently, we inhibit renderloops when switching to another TTY, and unhibit
when switching back. When we hotplug a display while switched to another TTY,
its renderloop isn't inhibited by default, yet when we switch back, we try
to uninhibit the fresh renderloop, which triggers an assert.

Inhibiting newly created outputs while switched to another TTY fixes this crash.

BUG: 435388
FIXED-IN: 5.21
This commit is contained in:
Jan Blackquill 2021-04-05 12:13:32 -04:00
parent c53b2fa3c5
commit 9f215a06fa

View file

@ -279,6 +279,10 @@ bool DrmBackend::initialize()
void DrmBackend::addOutput(DrmOutput *o) void DrmBackend::addOutput(DrmOutput *o)
{ {
if (!m_active) {
o->renderLoop()->inhibit();
}
m_outputs.append(o); m_outputs.append(o);
m_enabledOutputs.append(o); m_enabledOutputs.append(o);
emit o->gpu()->outputEnabled(o); emit o->gpu()->outputEnabled(o);