summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorJason Downs <downsj@cvs.openbsd.org>1996-08-07 05:40:48 +0000
committerJason Downs <downsj@cvs.openbsd.org>1996-08-07 05:40:48 +0000
commitc1bc94a9a76239adb68b4e337ebdd3c13995a6a4 (patch)
treef527ed694ef1f458c61fd800795a0dac8188601f /sys
parent49ac8a332f4d8a7701ebc899f103d5b92320e90f (diff)
It's silly to try and do the quirks table ala SCSI at this point; do it
my way, instead.
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/atapi/atapiconf.c42
1 files changed, 21 insertions, 21 deletions
diff --git a/sys/dev/atapi/atapiconf.c b/sys/dev/atapi/atapiconf.c
index 334bd34a6d5..2df3ed490e5 100644
--- a/sys/dev/atapi/atapiconf.c
+++ b/sys/dev/atapi/atapiconf.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: atapiconf.c,v 1.5 1996/08/07 01:56:28 downsj Exp $ */
+/* $OpenBSD: atapiconf.c,v 1.6 1996/08/07 05:40:47 downsj Exp $ */
/*
* Copyright (c) 1996 Manuel Bouyer. All rights reserved.
@@ -87,18 +87,19 @@ struct cfdriver atapibus_cd = {
*/
struct atapi_quirk_inquiry_pattern {
- struct {
- u_int8_t type;
- u_int8_t rem;
- char *product;
- char *revision;
- } pattern;
+ u_int8_t type;
+ u_int8_t rem;
+ char *product;
+ char *revision;
+
u_int8_t quirks;
};
struct atapi_quirk_inquiry_pattern atapi_quirk_inquiry_patterns[] = {
- {{ATAPI_DEVICE_TYPE_CD, ATAPI_REMOVABLE,
- "GCD-R580B", "1.00"}, ADEV_LITTLETOC},
+ {ATAPI_DEVICE_TYPE_CD, ATAPI_REMOVABLE,
+ "GCD-R580B", "1.00", ADEV_LITTLETOC}, /* GoldStar 8X */
+
+ {0, 0, NULL, NULL, 0} /* The End */
};
int
@@ -120,8 +121,7 @@ atapi_fixquirk(ad_link)
struct at_dev_link *ad_link;
{
struct atapi_identify *id = &ad_link->id;
- struct atapi_quirk_inquiry_pattern *finger;
- int quirk, nquirks;
+ struct atapi_quirk_inquiry_pattern *quirk;
/*
* Shuffle string byte order.
@@ -141,27 +141,27 @@ atapi_fixquirk(ad_link)
btrim(id->serial_number, sizeof(id->serial_number));
btrim(id->firmware_revision, sizeof(id->firmware_revision));
- nquirks = sizeof(atapi_quirk_inquiry_patterns) /
- sizeof(struct atapi_quirk_inquiry_pattern);
- for (quirk = 0; quirk < nquirks; quirk++) {
- finger = &atapi_quirk_inquiry_patterns[quirk];
+#define quirk_null(_q) ((_q->type == 0) && (_q->rem == 0) && \
+ (_q->product == NULL) && (_q->revision == NULL))
+ for (quirk = atapi_quirk_inquiry_patterns;
+ !quirk_null(quirk); quirk++) {
if ((id->config.device_type
- & ATAPI_DEVICE_TYPE_MASK) != finger->pattern.type)
+ & ATAPI_DEVICE_TYPE_MASK) != quirk->type)
continue;
- if ((id->config.cmd_drq_rem & finger->pattern.rem) == 0)
+ if ((id->config.cmd_drq_rem & quirk->rem) == 0)
continue;
- if (strcmp(id->model, finger->pattern.product))
+ if (strcmp(id->model, quirk->product))
continue;
- if (strcmp(id->firmware_revision, finger->pattern.revision))
+ if (strcmp(id->firmware_revision, quirk->revision))
continue;
break;
}
- if (quirk < nquirks) {
+ if (!quirk_null(quirk)) {
/* Found a quirk entry for this drive. */
- ad_link->quirks = finger->quirks;
+ ad_link->quirks = quirk->quirks;
}
}