Windows has fully user space graphics drivers since Vista. Linux still utilizes kernel modules and I'm not aware of plans to move everything to user space. It's honestly pretty cool that entire graphics driver can crash under Windows and all that happens is a bit of flickering.
Linux
From Wikipedia, the free encyclopedia
Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).
Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.
Rules
- Posts must be relevant to operating systems running the Linux kernel. GNU/Linux or otherwise.
- No misinformation
- No NSFW content
- No hate speech, bigotry, etc
Related Communities
Community icon by Alpár-Etele Méder, licensed under CC BY 3.0
Are you sure? It seems like WDDM has a user-mode "User-mode display driver" - which looks to me like the HW-specific part of Mesa: it's invoked by the D3D runtime - and a "Display miniport driver", which is in the kernel.
That said, no doubt Linux's ability to reset drivers is way, way behind... We're coming up on 20 years since Windows could recover from a graphics driver reset reliably without losing the desktop, and only partial hacks exist on Linux today.
I really need to get around to building a sample HTML page to show how unsafe having WebGL enabled on Linux browsers is. One long shader, and your desktop is a goner.
Are you sure?
I'm not a Windows system architect but I see the Radeon driver on my iGPU under Windows crash all the time in reproducible scenarios.
The only time the system can recover is when the display compositor crashes (Wayland)
This is a huge advantage of Windows...
@woelkchen @flork did they move all that font kerning stuff / gdi stuff out of the kernel too? i remember that was a 'thing' for a long time in 2000/xp/7 it was like a mini-vm that ran in kernel space and had lots of bugs
It doesn't matter much what Linux you use. Rather what is your desktop environment? (KDE Plasma, Gnome, sway etc.)
On KDE for example there is a shortcut to restart the compositor, which might fix your issue.
But in general you might have luck "restarting" it by switching the tty. You do that by pressing CTRL + ALT + some function key between F1 and F8 (the standard gui tty number depends on the distro). Try to switch to a non gui tty and then back.
For example, on my distro I would do:
- CTRL + ALT + F1
- CTRL + ALT + F2
but on yours it might be F7 or some other.
+1 to ctrl-alt-fsomething (start at f1 and go up to move through the different virtual terminals). once in a while there are graphics problems which this will fix.
If you're using GNOME Shell on X you can reload the shell (and all of its extensions) with alt-f2 and then in the "Run a command" dialog that appears type r
and hit enter. Unfortunately this doesn't work in GNOME on Wayland.
I agree with Ctrl+Alt+F1/F2 but would add
init 3 init 5
but I learned for my case its better to reboot if my GPU is acting up the instability would eventually come back
the init command probably only works in Debian nowadays givin it's a thing from the sysvinit era
Thanks Zorin OS uses GNOME with Wayland
While these can help on other issues, these will do nothing if the driver has an unrecoverable issue.
If the kernel runs into a oops it can recover and you won't notice anything except a nasty looking error in dmesg. If it runs into a panic you need to hard reboot the system as it can't continue to run.
And the driver is stuffed if the hardware decides to have an unrecoverable issue.
(I'm looking at you, Intel GuC. You dumb little bastard.)
amdgpu
has a recovery mechanism built in that can be triggered using sudo cat /sys/kernel/debug/dri/N/amdgpu_gpu_recover
where N is the number of the DRI device in question. You could bind a shortcut to doing that I presume.
Hmm I have AMD but I'm getting No such file or directory
Which part of the path does not exist?
Is it the correct GPU number?
I have an AMDGPU machine - a hateful HP laptop with a Vega 6 chipset - and the display regularly goes garbled when I switch VTs. I too am looking for a way to "reset the graphics card" and cat /sys/kernel/debug/dri/N/amdgpu_gpu_recover
ain't it: it resets it alright, but after that you get a frozen image and X is dead.
Maybe Wayland survives that but Xorg definitely doesn't.
The only reliable graphics card reset solution I've every found was to close then reopen the laptop to force the machine to go to sleep, then wake up and go through the restart rigmarole cleanly. I wish there was a way to do that sleep-wakeup routing with a keyboard shortcut, but I haven't found one.
I think the real solution is to buy a decent replacement laptop though.
Yeah, Xorg (and the apps) will likely die. There is a wayland protocol in the works to be able to gracefully handle driver resets but I'm not sure on its implementation status.
Is that function a niche thing? I've never needed it and don't know anybody who has... What are some situations where it might need to be used?
I have a case. My PC at work is a HP Celeron PC. For some reason the Intel HD drivers go nuts in Office and the whole ribbon just turns black. That spreads to all other applications and makes every signel menu bar just a black rectangle. The only solution to this is to restart the driver. No driver or windows update could fix it.
If no drivers or windows update could fix it, are you sure it's not a hardware issue? What you describe sounds similar to bad VRAM symptoms.
Happens only in Office. No other program has ever triggered it. So it's either Intel or HP or Windows, but since it is the lowest offering of hardware and software, probably a combination of all 3.
I think the question is, is it needed in your favourite Linux distro?
I guess not, since you would need GPU drivers in the first place /s
Linux has different drivers so the issue may be fixed. Oh and avoid using Wayland on that GPU. In case it fails all unsaved data will be lost
exactly my thought
Maybe sudo systemctl restart gdm
? That's not quite the same as it restarts gnome display manager.
When your computer freezes and you can't get to a tty with Ctrl+alt+F4 then it likely encountered a kernel panic. A panic is not recoverable. In some senerios I've seen the amdgpu module run into a kernel oops which is recoverable. It doesn't really effect the desktop other than a studder as the kernel reinitializes in the background.
If your system is freezing start by checking RAM and then try a different GPU. Its likely a hardware issue
Ctrl+alt+backspace
I think on some distros this is disabled by default. I have forgotten how you can re-enable it.
Doesn't that kill X11?
There used to exist a hotkey CTRL-ALT-BKSP for restarting your current X-Session, don't know if this still exists
That's specific to X11. It also wasn't always enabled for security reasons (breaking out of a locked screen). Now with Wayland there's no standard.
How is it a security risk to break out of a lock screen only to end up at a login screen?
You wouldn't end up at a login screen, you'd end up in the last logged in user's session.
Additionally, it terminated all gui processes. Which the windows shortcut mentioned in the question doesn't.
There is a proposal to consider making a Wayland extension where programs can sit around and re-attach to a fresh, non-deaded display server. KDE is much closer to having a working version.
That doesn't restart anything. That kills the X11 server.
It may or may not restart depending on system settings.
That doesn't work for Wayland and I'm unsure which one Zorin uses
It uses Wayland
That is just the key to kill the X server. It does not restart anything.
I was thinking of that when I read this and was like. windows has something like this???
Please explain why you need that in the post.
Average linux help post, someone comes along saying "why do you need that" instead of being helpful lol
And you know if I had actually given an answer he would have just told me why his way of doing things is better.