Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Linux 6.13 compat #16831

Draft
wants to merge 1 commit into
base: master
Choose a base branch
from
Draft

Linux 6.13 compat #16831

wants to merge 1 commit into from

Conversation

robn
Copy link
Member

@robn robn commented Dec 3, 2024

Motivation and Context

Regular prep for new kernel series.

Description

Astonishingly, there appear to be NO CHANGES required. So for the moment, this PR is simply a placeholder for anything that might come up during the 6.13-rc series.

(I wouldn't normally bump META, but I had to commit something to be allowed to create a PR).

How Has This Been Tested?

Full ZTS runs on 6.13-rc1, rc2, rc3 and rc5 completed successfully.

Types of changes

  • Bug fix (non-breaking change which fixes an issue)
  • New feature (non-breaking change which adds functionality)
  • Performance enhancement (non-breaking change which improves efficiency)
  • Code cleanup (non-breaking change which makes code smaller or more readable)
  • Breaking change (fix or feature that would cause existing functionality to change)
  • Library ABI change (libzfs, libzfs_core, libnvpair, libuutil and libzfsbootenv)
  • Documentation (a change to man pages or other documentation)

Checklist:

No changes from 6.12 🤯

Sponsored-by: https://despairlabs.com/sponsor/
Signed-off-by: Rob Norris <robn@despairlabs.com>
@robn robn marked this pull request as draft December 3, 2024 00:46
@github-actions github-actions bot added the Status: Work in Progress Not yet ready for general review label Dec 3, 2024
@behlendorf behlendorf added Status: Accepted Ready to integrate (reviewed, tested) Status: Work in Progress Not yet ready for general review and removed Status: Work in Progress Not yet ready for general review Status: Accepted Ready to integrate (reviewed, tested) labels Dec 6, 2024
Copy link
Contributor

@tonyhutter tonyhutter left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Astonishingly, there appear to be NO CHANGES required.

😮 wow hopefully that holds true for the rest of the RCs!

@robn
Copy link
Member Author

robn commented Dec 11, 2024

Test suite passed against 6.13-rc2.

@robn
Copy link
Member Author

robn commented Dec 18, 2024

Test suite passed against 6.13-rc3.

@robn
Copy link
Member Author

robn commented Jan 5, 2025

Test suite passed against 6.13-rc5.

@robn
Copy link
Member Author

robn commented Jan 7, 2025

Alas, rc6 broken twice. The first run had a deadlock between txg_sync and a /usr/sbin/zfs call somewhere. The second run has livelocked in txg_sync. No obvious single test involved. I'll do another run with rc5 to see if it seems right, and if so, will review the rc5->rc6 changes to see what happened.

@robn
Copy link
Member Author

robn commented Jan 8, 2025

rc5 crashed too

shop login: [21133.659386] Kernel panic - not syncing: buffer modified while frozen!
[21133.659592] CPU: 1 UID: 0 PID: 49649 Comm: dbuf_evict Tainted: P           OE      6.13.0-rc5 #2
[21133.659860] Tainted: [P]=PROPRIETARY_MODULE, [O]=OOT_MODULE, [E]=UNSIGNED_MODULE
[21133.660088] Hardware name: FreeBSD BHYVE/BHYVE, BIOS 14.0 10/17/2021
[21133.660284] Call Trace:
[21133.660370]  <TASK>
[21133.660443]  panic+0x340/0x3a0
[21133.660552]  arc_cksum_verify+0x210/0x210 [zfs]
[21133.660938]  arc_buf_destroy_impl+0x38/0x330 [zfs]
[21133.661212]  arc_buf_destroy+0xf7/0x370 [zfs]
[21133.661474]  ? __pfx_thread_generic_wrapper+0x10/0x10 [spl]
[21133.661658]  dbuf_destroy+0x5d/0x790 [zfs]
[21133.661921]  ? __pfx_thread_generic_wrapper+0x10/0x10 [spl]
[21133.662100]  dbuf_evict_one+0x14a/0x1d0 [zfs]
[21133.662328]  ? __pfx_dbuf_evict_thread+0x10/0x10 [zfs]
[21133.662328]  dbuf_evict_thread+0x128/0x280 [zfs]
[21133.662328]  thread_generic_wrapper+0x62/0x90 [spl]
[21133.662328]  kthread+0xce/0x100
[21133.662328]  ? __pfx_kthread+0x10/0x10
[21133.662328]  ret_from_fork+0x30/0x50
[21133.662328]  ? __pfx_kthread+0x10/0x10
[21133.662328]  ret_from_fork_asm+0x1a/0x30
[21133.662328]  </TASK>

I'll try again, but I'm also low-key wondering if we've changed something (I'm always running these tests against master).

@robn
Copy link
Member Author

robn commented Jan 9, 2025

And here's a crash on rc5, master @ 18c67d2. It completed a run on rc5 yesterday, this was a second run overnight:

[Fri Jan 10 10:09:43 2025] ZTS run /usr/local/share/zfs/zfs-tests/tests/functional/cache/cache_003_pos
[Fri Jan 10 10:10:09 2025] VERIFY3(vd->vdev_trim_thread == NULL) failed (ffff8c3d6ab24c80 == 0000000000000000)
[Fri Jan 10 10:10:09 2025] PANIC at vdev_trim.c:1703:vdev_trim_l2arc()
[Fri Jan 10 10:10:09 2025] Showing stack for process 2536603
[Fri Jan 10 10:10:09 2025] CPU: 3 UID: 0 PID: 2536603 Comm: spa_async Tainted: P           OE      6.13.0-rc5 #2
[Fri Jan 10 10:10:09 2025] Tainted: [P]=PROPRIETARY_MODULE, [O]=OOT_MODULE, [E]=UNSIGNED_MODULE
[Fri Jan 10 10:10:09 2025] Hardware name: FreeBSD BHYVE/BHYVE, BIOS 14.0 10/17/2021
[Fri Jan 10 10:10:09 2025] Call Trace:
[Fri Jan 10 10:10:09 2025]  <TASK>
[Fri Jan 10 10:10:09 2025]  dump_stack_lvl+0x60/0x80
[Fri Jan 10 10:10:09 2025]  spl_panic+0xfc/0x120 [spl]
[Fri Jan 10 10:10:09 2025]  ? srso_alias_return_thunk+0x5/0xfbef5
[Fri Jan 10 10:10:09 2025]  ? __mutex_lock.constprop.0+0x3f0/0x730
[Fri Jan 10 10:10:09 2025]  ? __pfx_thread_generic_wrapper+0x10/0x10 [spl]
[Fri Jan 10 10:10:09 2025]  vdev_trim_l2arc+0x264/0x2e0 [zfs]
[Fri Jan 10 10:10:09 2025]  spa_async_thread+0x466/0xa40 [zfs]
[Fri Jan 10 10:10:09 2025]  ? __pfx_spa_async_thread+0x10/0x10 [zfs]
[Fri Jan 10 10:10:09 2025]  ? __pfx_thread_generic_wrapper+0x10/0x10 [spl]
[Fri Jan 10 10:10:09 2025]  thread_generic_wrapper+0x62/0x90 [spl]
[Fri Jan 10 10:10:09 2025]  kthread+0xce/0x100
[Fri Jan 10 10:10:09 2025]  ? __pfx_kthread+0x10/0x10
[Fri Jan 10 10:10:09 2025]  ret_from_fork+0x30/0x50
[Fri Jan 10 10:10:09 2025]  ? __pfx_kthread+0x10/0x10
[Fri Jan 10 10:10:09 2025]  ret_from_fork_asm+0x1a/0x30
[Fri Jan 10 10:10:09 2025]  </TASK>

I'll try to reproduce it more reliably, because I still can't really guess if its a recent regression on our side, or it just didn't show up in earlier 6.13 runs because its hard to hit.

@darkbasic
Copy link

Any clue about whether this is a regression on our side?

@robn
Copy link
Member Author

robn commented Jan 16, 2025

Uncertain. I've hit that vdev_trim_thread panic once more since. The crash I currently have on the table is a namespace lock deadlock, but that's an old bug I believe; I can't see why it would be new here. So I'll look to fix that first, at least its isolated.

Mostly, I've had almost no time to look into it, and won't really for at least another week or so - I'm heading to a conference and then a short vacation on Saturday.

@ascendbeing
Copy link

hey @robn I was briefly trying this again but with 6.12.10-gentoo, and I appear to have experienced a crash. I was in the cli doing my thing and the display blanked and my system restarted.
I was using Nvidia kernel-open 550.x while this happened. 550.x is the stable branch and builds without patches against 6.13 but usually I use 565.
I'll try to find anything resembling a log later.

@yshui
Copy link
Contributor

yshui commented Jan 23, 2025

(coming from NixOS) make install seems to not work anymore? It doesn't install the kernel modules.

@yshui
Copy link
Contributor

yshui commented Jan 23, 2025

yeah i think make -C @LINUX_OBJ@ chdir into the kernel build dir. the kernel's Makefile.modinst then tries to read modules.order from there and can't find it.

should probably be make -f @LINUX_OBJ@/Makefile (don't know if this works on <6.13)

patch
diff --git a/module/Makefile.in b/module/Makefile.in
index f76e94afa..c735f0df7 100644
--- a/module/Makefile.in
+++ b/module/Makefile.in
@@ -87,7 +87,7 @@ modules_uninstall-Linux-legacy:
 KMODDIR := $(INSTALL_MOD_PATH)/lib/modules/@LINUX_VERSION@
 modules_install-Linux: modules_uninstall-Linux-legacy
 	@# Install the kernel modules
-	$(MAKE) -C @LINUX_OBJ@ M="$$PWD" modules_install \
+	$(MAKE) -f @LINUX_OBJ@/Makefile M="$$PWD" modules_install \
 		INSTALL_MOD_PATH=$(INSTALL_MOD_PATH) \
 		INSTALL_MOD_DIR=$(INSTALL_MOD_DIR) \
 		$(if @KERNEL_ARCH@,ARCH=@KERNEL_ARCH@) \

upstream change: torvalds/linux@13b2548, torvalds/linux@bad6beb

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Status: Work in Progress Not yet ready for general review
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants