From owner-freebsd-current@freebsd.org Mon Dec 12 17:43:15 2016 Return-Path: Delivered-To: freebsd-current@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id 17FCEC73C34 for ; Mon, 12 Dec 2016 17:43:15 +0000 (UTC) (envelope-from slw@zxy.spb.ru) Received: from mailman.ysv.freebsd.org (mailman.ysv.freebsd.org [IPv6:2001:1900:2254:206a::50:5]) by mx1.freebsd.org (Postfix) with ESMTP id 032FD1F7F for ; Mon, 12 Dec 2016 17:43:15 +0000 (UTC) (envelope-from slw@zxy.spb.ru) Received: by mailman.ysv.freebsd.org (Postfix) id 027BEC73C33; Mon, 12 Dec 2016 17:43:15 +0000 (UTC) Delivered-To: current@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id 02216C73C32 for ; Mon, 12 Dec 2016 17:43:15 +0000 (UTC) (envelope-from slw@zxy.spb.ru) Received: from zxy.spb.ru (zxy.spb.ru [195.70.199.98]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id B7E901F7D for ; Mon, 12 Dec 2016 17:43:14 +0000 (UTC) (envelope-from slw@zxy.spb.ru) Received: from slw by zxy.spb.ru with local (Exim 4.86 (FreeBSD)) (envelope-from ) id 1cGUd5-0009dm-JB; Mon, 12 Dec 2016 20:43:11 +0300 Date: Mon, 12 Dec 2016 20:43:11 +0300 From: Slawa Olhovchenkov To: Konstantin Belousov Cc: current@freebsd.org Subject: Re: Enabling NUMA in BIOS stop booting FreeBSD Message-ID: <20161212174311.GE90287@zxy.spb.ru> References: <20161211191626.GI31311@zxy.spb.ru> <20161211192656.GZ54029@kib.kiev.ua> <20161211194559.GJ31311@zxy.spb.ru> <20161211200654.GA54029@kib.kiev.ua> <20161211204709.GK31311@zxy.spb.ru> <20161212145418.GF54029@kib.kiev.ua> <20161212162152.GC90287@zxy.spb.ru> <20161212165457.GI54029@kib.kiev.ua> <20161212171634.GD90287@zxy.spb.ru> <20161212172418.GK54029@kib.kiev.ua> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20161212172418.GK54029@kib.kiev.ua> User-Agent: Mutt/1.5.24 (2015-08-30) X-SA-Exim-Connect-IP: X-SA-Exim-Mail-From: slw@zxy.spb.ru X-SA-Exim-Scanned: No (on zxy.spb.ru); SAEximRunCond expanded to false X-BeenThere: freebsd-current@freebsd.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: Discussions about the use of FreeBSD-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 12 Dec 2016 17:43:15 -0000 On Mon, Dec 12, 2016 at 07:24:18PM +0200, Konstantin Belousov wrote: > On Mon, Dec 12, 2016 at 08:16:34PM +0300, Slawa Olhovchenkov wrote: > > On Mon, Dec 12, 2016 at 06:54:57PM +0200, Konstantin Belousov wrote: > > > > > On Mon, Dec 12, 2016 at 07:21:53PM +0300, Slawa Olhovchenkov wrote: > > > > On Mon, Dec 12, 2016 at 04:54:18PM +0200, Konstantin Belousov wrote: > > > > > > > > > On Sun, Dec 11, 2016 at 11:47:09PM +0300, Slawa Olhovchenkov wrote: > > > > > > Booting... > > > > > > ESC[01;00H8+0x8+0xe9bdc] KDB: debugger backends: ddb > > > > > > KDB: current backend: ddb > > > > > > exit from kdb_init > > > > > > KDB: enter: Boot flags requested debugger > > > > > > [ thread pid 0 tid 0 ] > > > > > - remove any video consoles from the HEAD kernel config, i.e. sc/vt and > > > > > vga/efi, > > > > > - do not use boot -d, > > > > > - use serial console (IPMI SOL qualifies), > > > > > - set late console to 0, > > > > > and show me the verbose dmesg of such boot with the BIOS options > > > > > which cause troubles. > > > > > > > > Booting... > > > > KDB: debugger backends: ddb > > > > KDB: current backend: ddb > > > > SMAP type=01 base=0000000000000000 len=0000000000099c00 > > > > SMAP type=02 base=0000000000099c00 len=0000000000006400 > > > > SMAP type=02 base=00000000000e0000 len=0000000000020000 > > > > SMAP type=01 base=0000000000100000 len=000000007906b000 > > > > SMAP type=02 base=000000007916b000 len=0000000000936000 > > > > SMAP type=04 base=0000000079aa1000 len=0000000000509000 > > > > SMAP type=02 base=0000000079faa000 len=0000000002056000 > > > > SMAP type=01 base=0000000100000000 len=0000001f80000000 > > > > SMAP type=02 base=000000007c000000 len=0000000014000000 > > > > SMAP type=02 base=00000000fed1c000 len=0000000000029000 > > > > SMAP type=02 base=00000000ff000000 len=0000000001000000 > > > > > > > > This is all. No more. > > > When you switch between variations of the NUMA enablement options, do > > > you just reboot the machine or do you sometimes physically turn it off ? > > > > just reboot an 'power reset' via kvm client (memory preserved, i mean) > > > > > Try to enable memtest, with the hw.memtest.tests=1 loader variable. > > > Does it change things ? > > > > System booted, dmesg is http://zxy.spb.ru/dmesg.numa > I suspect now the reversed situation could take place, the non-interleaved > option would cause hang. No, also booted, dmesg http://zxy.spb.ru/dmesg.numa-ninter > My current guess is that memory content is preserved but swizzled by > the cache line sized chunks. So that the msgbuf header, left after the > previous boot, looks correct while the real buffer content is shuffled. > > Try the debugging patch below, which unconditionally disables import of > previous buffer. To test, you would need to boot, then frob options in > BIOS, reboot, again frob etc. still need test patch? if yes, with BIOS options? > diff --git a/sys/kern/subr_msgbuf.c b/sys/kern/subr_msgbuf.c > index f275aef3b4f..d45ef502204 100644 > --- a/sys/kern/subr_msgbuf.c > +++ b/sys/kern/subr_msgbuf.c > @@ -85,7 +85,7 @@ msgbuf_reinit(struct msgbuf *mbp, void *ptr, int size) > { > u_int cksum; > > - if (mbp->msg_magic != MSG_MAGIC || mbp->msg_size != size) { > + if (1 || mbp->msg_magic != MSG_MAGIC || mbp->msg_size != size) { > msgbuf_init(mbp, ptr, size); > return; > }