From 12e58deaa909c5d87bcb56ad6c47e33f5740722b Mon Sep 17 00:00:00 2001 From: Ray Strode 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 +#include +#include + +#include + +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.21.0