]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
logind: open device if needed
authorLennart Poettering <lennart@poettering.net>
Fri, 2 Mar 2018 10:55:51 +0000 (11:55 +0100)
committerLennart Poettering <lennart@poettering.net>
Fri, 2 Mar 2018 10:55:51 +0000 (11:55 +0100)
Fixes: #8291
src/login/logind-session-device.c

index db148d191637c78eb2363c5e25e6b07292e796ea..b7476e7d087374d634d9c8adee45e4a8632c1bee 100644 (file)
@@ -193,11 +193,19 @@ static int session_device_start(SessionDevice *sd) {
         switch (sd->type) {
 
         case DEVICE_TYPE_DRM:
-                /* Device is kept open. Simply call drmSetMaster() and hope there is no-one else. In case it fails, we
-                 * keep the device paused. Maybe at some point we have a drmStealMaster(). */
-                r = sd_drmsetmaster(sd->fd);
-                if (r < 0)
-                        return r;
+
+                if (sd->fd < 0) {
+                        /* Open device if it isn't open yet */
+                        sd->fd = session_device_open(sd, true);
+                        if (sd->fd < 0)
+                                return sd->fd;
+                } else {
+                        /* Device is kept open. Simply call drmSetMaster() and hope there is no-one else. In case it fails, we
+                         * keep the device paused. Maybe at some point we have a drmStealMaster(). */
+                        r = sd_drmsetmaster(sd->fd);
+                        if (r < 0)
+                                return r;
+                }
                 break;
 
         case DEVICE_TYPE_EVDEV: