162 lines
4.2 KiB
Diff
162 lines
4.2 KiB
Diff
From 14656db42a6b4d4d48cf74127f3187dfe85607ec Mon Sep 17 00:00:00 2001
|
|
From: Ray Strode <rstrode@redhat.com>
|
|
Date: Mon, 21 May 2018 15:03:29 +0000
|
|
Subject: [PATCH] utils: add new gdm-disable-wayland binary
|
|
|
|
We currently disable wayland for cirrus by calling printf
|
|
from a udev rule. This works, but it's a little too open
|
|
coded to easily write SELinux policy for.
|
|
|
|
This commit introduces a new program, gdm-disable-wayland,
|
|
that does the same thing, but in a dedicated binary.
|
|
|
|
A future commit will change the udev rule to use the binary.
|
|
|
|
https://bugzilla.gnome.org/show_bug.cgi?id=796315
|
|
|
|
|
|
(cherry picked from commit 2dc57da31781dedfe374ce353b0f5fd6aa9da56f)
|
|
---
|
|
utils/Makefile.am | 14 ++++++++++
|
|
utils/gdm-disable-wayland.c | 53 +++++++++++++++++++++++++++++++++++++
|
|
2 files changed, 67 insertions(+)
|
|
create mode 100644 utils/gdm-disable-wayland.c
|
|
|
|
diff --git a/utils/Makefile.am b/utils/Makefile.am
|
|
index ae3cc01fb..babe890b9 100644
|
|
--- a/utils/Makefile.am
|
|
+++ b/utils/Makefile.am
|
|
@@ -1,56 +1,70 @@
|
|
NULL =
|
|
|
|
AM_CPPFLAGS = \
|
|
-I$(srcdir) \
|
|
-I$(builddir) \
|
|
-I$(top_srcdir) \
|
|
-I$(top_builddir) \
|
|
-I$(top_srcdir)/common \
|
|
-I$(top_builddir)/common \
|
|
-DDATADIR=\"$(datadir)\" \
|
|
-DGDMCONFDIR=\"$(gdmconfdir)\" \
|
|
-DLOCALSTATEDIR=\""$(localstatedir)"\" \
|
|
+ -DGDM_RUN_DIR=\"$(GDM_RUN_DIR)\" \
|
|
+ -DGDM_RUNTIME_CONF=\"$(GDM_RUNTIME_CONF)\" \
|
|
-DGDM_SCREENSHOT_DIR=\""$(GDM_SCREENSHOT_DIR)"\"\
|
|
-DGNOMELOCALEDIR=\""$(datadir)/locale"\" \
|
|
$(UTILS_CFLAGS) \
|
|
$(CANBERRA_GTK_CFLAGS) \
|
|
$(GTK_CFLAGS) \
|
|
$(XLIB_CFLAGS) \
|
|
$(SYSTEMD_CFLAGS) \
|
|
$(COMMON_CFLAGS) \
|
|
$(NULL)
|
|
|
|
edit = sed \
|
|
-e 's|@sbindir[@]|$(sbindir)|g' \
|
|
-e 's|@sysconfdir[@]|$(sysconfdir)|g' \
|
|
-e 's|@localstatedir[@]|$(localstatedir)|g' \
|
|
-e 's|@GDM_PID_FILE[@]|$(GDM_PID_FILE)|g'
|
|
|
|
bin_PROGRAMS = \
|
|
gdmflexiserver \
|
|
gdm-screenshot \
|
|
$(NULL)
|
|
|
|
+libexec_PROGRAMS = \
|
|
+ gdm-disable-wayland \
|
|
+ $(NULL)
|
|
+
|
|
gdmflexiserver_LDADD = \
|
|
$(top_builddir)/common/libgdmcommon.la \
|
|
$(GTK_LIBS) \
|
|
$(COMMON_LIBS) \
|
|
$(SYSTEMD_LIBS) \
|
|
$(NULL)
|
|
|
|
gdm_screenshot_SOURCES = \
|
|
gdm-screenshot.c \
|
|
$(NULL)
|
|
|
|
gdm_screenshot_LDADD = \
|
|
$(GTK_LIBS) \
|
|
$(CANBERRA_GTK_LIBS) \
|
|
$(XLIB_LIBS) \
|
|
$(COMMON_LIBS) \
|
|
$(NULL)
|
|
|
|
+gdm_disable_wayland_LDADD = \
|
|
+ $(COMMON_LIBS) \
|
|
+ $(NULL)
|
|
+
|
|
+gdm_disable_wayland_SOURCES = \
|
|
+ gdm-disable-wayland.c \
|
|
+ $(NULL)
|
|
+
|
|
CLEANFILES = \
|
|
$(NULL)
|
|
|
|
DISTCLEANFILES = \
|
|
$(NULL)
|
|
diff --git a/utils/gdm-disable-wayland.c b/utils/gdm-disable-wayland.c
|
|
new file mode 100644
|
|
index 000000000..be61c4d8f
|
|
--- /dev/null
|
|
+++ b/utils/gdm-disable-wayland.c
|
|
@@ -0,0 +1,53 @@
|
|
+/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*-
|
|
+ *
|
|
+ * Copyright (C) 2018 Red Hat, Inc.
|
|
+ *
|
|
+ * This program is free software; you can redistribute it and/or modify
|
|
+ * it under the terms of the GNU General Public License as published by
|
|
+ * the Free Software Foundation; either version 2 of the License, or
|
|
+ * (at your option) any later version.
|
|
+ *
|
|
+ * This program is distributed in the hope that it will be useful,
|
|
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
+ * GNU General Public License for more details.
|
|
+ *
|
|
+ * You should have received a copy of the GNU General Public License
|
|
+ * along with this program; if not, write to the Free Software
|
|
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
+ *
|
|
+ */
|
|
+
|
|
+#include "config.h"
|
|
+
|
|
+#include <locale.h>
|
|
+#include <stdlib.h>
|
|
+#include <sysexits.h>
|
|
+
|
|
+#include <glib.h>
|
|
+
|
|
+int
|
|
+main (int argc, char *argv[])
|
|
+{
|
|
+ g_autoptr(GKeyFile) key_file = NULL;
|
|
+ g_autoptr(GError) error = NULL;
|
|
+ gboolean saved_okay;
|
|
+
|
|
+ setlocale (LC_ALL, "");
|
|
+
|
|
+ key_file = g_key_file_new ();
|
|
+
|
|
+ g_key_file_set_boolean (key_file, "daemon", "WaylandEnable", FALSE);
|
|
+
|
|
+ g_mkdir_with_parents (GDM_RUN_DIR, 0711);
|
|
+
|
|
+ saved_okay = g_key_file_save_to_file (key_file, GDM_RUNTIME_CONF, &error);
|
|
+
|
|
+ if (!saved_okay) {
|
|
+ g_printerr ("gdm-disable-wayland: unable to disable wayland: %s",
|
|
+ error->message);
|
|
+ return EX_CANTCREAT;
|
|
+ }
|
|
+
|
|
+ return EX_OK;
|
|
+}
|
|
--
|
|
2.17.1
|
|
|