fprintf(f,
"# This is private data. Do not parse.\n"
- "IS_VTCONSOLE=%i\n",
- seat_is_vtconsole(s));
+ "IS_VTCONSOLE=%i\n"
+ "CAN_MULTI_SESSION=%i\n",
+ seat_is_vtconsole(s),
+ seat_can_multi_session(s));
if (s->active) {
assert(s->active->user);
if (s->manager->n_autovts <= 0)
return 0;
- if (!seat_is_vtconsole(s))
+ if (!seat_can_multi_session(s))
return 0;
for (i = 1; i <= s->manager->n_autovts; i++) {
assert(s);
assert(vtnr >= 1);
- if (!seat_is_vtconsole(s))
+ if (!seat_can_multi_session(s))
return -EINVAL;
log_debug("VT changed to %i", vtnr);
assert(s);
- if (!seat_is_vtconsole(s))
+ if (!seat_can_multi_session(s))
return 0;
lseek(s->manager->console_active_fd, SEEK_SET, 0);
assert(session);
assert(!session->seat);
- if (!seat_is_vtconsole(s) && s->sessions)
+ if (!seat_can_multi_session(s) && s->sessions)
return -EEXIST;
session->seat = s;
seat_send_changed(s, "Sessions\0");
- if (!seat_is_vtconsole(s)) {
+ if (!seat_can_multi_session(s)) {
assert(!s->active);
seat_set_active(s, session);
}
return s->manager->vtconsole == s;
}
+bool seat_can_multi_session(Seat *s) {
+ assert(s);
+
+ if (!seat_is_vtconsole(s))
+ return false;
+
+ /* If we can't watch which VT is in the foreground, we don't
+ * support VT switching */
+
+ return s->manager->console_active_fd >= 0;
+}
+
int seat_get_idle_hint(Seat *s, dual_timestamp *t) {
Session *session;
bool idle_hint = true;
"SERVICE=%s\n",
s->service);
- if (s->seat && seat_is_vtconsole(s->seat))
+ if (s->seat && seat_can_multi_session(s->seat))
fprintf(f,
"VTNR=%i\n",
s->vtnr);
seat_attach_session(o, s);
}
- if (vtnr && s->seat && seat_is_vtconsole(s->seat)) {
+ if (vtnr && s->seat && seat_can_multi_session(s->seat)) {
int v;
k = safe_atoi(vtnr, &v);
return r;
}
-
int manager_dispatch_vcsa_udev(Manager *m) {
struct udev_device *d;
int r = 0;
m->console_active_fd = open("/sys/class/tty/tty0/active", O_RDONLY|O_NOCTTY|O_CLOEXEC);
if (m->console_active_fd < 0) {
+
+ /* On certain architectures (S390 and Xen), /dev/tty0
+ does not exist, so don't fail if we can't open it.*/
+ if (errno == ENOENT)
+ return 0;
+
log_error("Failed to open /sys/class/tty/tty0/active: %m");
return -errno;
}