Date: Fri, 05 Aug 2011 16:08:27 +0200 From: Christoph Hoffmann <christoph_hoffmann@me.com> To: Christoph Hoffmann <christoph_hoffmann@me.com> Cc: freebsd-current@freebsd.org Subject: Re: gptzfsboot error using HP Smart Array P410i Controller Message-ID: <3D9B1E72-385F-493A-A6B3-4684A2DB50E4@me.com> In-Reply-To: <9B42BCDF-43E3-4517-9972-47A8B539880F@me.com> References: <E040B3A9-9B62-4545-ADC9-5CE3A9217024@me.com> <491F5434-3EF2-40AF-B962-892046DB1D54@me.com> <201108050737.45418.jhb@freebsd.org> <9B42BCDF-43E3-4517-9972-47A8B539880F@me.com>
index | next in thread | previous in thread | raw e-mail
Hello Everyone,
Despite the BIOS information about the nonexistent floppy, the zfsboot.c code
will prevent to boot from the first HDD if a floppy is given as a first available device.
The drive 0x0 (floppy) will be probed before the code below and an error occurs:
[…]
gptzfsboot: error 1 lba 32
gptzfsboot: error 1 lba 1
[…]
The continue statement will skip the rest of the iteration because
if ((i | DRV_HARD) == *(uint8_t *)PTOV(ARGS))
is true if the drive equals 0x80. As a result we do not call probe_drive()
for this drive.
Eliminating
if ((i | DRV_HARD) == *(uint8_t *)PTOV(ARGS))
continue;
would help.
Any comments will be appreciated.
Best Regards,
Christoph
i386/zfsboot/zfsboot.c
int
main(void)
{
[…]
/*
* Probe the rest of the drives that the bios knows about. This
* will find any other available pools and it may fill in missing
* vdevs for the boot pool.
*/
for (i = 0; i < *(unsigned char *)PTOV(BIOS_NUMDRIVES); i++) {
if ((i | DRV_HARD) == *(uint8_t *)PTOV(ARGS))
continue;
if (!int13probe(i | DRV_HARD))
break;
[…]
probe_drive(dsk, NULL);
}
[…]
On Aug 5, 2011, at 1:47 PM, Christoph Hoffmann wrote:
> Hello John,
>
> No, I and not using clang.
>
> My problem persists even I apply the patch.
>
> As a workaround I have to put OS on second LUN presented by the
> P410i Controller.
>
> Regards,
>
> Christoph
>
> --
> Christoph Hoffmann
>
>
> On Aug 5, 2011, at 1:37 PM, John Baldwin wrote:
>
>> On Thursday, August 04, 2011 3:26:49 pm Christoph Hoffmann wrote:
>>> Hello Everyone,
>>>
>>> The system will successfully boot only if the OS installation is laying on
>>> the second drive or higher (0x81 and more).
>>
>> Are you using clang? If so, you should try either using GCC or using this
>> patch with clang as a workaround from the previous thread on zfsboot issues:
>>
>> Index: sys/boot/i386/zfsboot/Makefile
>> ===================================================================
>> --- sys/boot/i386/zfsboot/Makefile (revision 224653)
>> +++ sys/boot/i386/zfsboot/Makefile (working copy)
>> @@ -20,7 +20,6 @@
>> -fomit-frame-pointer \
>> -fno-unit-at-a-time \
>> -mno-align-long-strings \
>> - -mrtd \
>> -DBOOT2 \
>> -DSIOPRT=${BOOT_COMCONSOLE_PORT} \
>> -DSIOFMT=${B2SIOFMT} \
>> Index: sys/boot/i386/gptzfsboot/Makefile
>> ===================================================================
>> --- sys/boot/i386/gptzfsboot/Makefile (revision 224653)
>> +++ sys/boot/i386/gptzfsboot/Makefile (working copy)
>> @@ -22,7 +22,6 @@
>> -fomit-frame-pointer \
>> -fno-unit-at-a-time \
>> -mno-align-long-strings \
>> - -mrtd \
>> -DGPT -DBOOT2 \
>> -DSIOPRT=${BOOT_COMCONSOLE_PORT} \
>> -DSIOFMT=${B2SIOFMT} \
>>
>> --
>> John Baldwin
>> _______________________________________________
>> freebsd-current@freebsd.org mailing list
>> http://lists.freebsd.org/mailman/listinfo/freebsd-current
>> To unsubscribe, send any mail to "freebsd-current-unsubscribe@freebsd.org"
>
> _______________________________________________
> freebsd-current@freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/freebsd-current
> To unsubscribe, send any mail to "freebsd-current-unsubscribe@freebsd.org"
help
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?3D9B1E72-385F-493A-A6B3-4684A2DB50E4>
