From: David Herrmann Date: Thu, 16 Jul 2015 16:18:01 +0000 (+0200) Subject: logind: prefer new sessions over older ones on VT switches X-Git-Tag: v226.4~1^2~201 X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=42c23dcd12e2b65f7b16b560cabdaf46bafaefec;hp=c0434076fbe643d3830b00de233900b8f828dbde logind: prefer new sessions over older ones on VT switches Our seat->positions[] array keeps track of the 'preferred' session on a VT. The only situation this is used, is to select the session to activate when a VT is activated. In the normal case, there's only one session per VT so the selection is trivial. Older greeters, however, implement take-overs when they start sessions on the same VT that the greeter ran on. We recently limited such take-overs to VTs where a greeter is running on, to force people to never share VTs in new code that is written. For legacy reasons, we need to be compatible to old greeters, though. Hence, we allow those greeters to implement take-over. In such take-overs, however, we should really make sure that the new sessions gets preferred over the old one under all circumstances. Hence, make sure we override the previous preferred session with a new session. --- diff --git a/src/login/logind-seat.c b/src/login/logind-seat.c index 72bcfc4a5..3daaf000e 100644 --- a/src/login/logind-seat.c +++ b/src/login/logind-seat.c @@ -473,7 +473,7 @@ void seat_claim_position(Seat *s, Session *session, unsigned int pos) { seat_evict_position(s, session); session->position = pos; - if (pos > 0 && !s->positions[pos]) + if (pos > 0) s->positions[pos] = session; }