Date: Mon, 15 Aug 2011 12:12:07 -0400 From: John Baldwin <jhb@freebsd.org> To: freebsd-current@freebsd.org Cc: Christoph Hoffmann <christoph_hoffmann@me.com> Subject: Re: gptzfsboot error using HP Smart Array P410i Controller Message-ID: <201108151212.07874.jhb@freebsd.org> In-Reply-To: <3D9B1E72-385F-493A-A6B3-4684A2DB50E4@me.com> References: <E040B3A9-9B62-4545-ADC9-5CE3A9217024@me.com> <9B42BCDF-43E3-4517-9972-47A8B539880F@me.com> <3D9B1E72-385F-493A-A6B3-4684A2DB50E4@me.com>
next in thread | previous in thread | raw e-mail | index | archive | help
On Friday, August 05, 2011 10:08:27 am Christoph Hoffmann wrote:
> Hello Everyone,
>=20
> Despite the BIOS information about the nonexistent floppy, the zfsboot.c=
=20
code=20
> will prevent to boot from the first HDD if a floppy is given as a first=20
available device.
>=20
> The drive 0x0 (floppy) will be probed before the code below and an error=
=20
occurs:
> [=85]
> gptzfsboot: error 1 lba 32 =
=20
> gptzfsboot: error 1 lba 1 =
=20
> [=85]
>=20
> 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.
But that shouldn't happen if ARGS has a drive number of 0. (In that case 0=
x80=20
!=3D 0x0, so it shouldn't match.)
This shows that PTOV(ARGS) actually has a %dl value of 0x80 which is correc=
t. =20
The question is how your initial 'dsk' ended up using 0x0 instead of 0x80.
Note that your 'type' is 0, so that means that it was ok initially (TYPE_AD=
is=20
0):
dsk->drive =3D *(uint8_t *)PTOV(ARGS);
dsk->type =3D dsk->drive & DRV_HARD ? TYPE_AD : TYPE_FD;
Somewhere between where 'dsk' is initalized in main() and before probe_driv=
e()=20
is called in main() for 'dsk', 'dsk->drive' is getting clobbered. Can you =
add=20
some additional printfs to nail down where that is happening?
=2D-=20
John Baldwin
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201108151212.07874.jhb>
