Date: Sun, 14 Aug 2011 22:51:11 +0400 From: Test Rat <ttsestt@gmail.com> To: Freddie Cash <fjwcash@gmail.com> Cc: Alexander Best <arundel@freebsd.org>, freebsd-current@freebsd.org Subject: Re: [rfc] replacing /boot/kernel.old with a unique directory name Message-ID: <86mxfbn7xc.fsf@gmail.com> In-Reply-To: <CAOjFWZ5uQ72D9H5SQnuS0uL3eszkZuGa0jHieo7WDaEOSFnAgQ@mail.gmail.com> (Freddie Cash's message of "Sun, 14 Aug 2011 10:56:57 -0700") References: <20110813195127.GA34295@freebsd.org> <CAOjFWZ5uQ72D9H5SQnuS0uL3eszkZuGa0jHieo7WDaEOSFnAgQ@mail.gmail.com>
next in thread | previous in thread | raw e-mail | index | archive | help
Freddie Cash <fjwcash@gmail.com> writes:
> On Sat, Aug 13, 2011 at 12:51 PM, Alexander Best <arundel@freebsd.org>wrote:
>
>> hi there,
>>
>> i just had the following idea: how about instead of copying the current
>> kernel
>> to /boot/kernel.old and then installing the new one under /boot/kernel as
>> the
>> results of target installkernel, we create a unique directory name for the
>> old
>> kernel?
>>
>> something like /boot/kernel-r${revision}-${/dev/random}?
>>
>> that would let people not only boot the previous kernel, but all kernels
>> that
>> have been replaced by target installkernel. this would make tracking
>> issues,
>> which have been introduced by a certain commit much easier, imho.
>>
>> i don't think implementing this logic would be that difficult. the only
>> problem
>> i see is with ${/dev/random} in the case where people are running a kernel
>> without /dev/{u}random support.
>>
>
> A better method may be to use KODIR to install the *new* kernel to a unique
> directory via installkernel (make KERNCONF=SOMEKERNEL
> KODIR=/boot/SOMEKERNEL-rev-whatever installkernel) and then using "nextboot
> -k SOMEKERNEL-rev-whatever" to set that kernel as bootable on the next boot.
>
> You reboot, make sure everything works with SOMEKERNEL-rev-whatever, and
> then make that the default kernel (rm -rf /boot/kernel; cp -Rvp
> /boot/SOMEKERNEL-rev-whatever /boot/kernel; shutdown -r now).
[...]
nextboot needs write access in loader to reset kernel, which is only
available for ufs. So, forget about zfs and every other fs from
libstand(3), e.g. ext2fs, msdosfs, nfs.
bootonce is also only supported in gptboot (ufs), not gptzfsboot.
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?86mxfbn7xc.fsf>
