From b036ad9b547f6b0bdc7ee248fbf3166621f733bb Mon Sep 17 00:00:00 2001 From: Drew DeVault Date: Mon, 3 Apr 2017 07:44:36 -0400 Subject: [PATCH 1/2] Downgrade nvidia proprietary driver warning --- sway/main.c | 3 +-- sway/sway.1.txt | 3 --- 2 files changed, 1 insertion(+), 5 deletions(-) diff --git a/sway/main.c b/sway/main.c index b9f8936f1..ab6ecc1f6 100644 --- a/sway/main.c +++ b/sway/main.c @@ -63,8 +63,7 @@ void detect_proprietary() { break; } if (strstr(line, "nvidia")) { - fprintf(stderr, "\x1B[1;31mWarning: Proprietary nvidia drivers do NOT support Wayland. Use nouveau.\x1B[0m\n"); - fprintf(stderr, "\x1B[1;31mYes, they STILL don't work with the newly announced wayland \"support\".\x1B[0m\n"); + fprintf(stderr, "\x1B[1;31mWarning: Proprietary nvidia driver support is considered experimental.\x1B[0m\n"); free(line); break; } diff --git a/sway/sway.1.txt b/sway/sway.1.txt index 1a77611dd..bc827bd58 100644 --- a/sway/sway.1.txt +++ b/sway/sway.1.txt @@ -51,9 +51,6 @@ rather than switch to something else. Launch sway directly from a tty or via your favorite Wayland-compatible login manager. -*Important note for nvidia users*: The proprietary nvidia driver does _not_ have -support for Wayland as of 2016-06-10. Use nouveau. - Commands -------- From b3541d9dc5e3037889026d3d918b174d9ecc9567 Mon Sep 17 00:00:00 2001 From: Drew DeVault Date: Wed, 12 Apr 2017 10:04:28 -0400 Subject: [PATCH 2/2] Implement more thourough nvidia config check --- sway/main.c | 39 +++++++++++++++++++++++++++++++++++---- 1 file changed, 35 insertions(+), 4 deletions(-) diff --git a/sway/main.c b/sway/main.c index ab6ecc1f6..39bf225e4 100644 --- a/sway/main.c +++ b/sway/main.c @@ -57,24 +57,55 @@ void detect_proprietary() { if (!f) { return; } + bool nvidia = false, nvidia_modeset = false, nvidia_uvm = false, nvidia_drm = false; while (!feof(f)) { char *line; if (!(line = read_line(f))) { break; } if (strstr(line, "nvidia")) { - fprintf(stderr, "\x1B[1;31mWarning: Proprietary nvidia driver support is considered experimental.\x1B[0m\n"); - free(line); - break; + nvidia = true; + } + if (strstr(line, "nvidia_modeset")) { + nvidia_modeset = true; + } + if (strstr(line, "nvidia_uvm")) { + nvidia_uvm = true; + } + if (strstr(line, "nvidia_drm")) { + nvidia_drm = true; } if (strstr(line, "fglrx")) { - fprintf(stderr, "\x1B[1;31mWarning: Proprietary AMD drivers do NOT support Wayland. Use radeon.\x1B[0m\n"); + fprintf(stderr, "\x1B[1;31mWarning: Proprietary AMD drivers do " + "NOT support Wayland. Use radeon.\x1B[0m\n"); free(line); break; } free(line); } fclose(f); + if (nvidia) { + fprintf(stderr, "\x1B[1;31mWarning: Proprietary nvidia driver support " + "is considered experimental. Nouveau is strongly recommended." + "\x1B[0m\n"); + if (!nvidia_modeset || !nvidia_uvm || !nvidia_drm) { + fprintf(stderr, "\x1B[1;31mWarning: You do not have all of the " + "necessary kernel modules loaded for nvidia support. " + "You need nvidia, nvidia_modeset, nvidia_uvm, and nvidia_drm." + "\x1B[0m\n"); + } + f = fopen("/proc/cmdline", "r"); + if (f) { + char *line = read_line(f); + if (line && !strstr(line, "nvidia-drm.modeset=1")) { + fprintf(stderr, "\x1B[1;31mWarning: You must add " + "nvidia-drm.modeset=1 to your kernel command line to use " + "the proprietary driver.\x1B[0m\n"); + } + fclose(f); + free(line); + } + } } void run_as_ipc_client(char *command, char *socket_path) {