[Bug 2007827] Re: [SRU] flash-kernel failure when upgrading f-k and kernel in the same cycle

Steve Langasek 2007827 at bugs.launchpad.net
Fri Jun 23 17:40:57 UTC 2023


Dave, I don't agree that there's a relevant difference here between
flash-kernel and grub.

Grub: initrd not yet generated; grub postinst is called and adds kernel
as first entry in grub.cfg; power event happens before kernel postinst
is called; system fails to (noninteractively) boot.

flash-kernel: initrd not yet generated; flash-kernel postinst is called
and writes kernel (without initramfs) to the boot partition; power event
happens before kernel postinst is called; system fails to boot.

Both scenarios need to be guarded against, and we should use the same
model for both (and any other bootloaders on other archs).

*Unfortunately*, it turns out that while Andy and I whiteboarded this
about 5 years back, what we discussed never wound up being implemented
in the kernel packages.  I believe the plan at the time was to use a
dpkg-divert in the kernel preinst to divert /boot/vmlinuz-$ver to
/boot/vmlinuz-$ver.dpkg-something, and then to un-divert it in the
postinst only after the initramfs has been generated.  grub already has
code to ignore the pattern vmlinuz*.dpkg-* so no further changes would
be required for grub; and it would be easy to make flash-kernel match.

However, none of this matters so long as the kernel doesn't implement
such an interface.

In any case, I'm not happy with the proposed implementation in flash-
kernel.  I think rooting around in the dpkg database is bad form.
Ultimately, though, it's not my opinion on this that matters - we really
need input from the Kernel Team here wrt what interface we're going to
support between the packages.  I subscribed Andy to the bug, but he
hasn't replied yet; adding Dimitri as well.

-- 
You received this bug notification because you are a member of Ubuntu
Foundations Bugs, which is subscribed to flash-kernel in Ubuntu.
https://bugs.launchpad.net/bugs/2007827

Title:
  [SRU] flash-kernel failure when upgrading f-k and kernel in the same
  cycle

Status in flash-kernel package in Ubuntu:
  Fix Released
Status in flash-kernel source package in Focal:
  New
Status in flash-kernel source package in Jammy:
  New
Status in flash-kernel source package in Kinetic:
  Incomplete
Status in flash-kernel source package in Lunar:
  Fix Released

Bug description:
  [Impact]
  In version 3.104ubuntu15 of flash-kernel, when both f-k and the kernel are upgraded in the same cycle, depending on the ordering of dpkg trigger execution, f-k may find the content of /boot "inconsistent" causing it to fail and return error exit status 1.

  Erorr message:
  Processing triggers for man-db (2.10.2-1) ...
  Processing triggers for flash-kernel (3.104ubuntu15) ...
  flash-kernel: installing version 5.15.0-1018-xilinx-zynqmp
  Initrd required for FIT method
  dpkg: error processing package flash-kernel (--configure):
   installed flash-kernel package post-installation script subprocess returned error exit status 1
  Processing triggers for linux-image-5.15.0-1018-xilinx-zynqmp (5.15.0-1018.20) ...
  /etc/kernel/postinst.d/initramfs-tools:
  update-initramfs: Generating /boot/initrd.img-5.15.0-1018-xilinx-zynqmp

  flash-kernel gets the latest kernel version by "linux-version list".
  When flash-kernel was triggered to generate fitimage, the kernel version is "5.15.0-1018" and the initrd for it wasn't ready. So, flash-kernel failed to generate the fitimage.

  A subsequent run of "apt install -f" fixed things because, by that
  point, the kernel's own trigger had executed, ensuring that update-
  initramfs had been run. In the case that f-k is run "prematurely" and
  finds itself in this situation (/boot/kernel-$[ver} exists, but
  /boot/initrd-${ver}) doesn't), it should probably bail out silently
  under the assumption that whatever is responsible for it will rectify
  the situation and trigger f-k again (as happens in the kernel postinst
  hooks).

  [Test Case]
  1. Flash an old image (with an out of date kernel and flash-kernel)
  2. sudo apt-get update
  3. sudo apt install flash-kernel with the fix and linux packages
  4. Upgrade should proceed without issue

  [Regression Potential]
  As with the previous flash-kernel uploads, it is possible that a breakage in the changed code can lead to issues with upgrading kernels (due to f-k being executed via a trigger at the end) or with Xilinx devices in the field not upgrading correctly. I will test all the changes extensively though.

  Related issues:
  LP: #1861292 flash-kernel failure during kernel upgrade

To manage notifications about this bug go to:
https://bugs.launchpad.net/ubuntu/+source/flash-kernel/+bug/2007827/+subscriptions




More information about the foundations-bugs mailing list