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>
next in thread | previous in thread | raw e-mail | index | archive | help
Hello Everyone, Despite the BIOS information about the nonexistent floppy, the zfsboot.c = code=20 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: [=85] gptzfsboot: error 1 lba 32 = =20 gptzfsboot: error 1 lba 1 = =20 [=85] The continue statement will skip the rest of the iteration because =20 if ((i | DRV_HARD) =3D=3D *(uint8_t *)PTOV(ARGS))=20 is true if the drive equals 0x80. As a result we do not call = probe_drive() for this drive. Eliminating if ((i | DRV_HARD) =3D=3D *(uint8_t *)PTOV(ARGS)) =20 continue; would help. Any comments will be appreciated. Best Regards, Christoph i386/zfsboot/zfsboot.c int main(void) { =20 [=85] /* * 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 =3D 0; i < *(unsigned char *)PTOV(BIOS_NUMDRIVES); i++) { if ((i | DRV_HARD) =3D=3D *(uint8_t *)PTOV(ARGS)) =20 continue; if (!int13probe(i | DRV_HARD)) break; [=85] probe_drive(dsk, NULL); } [=85] On Aug 5, 2011, at 1:47 PM, Christoph Hoffmann wrote: > Hello John, >=20 > No, I and not using clang. >=20 > My problem persists even I apply the patch.=20 >=20 > As a workaround I have to put OS on second LUN presented by the=20 > P410i Controller. >=20 > Regards, >=20 > Christoph >=20 > -- > Christoph Hoffmann >=20 >=20 > On Aug 5, 2011, at 1:37 PM, John Baldwin wrote: >=20 >> On Thursday, August 04, 2011 3:26:49 pm Christoph Hoffmann wrote: >>> Hello Everyone, >>>=20 >>> The system will successfully boot only if the OS installation is = laying on >>> the second drive or higher (0x81 and more). >>=20 >> Are you using clang? If so, you should try either using GCC or using = this=20 >> patch with clang as a workaround from the previous thread on zfsboot = issues: >>=20 >> Index: sys/boot/i386/zfsboot/Makefile >> =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D= =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D= =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D >> --- 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=3D${BOOT_COMCONSOLE_PORT} \ >> -DSIOFMT=3D${B2SIOFMT} \ >> Index: sys/boot/i386/gptzfsboot/Makefile >> =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D= =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D= =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D >> --- 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=3D${BOOT_COMCONSOLE_PORT} \ >> -DSIOFMT=3D${B2SIOFMT} \ >>=20 >> --=20 >> 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" >=20 > _______________________________________________ > 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"
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?3D9B1E72-385F-493A-A6B3-4684A2DB50E4>