From owner-freebsd-current@freebsd.org Mon Dec 12 19:26:22 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 7CAB5C73DB4 for ; Mon, 12 Dec 2016 19:26:22 +0000 (UTC) (envelope-from slw@zxy.spb.ru) Received: from mailman.ysv.freebsd.org (unknown [127.0.1.3]) by mx1.freebsd.org (Postfix) with ESMTP id 67FA81823 for ; Mon, 12 Dec 2016 19:26:22 +0000 (UTC) (envelope-from slw@zxy.spb.ru) Received: by mailman.ysv.freebsd.org (Postfix) id 6450AC73DB3; Mon, 12 Dec 2016 19:26:22 +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 63F1BC73DB2 for ; Mon, 12 Dec 2016 19:26:22 +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 24CCE1822 for ; Mon, 12 Dec 2016 19:26:22 +0000 (UTC) (envelope-from slw@zxy.spb.ru) Received: from slw by zxy.spb.ru with local (Exim 4.86 (FreeBSD)) (envelope-from ) id 1cGWEt-000CmX-6U; Mon, 12 Dec 2016 22:26:19 +0300 Date: Mon, 12 Dec 2016 22:26:19 +0300 From: Slawa Olhovchenkov To: Konstantin Belousov Cc: current@freebsd.org Subject: Re: Enabling NUMA in BIOS stop booting FreeBSD Message-ID: <20161212192619.GF90287@zxy.spb.ru> References: <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> <20161212174311.GE90287@zxy.spb.ru> <20161212183647.GL54029@kib.kiev.ua> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20161212183647.GL54029@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 19:26:22 -0000 On Mon, Dec 12, 2016 at 08:36:47PM +0200, Konstantin Belousov wrote: > On Mon, Dec 12, 2016 at 08:43:11PM +0300, Slawa Olhovchenkov wrote: > > 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 > I mean, it could hang if memory testing is not enabled. realy? system boot w/o memory testing when NUMA ON and interleave OFF: I am already report about boot after off interleave. > > > > > 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? > Yes, please test the patch. I explained the procedure above. sorry, i don't know 'frob'. what exactly options combination I need test and what about memory test? > > > > > 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; > > > }