You are not logged in.

#1 2024-09-11 13:08:44

joske
Member
Registered: 2024-09-11
Posts: 15

Zswap leads to trashing on default arch kernel (not zen kernel)

I'm experiencing complete lockups (doesn't even respond to ping), but sysreq still works. Several crashes today while running `cargo test` on big rust project. I had several of these over the course of the last few days. At first I thought it was virtualbox, but today I was not running any VMs. Nothing in logs about the crash.

Kernel was updated today to (6.10.9-arch1-2) but it does not fix the issue.

info:

CPU: 24-core (8-mt/16-st) 13th Gen Intel Core i9-13900K (-MST AMCP-)
speed/min/max: 811/800/5500:5800:4300 MHz Kernel: 6.10.9-arch1-2 x86_64
Up: 17m Mem: 5.47/31.09 GiB (17.6%) Storage: 3.29 TiB (13.5% used) Procs: 536
Shell: fish inxi: 3.3.35
Graphics:
  Device-1: AMD Ellesmere [Radeon RX 470/480/570/570X/580/580X/590]
    driver: amdgpu v: kernel
  Device-2: Logitech Logitech Webcam C925e driver: snd-usb-audio,uvcvideo
    type: USB
  Display: x11 server: X.Org v: 21.1.13 with: Xwayland v: 24.1.2 driver: X:
    loaded: amdgpu unloaded: modesetting,radeon dri: radeonsi gpu: amdgpu
    resolution: 1: 2560x1440~60Hz 2: 2560x1440~60Hz
  API: EGL v: 1.5 drivers: kms_swrast,radeonsi,swrast
    platforms: gbm,x11,surfaceless,device
  API: OpenGL v: 4.6 compat-v: 4.5 vendor: amd mesa v: 24.2.2-arch1.1
    renderer: AMD Radeon RX 580 Series (radeonsi polaris10 LLVM 18.1.8 DRM 3.57
    6.10.9-arch1-2)

It seems to be related to memory pressure. When I run 'cargo test' on my project, it consumes ridiculous amounts of memory, and this crashes the kernel EVERY single time. With LTS kernel, the OOM killer kills the terminal and kernel does not crash:

Out of memory: Killed process 306333 (snarkvm_synthes) total-vm:52890776kB, anon-rss:29081172kB, file-rss:512kB, shmem-rss:0kB, UID:1000 pgtables:72928kB oom_score_adj:200

System was rock solid before. Seems like a kernel regression as the LTS kernel does not lock up.

Last edited by joske (2024-09-16 06:26:50)

Offline

#2 2024-09-11 18:18:23

joske
Member
Registered: 2024-09-11
Posts: 15

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

The following command reproduces the lockup:

perl -wE 'my @xs; for (1..2**20) { push @xs, q{a} x 2**20 }; say scalar @xs;'

On LTS kernel 6.6.50-2-lts, the OOM killer just kills the process, on 6.10.9-arch1-2, the system locks up, fans still spinning, but not reacting, not even to pings.

On another system I was not able to reproduce this behaviour, there also the OOM killer killed the fork bomb and stayed responsive.

Offline

#3 2024-09-11 19:38:31

joske
Member
Registered: 2024-09-11
Posts: 15

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

I built my own 6.10.9 kernel from kernel.org using 'localmodconfig'. With that kernel, OOM killer works and system doesn't lock up. So the problem must lie with the arch patches.

Offline

#4 2024-09-11 19:50:40

joske
Member
Registered: 2024-09-11
Posts: 15

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

also the zen kernel doesn't lock up.

Offline

#5 2024-09-12 16:35:41

wtx
Member
Registered: 2014-06-09
Posts: 82

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

My suggestion is to publish somewhere complete log (dmesg) from your system. There should be additional information from kernel placed before or after OOM occurred.

Offline

#6 2024-09-12 18:03:48

joske
Member
Registered: 2024-09-11
Posts: 15

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

Like I said, there's nothing at all in the logs. When I check with 'journalctl -t kernel' it just shows the new boot

Offline

#7 2024-09-13 09:35:37

Lone_Wolf
Administrator
From: Netherlands, Europe
Registered: 2005-10-04
Posts: 13,150

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

Others may see things you missed.

Please reproduce the oom crash, after rebooting run as root

# journalctl -b -1 |  curl -F 'file=@-' 0x0.st

and post the link it will output.
(the -1 is to get the journal from the previous boot, if you need older boot logs use -2,-3 etc) .


Disliking systemd intensely, but not satisfied with alternatives so focusing on taming systemd.

clean chroot building not flexible enough ?
Try clean chroot manager by graysky

Offline

#8 2024-09-13 10:49:50

V1del
Forum Moderator
Registered: 2012-10-16
Posts: 23,606

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

FWIW the Arch patches are listed under https://github.com/archlinux/linux/rele … 0.10-arch1 for example. Of these the only thing I can imagine having any relevance is the increase in ASLR bits.

Offline

#9 2024-09-14 08:38:42

joske
Member
Registered: 2024-09-11
Posts: 15

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

Offline

#10 2024-09-14 08:40:43

joske
Member
Registered: 2024-09-11
Posts: 15

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

with zen kernel, no lockup: http://0x0.st/XxGR.txt

Offline

#11 2024-09-14 10:04:07

wtx
Member
Registered: 2014-06-09
Posts: 82

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

What is on the screen when the system is lockup? If you are in X-Window session try to switch it to virtual terminal mode (the text one).
Additionally you can configure serial console (rs 232 directly - real HW with UART, not USB-to-rs232 adapter) for this PC if it is possible and then check the messages on the screen.

Make a photo of the screen and publish it somewhere. Put link to this photo here. We will take a look at it.

Offline

#12 2024-09-14 12:46:27

Lone_Wolf
Administrator
From: Netherlands, Europe
Registered: 2005-10-04
Posts: 13,150

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

sep 14 10:36:45 silence gnome-shell[2333]: Extension apps-menu@gnome-shell-extensions.gcampax.github.com already installed in /home/jos/.local/share/gnome-shell/extensions/apps-menu@gnome-shell-extensions.gcampax.github.com. /usr/share/gnome-shell/extensions/apps-menu@gnome-shell-extensions.gcampax.github.com will not be loaded
sep 14 10:36:45 silence gnome-shell[2333]: Extension auto-move-windows@gnome-shell-extensions.gcampax.github.com already installed in /home/jos/.local/share/gnome-shell/extensions/auto-move-windows@gnome-shell-extensions.gcampax.github.com. /usr/share/gnome-shell/extensions/auto-move-windows@gnome-shell-extensions.gcampax.github.com will not be loaded
sep 14 10:36:45 silence gnome-shell[2333]: Extension launch-new-instance@gnome-shell-extensions.gcampax.github.com already installed in /home/jos/.local/share/gnome-shell/extensions/launch-new-instance@gnome-shell-extensions.gcampax.github.com. /usr/share/gnome-shell/extensions/launch-new-instance@gnome-shell-extensions.gcampax.github.com will not be loaded
sep 14 10:36:45 silence gnome-shell[2333]: Extension native-window-placement@gnome-shell-extensions.gcampax.github.com already installed in /home/jos/.local/share/gnome-shell/extensions/native-window-placement@gnome-shell-extensions.gcampax.github.com. /usr/share/gnome-shell/extensions/native-window-placement@gnome-shell-extensions.gcampax.github.com will not be loaded
sep 14 10:36:45 silence gnome-shell[2333]: Extension screenshot-window-sizer@gnome-shell-extensions.gcampax.github.com already installed in /home/jos/.local/share/gnome-shell/extensions/screenshot-window-sizer@gnome-shell-extensions.gcampax.github.com. /usr/share/gnome-shell/extensions/screenshot-window-sizer@gnome-shell-extensions.gcampax.github.com will not be loaded
sep 14 10:36:45 silence gnome-shell[2333]: Extension user-theme@gnome-shell-extensions.gcampax.github.com already installed in /home/jos/.local/share/gnome-shell/extensions/user-theme@gnome-shell-extensions.gcampax.github.com. /usr/share/gnome-shell/extensions/user-theme@gnome-shell-extensions.gcampax.github.com will not be loaded

You appear to be using a local version of extensions that are also present in the gnome systemwide install.
Is this intentional ?

There are atleast 2 coredumps at the bottom of the log, and it looks like they are related to dleyna-renderer-service  .
In the log from the zen kernel there's no sign of dleyna or coredumps .

I suggest you ensure dleyna is inactive while booted in the stock kernel and try to reproduce the crash.

Last edited by Lone_Wolf (2024-09-14 12:47:42)


Disliking systemd intensely, but not satisfied with alternatives so focusing on taming systemd.

clean chroot building not flexible enough ?
Try clean chroot manager by graysky

Offline

#13 2024-09-14 18:41:45

joske
Member
Registered: 2024-09-11
Posts: 15

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

What happens is, screen stays active, cursor doesn't move anymore, no corruption on screen. I can still see disk activity, and fans are spinning up. Switching VT does not work, system does not react to any key. Alt-SysRq does work.
https://photos.app.goo.gl/jrxa98asXY9281ha6

I was not aware of the extension duplicates. I removed the local versions. I also deleted dleyna.

Triggered the issue again with default kernel: http://0x0.st/Xx5B.txt

Last edited by joske (2024-09-14 18:46:24)

Offline

#14 2024-09-14 18:49:27

joske
Member
Registered: 2024-09-11
Posts: 15

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

I think the kernel doesn't really lock up, but is just trashing non-stop (RAM + swap full) without triggering OOM

Offline

#15 2024-09-14 18:51:26

joske
Member
Registered: 2024-09-11
Posts: 15

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

The system does have a real serial port (but disabled in BIOS). Need to dig out my old serial cables, it's been a long time that I had to use this :-D

Offline

#16 2024-09-14 21:27:13

wtx
Member
Registered: 2014-06-09
Posts: 82

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

What happens is, screen stays active, cursor doesn't move anymore, no corruption on screen. I can still see disk activity, and fans are spinning up. Switching VT does not work, system does not react to any key. Alt-SysRq does work.

You could try to switch to VT *before* you start perl test application and then take the picture of the screen while still in VT mode.
Then you can also use some of the SYSRQ combinations like "m" and then "e" and check if after "e" the system recovered from the thrashing.

Last edited by wtx (2024-09-14 21:32:07)

Offline

#17 2024-09-15 07:46:58

seth
Member
Registered: 2012-09-03
Posts: 60,393

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

bijiben crash looks like https://bbs.archlinux.org/viewtopic.php?id=295914 and isn't in the (shorter) zen kernel boot, do you eventually get those there as well?


Next to the ASLR bits, try to add "transparent_hugepage=never" (general advise) to the kernel commandline and disable https://wiki.archlinux.org/title/Zswap because that can massively blow up when decompressing the swap.

If you're running OOM (incl. swap) thrashing becomes inevitable until the OOM killer steps in, you can drive the latter more aggressively but of course probably first and foremost want to prevent an unwarranted OOM.

Finally

System was rock solid before.

Which kernel was the last good one?

Online

#18 2024-09-15 18:06:48

joske
Member
Registered: 2024-09-11
Posts: 15

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

Yes bijiben crash always happens, I've been trying to look into this, but never found a solution. Seems harmless though.

I don't know which kernel was fine, as I don't usually run 8 VMs (as I needed to do for work). This was the first crash, but I blamed that one on virtualbox modules. Also I had to run rust unit tests a few days later that for some reason blow up memory, that's how I noticed that it was strange and reproducible (system would hang every time I was running those tests). That it uses so much memory was known (but not by me :-D) and I can't fix those now.

Offline

#19 2024-09-15 18:21:11

joske
Member
Registered: 2024-09-11
Posts: 15

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

Tried now on the latest 6.10.10-arch1-1 kernel, and system still becomes unresponsive. This time I let it run a bit longer, but didn't recover. Then I tried to do alt-sysrq-k, this killed the terminal and the perl process, and system was working again.

I think the logs now have something maybe useful: http://0x0.st/X3-b.txt

Offline

#20 2024-09-15 18:29:22

joske
Member
Registered: 2024-09-11
Posts: 15

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

AHA! I disabled zwap at runtime, and did swapoff/swapon, and now the same kernel OOM killed the perl process!

Last edited by joske (2024-09-15 18:29:54)

Offline

#21 2024-09-15 22:06:23

seth
Member
Registered: 2012-09-03
Posts: 60,393

Re: Zswap leads to trashing on default arch kernel (not zen kernel)

systool -vm zswap

compare the output among kernels.
But with little phsyical swap, much RAM, a large enough https://wiki.archlinux.org/title/Zswap# … _pool_size and highly compressible data I can see how the principal concept has explosive potential and you may end up juggling pages between the physcal swap and the cache instead of killing the process.

You might wantto stress your finding in the subject ("zswap leads to trashing" or sth. like that) and try to constrain the pool (more) to keep more RAM and write back the zswap cache more gradually.
Did you also test to disable THP?

Online

Board footer

Powered by FluxBB