diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/login/logind-dbus.c | 7 | ||||
| -rw-r--r-- | src/login/logind-seat.c | 18 | ||||
| -rw-r--r-- | src/login/logind-session.c | 10 | ||||
| -rw-r--r-- | src/login/logind-session.h | 2 | 
4 files changed, 20 insertions, 17 deletions
| diff --git a/src/login/logind-dbus.c b/src/login/logind-dbus.c index cd9cab7334..ca435dfcbb 100644 --- a/src/login/logind-dbus.c +++ b/src/login/logind-dbus.c @@ -699,9 +699,12 @@ static int method_create_session(sd_bus_message *message, void *userdata, sd_bus           * after the user-session and want the user-session to take           * over the VT. We need to support this for           * backwards-compatibility, so make sure we allow new sessions -         * on a VT that a greeter is running on. +         * on a VT that a greeter is running on. Furthermore, to allow +         * re-logins, we have to allow a greeter to take over a used VT for +         * the exact same reasons.           */ -        if (vtnr > 0 && +        if (c != SESSION_GREETER && +            vtnr > 0 &&              vtnr < m->seat0->position_count &&              m->seat0->positions[vtnr] &&              m->seat0->positions[vtnr]->class != SESSION_GREETER) diff --git a/src/login/logind-seat.c b/src/login/logind-seat.c index fb5d076311..9d5287ad35 100644 --- a/src/login/logind-seat.c +++ b/src/login/logind-seat.c @@ -290,8 +290,8 @@ int seat_switch_to_next(Seat *s) {                  return -EINVAL;          start = 1; -        if (s->active && s->active->pos > 0) -                start = s->active->pos; +        if (s->active && s->active->position > 0) +                start = s->active->position;          for (i = start + 1; i < s->position_count; ++i)                  if (s->positions[i]) @@ -311,8 +311,8 @@ int seat_switch_to_previous(Seat *s) {                  return -EINVAL;          start = 1; -        if (s->active && s->active->pos > 0) -                start = s->active->pos; +        if (s->active && s->active->position > 0) +                start = s->active->position;          for (i = start - 1; i > 0; --i)                  if (s->positions[i]) @@ -472,9 +472,9 @@ int seat_stop_sessions(Seat *s, bool force) {  void seat_evict_position(Seat *s, Session *session) {          Session *iter; -        unsigned int pos = session->pos; +        unsigned int pos = session->position; -        session->pos = 0; +        session->position = 0;          if (pos == 0)                  return; @@ -486,7 +486,7 @@ void seat_evict_position(Seat *s, Session *session) {                   * position (eg., during gdm->session transition), so let's look                   * for it and set it on the free slot. */                  LIST_FOREACH(sessions_by_seat, iter, s->sessions) { -                        if (iter->pos == pos) { +                        if (iter->position == pos) {                                  s->positions[pos] = iter;                                  break;                          } @@ -504,7 +504,7 @@ void seat_claim_position(Seat *s, Session *session, unsigned int pos) {          seat_evict_position(s, session); -        session->pos = pos; +        session->position = pos;          if (pos > 0 && !s->positions[pos])                  s->positions[pos] = session;  } @@ -512,7 +512,7 @@ void seat_claim_position(Seat *s, Session *session, unsigned int pos) {  static void seat_assign_position(Seat *s, Session *session) {          unsigned int pos; -        if (session->pos > 0) +        if (session->position > 0)                  return;          for (pos = 1; pos < s->position_count; ++pos) diff --git a/src/login/logind-session.c b/src/login/logind-session.c index 6a450b02a0..45f4c09d3d 100644 --- a/src/login/logind-session.c +++ b/src/login/logind-session.c @@ -264,7 +264,7 @@ int session_save(Session *s) {                  fprintf(f, "VTNR=%u\n", s->vtnr);          if (!s->vtnr) -                fprintf(f, "POS=%u\n", s->pos); +                fprintf(f, "POSITION=%u\n", s->position);          if (s->leader > 0)                  fprintf(f, "LEADER="PID_FMT"\n", s->leader); @@ -302,7 +302,7 @@ int session_load(Session *s) {                  *seat = NULL,                  *vtnr = NULL,                  *state = NULL, -                *pos = NULL, +                *position = NULL,                  *leader = NULL,                  *type = NULL,                  *class = NULL, @@ -329,7 +329,7 @@ int session_load(Session *s) {                             "DESKTOP",        &s->desktop,                             "VTNR",           &vtnr,                             "STATE",          &state, -                           "POS",            &pos, +                           "POSITION",       &position,                             "LEADER",         &leader,                             "TYPE",           &type,                             "CLASS",          &class, @@ -388,10 +388,10 @@ int session_load(Session *s) {          if (!s->seat || !seat_has_vts(s->seat))                  s->vtnr = 0; -        if (pos && s->seat) { +        if (position && s->seat) {                  unsigned int npos; -                safe_atou(pos, &npos); +                safe_atou(position, &npos);                  seat_claim_position(s->seat, s, npos);          } diff --git a/src/login/logind-session.h b/src/login/logind-session.h index 4bf739a44d..b8565ebf51 100644 --- a/src/login/logind-session.h +++ b/src/login/logind-session.h @@ -70,7 +70,7 @@ struct Session {          Manager *manager;          const char *id; -        unsigned int pos; +        unsigned int position;          SessionType type;          SessionClass class; | 
