Page MenuHomeFreeBSD

freebsd-update(8): Use kern.module_path
ClosedPublic

Authored by fernape on Apr 15 2024, 12:20 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Dec 27, 1:19 AM
Unknown Object (File)
Nov 23 2024, 6:02 PM
Unknown Object (File)
Nov 23 2024, 12:47 PM
Unknown Object (File)
Nov 22 2024, 10:55 AM
Unknown Object (File)
Nov 22 2024, 12:01 AM
Unknown Object (File)
Nov 18 2024, 6:44 PM
Unknown Object (File)
Nov 16 2024, 9:52 PM
Unknown Object (File)
Nov 13 2024, 6:35 AM
Subscribers

Details

Summary

Instead of tailored configuration files to look for module_path entries.

Reported by: kevans@

Test Plan

Just try freebsd-update fetch upgrade

(yes, without the -r so the process will abort after the information message)

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 57125
Build 54013: arc lint + arc unit

Event Timeline

zlei added inline comments.
usr.sbin/freebsd-update/freebsd-update.sh
677

The following is from x86_64 QEMU VM:

# sysctl kern.module_path | cut -f2 -d\" | tr ";" "|"
/boot/kernel|/boot/modules|/boot/dtb|/boot/dtb/overlays

IIUC, 3rd party modules are not going to be installed into /boot/kernel . I'm not familiar with dtb parts, but I'd ask for confirmation if 3rd party modules will be installed into /boot/dtb or `/boot/dtb/overlays' ?

usr.sbin/freebsd-update/freebsd-update.sh
677

Likely not, but if they are then the same caveat applies -- the kernel and dtb are generally pretty closely coupled, and there's some risk if you end up upgrading one without the other.

Also, the cut step of the pipe can go away; use sysctl -n kern.module_path to omit the sysctl name and just get the value

679–680
This revision is now accepted and ready to land.Apr 15 2024, 4:10 PM
usr.sbin/freebsd-update/freebsd-update.sh
677

Likely not, but if they are then the same caveat applies -- the kernel and dtb are generally pretty closely coupled, and there's some risk if you end up upgrading one without the other.

Looks sane :)

Also, the cut step of the pipe can go away; use sysctl -n kern.module_path to omit the sysctl name and just get the value

usr.sbin/freebsd-update/freebsd-update.sh
679–680

Why? An empty sysctl is likely wrong, but loader.conf doesn't need any notion of a default because /boot/loader should always be passing it into the kernel for it to set it...

  • freebsd-update(8): Use kern.module_path
  • Address imp's comment.
This revision now requires review to proceed.Apr 16 2024, 4:28 PM
usr.sbin/freebsd-update/freebsd-update.sh
680

An empty kern.module_path should not happen. So does it ( an empty kern.module_path ) deserve an informative message ? Just in case ...

  • Add warning message when kern.module_path is empty
This revision is now accepted and ready to land.Apr 18 2024, 2:36 PM
This revision was automatically updated to reflect the committed changes.

Thank you all for the review.