summaryrefslogtreecommitdiff
path: root/sys/dev/ata/wd.c
diff options
context:
space:
mode:
authorUwe Stuehler <uwe@cvs.openbsd.org>2005-11-09 19:05:49 +0000
committerUwe Stuehler <uwe@cvs.openbsd.org>2005-11-09 19:05:49 +0000
commit18629dc9ff26c2c75bd348b0d34681ce8a203388 (patch)
tree110678ac13d10471f1217b4ed4234cf0835e7517 /sys/dev/ata/wd.c
parentdd911d3a6513d0234c5faa7fe84a1c8e4caafbda (diff)
Don't fall back to fake geometry if ata_get_params() fails.
"looks sane" grange@; tested by niall@ krw@ jmc@ jolan@
Diffstat (limited to 'sys/dev/ata/wd.c')
-rw-r--r--sys/dev/ata/wd.c18
1 files changed, 6 insertions, 12 deletions
diff --git a/sys/dev/ata/wd.c b/sys/dev/ata/wd.c
index 41e2a51068a..89fb2089b52 100644
--- a/sys/dev/ata/wd.c
+++ b/sys/dev/ata/wd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: wd.c,v 1.44 2005/09/01 02:16:56 uwe Exp $ */
+/* $OpenBSD: wd.c,v 1.45 2005/11/09 19:05:48 uwe Exp $ */
/* $NetBSD: wd.c,v 1.193 1999/02/28 17:15:27 explorer Exp $ */
/*
@@ -1258,29 +1258,23 @@ bad144intern(struct wd_softc *wd)
int
wd_get_params(struct wd_softc *wd, u_int8_t flags, struct ataparams *params)
{
-#ifdef __zaurus__
- /* XXX fix after 3.8 release */
- /* We already have the drive parameters; just return them. */
- if (params == &wd->sc_params && wd->sc_params.atap_cylinders != 0)
- return 0;
-#endif /* __zaurus__ */
switch (ata_get_params(wd->drvp, flags, params)) {
case CMD_AGAIN:
return 1;
case CMD_ERR:
-#ifdef __zaurus__
- /* XXX fix after 3.8 release */
- /* We already have the drive parameters; reuse them. */
+ /* If we already have drive parameters, reuse them. */
if (wd->sc_params.atap_cylinders != 0) {
- *params = wd->sc_params;
+ if (params != &wd->sc_params)
+ bcopy(&wd->sc_params, params,
+ sizeof(struct ataparams));
return 0;
}
-#endif /* __zaurus__ */
/*
* We `know' there's a drive here; just assume it's old.
* This geometry is only used to read the MBR and print a
* (false) attach message.
*/
+ bzero(params, sizeof(struct ataparams));
strncpy(params->atap_model, "ST506",
sizeof params->atap_model);
params->atap_config = ATA_CFG_FIXED;