From owner-freebsd-stable@FreeBSD.ORG Tue Jun 1 09:45:09 2010 Return-Path: Delivered-To: freebsd-stable@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 6BAAD1065674 for ; Tue, 1 Jun 2010 09:45:09 +0000 (UTC) (envelope-from O.Seibert@cs.ru.nl) Received: from kookpunt.science.ru.nl (kookpunt.science.ru.nl [131.174.30.61]) by mx1.freebsd.org (Postfix) with ESMTP id E580B8FC1E for ; Tue, 1 Jun 2010 09:45:08 +0000 (UTC) Received: from twoquid.cs.ru.nl (twoquid.cs.ru.nl [131.174.142.38]) by kookpunt.science.ru.nl (8.13.7/5.31) with ESMTP id o519j6Jx011006; Tue, 1 Jun 2010 11:45:06 +0200 (MEST) Received: by twoquid.cs.ru.nl (Postfix, from userid 4100) id 492802E063; Tue, 1 Jun 2010 11:45:06 +0200 (CEST) Date: Tue, 1 Jun 2010 11:45:06 +0200 From: Olaf Seibert To: freebsd-stable@freebsd.org Message-ID: <20100601094506.GA25207@twoquid.cs.ru.nl> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline User-Agent: Mutt/1.5.19 (2009-01-05) X-Spam-Score: -0.669 () ALL_TRUSTED,BAYES_50,DNS_FROM_OPENWHOIS X-Scanned-By: MIMEDefang 2.63 on 131.174.30.61 Subject: freebsd-update with non-GENERIC kerrnel X-BeenThere: freebsd-stable@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Production branch of FreeBSD source code List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 01 Jun 2010 09:45:09 -0000 I find the way freebsd-update handles a system that runs a non-GENERIC kernel less than helpful. It is doing this: | fourquid.3:~$ sudo freebsd-update upgrade -r 8.1-BETA1 | Password: | Looking up update.FreeBSD.org mirrors... 3 mirrors found. | Fetching metadata signature for 8.0-RELEASE from update5.FreeBSD.org... done. | Fetching metadata index... done. | Fetching 2 metadata patches.. done. | Applying metadata patches... done. | Inspecting system... done. | | WARNING: This system is running a "fourquid" kernel, which is not a | kernel configuration distributed as part of FreeBSD 8.0-RELEASE. | This kernel will not be updated: you MUST update the kernel manually | before running "/usr/sbin/freebsd-update install". | | The following components of FreeBSD seem to be installed: | src/base src/bin src/cddl src/contrib src/crypto src/etc src/games | src/gnu src/include src/krb5 src/lib src/libexec src/release src/rescue | src/sbin src/secure src/share src/sys src/tools src/ubin src/usbin | world/base world/catpages world/dict world/doc world/games world/info | world/lib32 world/manpages world/proflibs | | The following components of FreeBSD do not seem to be installed: | kernel/generic | | Does this look reasonable (y/n)? n I do have the kernel sources installed, so I would like to have them updated. I don't even mind to have a GENERIC kernel temporarily installed, until I compile my own (fortunately, they are not that different). It is nice that it tells me that I "MUST update the kernel manually", but it gives me no help in getting the sources and doing that. (Can the new kernel even be built in all cases with old tools? NetBSD offers a nice cross-building system for that.) For my previous update to 8.0-RELEASE-p2 I patched freebsd-update simply to think that my kernel *is* GENERIC, --- /usr/sbin/freebsd-update 2009-12-22 17:16:01.000000000 +0100 +++ /tmp/freebsd-update 2010-05-11 10:35:05.000000000 +0200 @@ -631,6 +631,7 @@ # we're running an SMP kernel. This mis-identification is a bug # which was fixed in 6.2-STABLE. KERNCONF=`uname -i` + KERNCONF=GENERIC if [ ${KERNCONF} = "SMP-GENERIC" ]; then KERNCONF=SMP fi but that seems riskier as updates get a bit bigger. The official way seems to be to reboot using GENERIC, upgrade (with a reboot with new GENERIC), rebuild new CUSTOM kernel, reboot again. At least the first reboot ought to be avoided... -Olaf. --