Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 25 Feb 2009 17:45:45 +1100
From:      Lawrence Stewart <lstewart@freebsd.org>
To:        Luigi Rizzo <rizzo@iet.unipi.it>
Cc:        kib@freebsd.org, current@freebsd.org
Subject:   [SOLVED] Re: Recent versions of pxeboot hang/panic on AMD platform.
Message-ID:  <49A4E919.1070503@freebsd.org>
In-Reply-To: <49A35CB1.4050304@freebsd.org>
References:  <20081121231400.GA94863@onelab2.iet.unipi.it> <49A35CB1.4050304@freebsd.org>

next in thread | previous in thread | raw e-mail | index | archive | help
Lawrence Stewart wrote:
> Luigi Rizzo wrote:
>> [copying some people involved with recent related commits]
>>
>> As reported in  kern/118222 recent versions of pxeboot hang/panic
>> on AMD platform.
>>
>> Initial reports mentioned that the RELENG_6 versions worked well,
>> however i found out that even the recent RELENG_6 code is problematic.
>>
>> Specifically, the problem i see on two machines with AMD CPU (one
>> is an Asus M2N-VM) motherboard netbooting with PXEboot, is that the
>> loading of config files or binary modules (kernel, etc.) randomly
>> hangs with recent version of pxeboot (RELENG_6, RELENG_7 and HEAD
>> all give the same behaviour).
>>
>> The same system works fine with an old version of pxeboot from RELENG_6.
>>
>> Things seem to work fine on i386 (tried a Pentium4, N270 and on qemu) 
>> with all the versions below.
>>
>> To make some investigation i started with a reliable version
>> (RELENG_6, early 2008) and moved forward to figure out where the
>> problem was introduced. I found the following:
>>
>>         RELENG_6 as of 2008.03.01 (svn 176674)  works
>>         RELENG_6 as of 2008.03.15 (svn 177190)  works
>>                 (same as previous)
>>         RELENG_6 as of 2008.03.31 (svn 177768)  does NOT work
>>             changed files:
>>                 Index: RELENG_6/sys/boot/i386/boot2/boot2.c
>>                 Index: RELENG_6/sys/boot/i386/btx/btx/Makefile
>>                 Index: RELENG_6/sys/boot/i386/btx/btx/btx.S
>>                 Index: RELENG_6/sys/boot/i386/gptboot/gptboot.c
>>                 Index: RELENG_6/sys/boot/i386/libi386/biossmap.c
>>                 Index: RELENG_6/sys/boot/i386/libi386/biosmem.c
>>
>> There is a recent, related change (august 2008) which however
>> does not seem to fix the bug.
>>
>> (all the above is basically an MFC of something applied slightly 
>> earlier to
>> head and RELENG_7 . I have experienced the same exact bug with a fresh
>> head and RELENG_7, even though I have not found the exact point there
>> where the problem arised).
>>
>> The fact that the failure occurs at random times, even quite early 
>> (e.g. while reading the Forth config files) suggests that the problem
>> may be related to interrupts coming at the wrong time.
>> Unfortunately the changes to btx.S (which i believe may be related to
>> the problem, as the changes to the other files seem innocuous or 
>> unrelated)
>> are beyond my knowledge.
>> So, anyone has ideas on what could be happening here, and especially
>> how likely it is that we might see the same problem with a disk or 
>> usb-based
>> booting ?
> 
> Just adding a "me too" with pxeboot built from head r188509. Running 
> with pxeboot from AMD64 6.3-RELEASE as Luigi's research hinted seems to 
> resolve the issue for me also. I haven't tried pxeboot built from 
> r177768 yet though to see if it too fails.
> 
> To quickly touch on symptoms... I've never seen a panic. I experience 
> permanent hangs that occur maybe 50% (or possibly even more) of the time 
> when I reboot or cold start the machine. Only option is to reboot when 
> it hangs. Rebooting a few times will eventually allow the boot process 
> to finish and then once the kernel kicks off probing, all is good.
> 
> Hardware is an Intel 865GM chipset based Gigabyte mainboard with a 3GHz 
> HTT P4 CPU (HTT enabled).
> 
> Happy to help debug further if anyone has ideas to try.
> 

On a whim I decided to try a PCI Intel GigE NIC I had lying around... 
low and behold I can't make the machine hang during boot any more with 
pxeboot built from head r188509.

To be a bit more specific about the hardware involved, the motherboard 
is a Gigabyte GA-8I865GM-775 with BIOS version F5 and the onboard NIC 
shows up as follows:

Marvell Yukon pxe rom version (reported during boot): 1.11

pciconf -lv:

skc0@pci0:1:9:0:        class=0x020000 card=0xe0001458 chip=0x432011ab 
rev=0x13 hdr=0x00
     vendor     = 'Marvell Semiconductor (Was: Galileo Technology Ltd)' 

     device     = 'Yukon 88E8001/8003/8010 PCI Gigabit Ethernet 
Controller (Copper)'
     class      = network 

     subclass   = ethernet


Onboard NIC related verbose dmesg output:

skc0: <Marvell Gigabit Ethernet> port 0xa400-0xa4ff mem 
0xf9040000-0xf9043fff irq 20 at device 9.0 on pci1
skc0: Reserved 0x4000 bytes for rid 0x10 type 3 at 0xf9040000 

skc0: interrupt moderation is 100 us 

skc0: Marvell Yukon Lite Gigabit Ethernet rev. (0x9) 

skc0: chip ver  = 0xb1 

skc0: chip rev  = 0x09 

skc0: SK_EPROM0 = 0x10 

skc0: SRAM size = 0x010000 

sk0: <Marvell Semiconductor, Inc. Yukon> on skc0 

sk0: bpf attached 

sk0: Ethernet address: <mac> 

miibus0: <MII bus> on sk0 

e1000phy0: <Marvell 88E1011 Gigabit PHY> PHY 0 on miibus0 

e1000phy0:  10baseT, 10baseT-FDX, 100baseTX, 100baseTX-FDX, 
1000baseTX-FDX, auto
ioapic0: routing intpin 20 (PCI IRQ 20) to lapic 0 vector 54 

skc0: [MPSAFE] 

skc0: [ITHREAD]


As a follow on from the Intel NIC discovery, I also noticed John's 
commit from yesterday (r189017) which looked promising and took it for a 
spin. I'm happy to report that it appears to resolve the hang with the 
Marvell card's pxe rom. After at least a dozen reboot/cold start 
attempts it hasn't hung once, whereas pxeboot build from r189016 hangs 
most of the time. The addon Intel NIC is still unphased by either 
pxeboot version and boots just fine regardless.

So for me at least, looks like the case is closed. Thanks go to Tor, 
John and Bjoern for their work on r189017.

Cheers,
Lawrence



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?49A4E919.1070503>