summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
authorJason Wright <jason@cvs.openbsd.org>2002-11-19 18:40:18 +0000
committerJason Wright <jason@cvs.openbsd.org>2002-11-19 18:40:18 +0000
commit6de774d6cba7e3cd5ab65ca8bd33d4e854d185ac (patch)
treee947e412c38cb1b45d34a5c858acb00564f371df /sys/dev
parentf8eb256c65fe796edfbbb90ae32c5502ca585795 (diff)
Add a simplistic table driven lookup routine and use it where appropriate.
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/pci/adv_pci.c21
-rw-r--r--sys/dev/pci/adw_pci.c21
-rw-r--r--sys/dev/pci/ahc_pci.c90
-rw-r--r--sys/dev/pci/autri.c35
-rw-r--r--sys/dev/pci/auvia.c21
-rw-r--r--sys/dev/pci/bha_pci.c14
-rw-r--r--sys/dev/pci/cmpci.c18
-rw-r--r--sys/dev/pci/cs4280.c21
-rw-r--r--sys/dev/pci/cy_pci.c35
-rw-r--r--sys/dev/pci/cz.c12
-rw-r--r--sys/dev/pci/eap.c31
-rw-r--r--sys/dev/pci/esa.c22
-rw-r--r--sys/dev/pci/fms.c12
-rw-r--r--sys/dev/pci/hifn7751.c26
-rw-r--r--sys/dev/pci/i82365_pci.c19
-rw-r--r--sys/dev/pci/if_an_pci.c21
-rw-r--r--sys/dev/pci/if_ep_pci.c27
-rw-r--r--sys/dev/pci/if_fpa.c11
-rw-r--r--sys/dev/pci/if_fxp_pci.c39
-rw-r--r--sys/dev/pci/if_gem_pci.c25
-rw-r--r--sys/dev/pci/if_rl_pci.c30
-rw-r--r--sys/dev/pci/if_sf.c10
-rw-r--r--sys/dev/pci/if_sis.c25
-rw-r--r--sys/dev/pci/if_ste.c19
-rw-r--r--sys/dev/pci/if_ti.c40
-rw-r--r--sys/dev/pci/if_tx.c12
-rw-r--r--sys/dev/pci/if_txp.c29
-rw-r--r--sys/dev/pci/if_vr.c32
-rw-r--r--sys/dev/pci/if_wb.c26
-rw-r--r--sys/dev/pci/if_xl_pci.c57
-rw-r--r--sys/dev/pci/pci.c16
-rw-r--r--sys/dev/pci/pcivar.h9
-rw-r--r--sys/dev/pci/ubsec.c34
33 files changed, 349 insertions, 511 deletions
diff --git a/sys/dev/pci/adv_pci.c b/sys/dev/pci/adv_pci.c
index 4530e53dc04..e0ed9578d29 100644
--- a/sys/dev/pci/adv_pci.c
+++ b/sys/dev/pci/adv_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: adv_pci.c,v 1.6 2002/03/14 01:26:58 millert Exp $ */
+/* $OpenBSD: adv_pci.c,v 1.7 2002/11/19 18:40:16 jason Exp $ */
/* $NetBSD: adv_pci.c,v 1.5 1998/09/26 15:52:55 dante Exp $ */
/*
@@ -97,6 +97,12 @@ struct cfattach adv_pci_ca =
sizeof(ASC_SOFTC), adv_pci_match, adv_pci_attach
};
+const struct pci_matchid adv_pci_devices[] = {
+ { PCI_VENDOR_ADVSYS, PCI_PRODUCT_ADVSYS_1200A },
+ { PCI_VENDOR_ADVSYS, PCI_PRODUCT_ADVSYS_1200B },
+ { PCI_VENDOR_ADVSYS, PCI_PRODUCT_ADVSYS_ULTRA },
+};
+
/******************************************************************************/
/*
* Check the slots looking for a board we recognise
@@ -108,17 +114,8 @@ adv_pci_match(parent, match, aux)
struct device *parent;
void *match, *aux;
{
- struct pci_attach_args *pa = aux;
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_ADVSYS)
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_ADVSYS_1200A:
- case PCI_PRODUCT_ADVSYS_1200B:
- case PCI_PRODUCT_ADVSYS_ULTRA:
- return (1);
- }
-
- return 0;
+ return (pci_matchbyid((struct pci_attach_args *)aux, adv_pci_devices,
+ sizeof(adv_pci_devices)/sizeof(adv_pci_devices[0])));
}
diff --git a/sys/dev/pci/adw_pci.c b/sys/dev/pci/adw_pci.c
index 3a262c46680..d75cea1094b 100644
--- a/sys/dev/pci/adw_pci.c
+++ b/sys/dev/pci/adw_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: adw_pci.c,v 1.11 2002/03/14 01:26:58 millert Exp $ */
+/* $OpenBSD: adw_pci.c,v 1.12 2002/11/19 18:40:16 jason Exp $ */
/* $NetBSD: adw_pci.c,v 1.7 2000/05/26 15:13:46 dante Exp $ */
/*
@@ -85,6 +85,12 @@ struct cfattach adw_pci_ca =
sizeof(ADW_SOFTC), adw_pci_match, adw_pci_attach
};
+const struct pci_matchid adw_pci_devices[] = {
+ { PCI_VENDOR_ADVSYS, PCI_PRODUCT_ADVSYS_WIDE },
+ { PCI_VENDOR_ADVSYS, PCI_PRODUCT_ADVSYS_U2W },
+ { PCI_VENDOR_ADVSYS, PCI_PRODUCT_ADVSYS_U3W },
+};
+
/******************************************************************************/
/*
* Check the slots looking for a board we recognise
@@ -97,17 +103,8 @@ adw_pci_match(parent, match, aux)
void *match;
void *aux;
{
- struct pci_attach_args *pa = aux;
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_ADVSYS)
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_ADVSYS_WIDE:
- case PCI_PRODUCT_ADVSYS_U2W:
- case PCI_PRODUCT_ADVSYS_U3W:
- return (1);
- }
-
- return 0;
+ return (pci_matchbyid((struct pci_attach_args *)aux, adw_pci_devices,
+ sizeof(adw_pci_devices)/sizeof(adw_pci_devices[0])));
}
diff --git a/sys/dev/pci/ahc_pci.c b/sys/dev/pci/ahc_pci.c
index 9c26a0ab988..7f6843fe39a 100644
--- a/sys/dev/pci/ahc_pci.c
+++ b/sys/dev/pci/ahc_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ahc_pci.c,v 1.35 2002/07/05 05:41:02 smurph Exp $ */
+/* $OpenBSD: ahc_pci.c,v 1.36 2002/11/19 18:40:16 jason Exp $ */
/* $NetBSD: ahc_pci.c,v 1.9 1996/10/21 22:56:24 thorpej Exp $ */
/*
@@ -156,60 +156,50 @@ struct cfattach ahc_pci_ca = {
sizeof(struct ahc_softc), ahc_pci_probe, ahc_pci_attach
};
+const struct pci_matchid ahc_pci_devices[] = {
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_AIC7810 },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_AIC7850 },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_AIC7855 },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_AIC5900 },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_AIC5905 },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_AIC7860 },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_2940AU },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_AIC7870 },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_2930CU },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_2940 },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_3940 },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_3985 },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_2944 },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_AIC7880 },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_2940U },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_3940U },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_398XU },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_2944U },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_2940UWPro },
+ { PCI_VENDOR_ADP, PCI_PRODUCT_ADP_7895 },
+ { PCI_VENDOR_ADP2, PCI_PRODUCT_ADP2_AIC7890 },
+ { PCI_VENDOR_ADP2, PCI_PRODUCT_ADP2_2940U2 },
+ { PCI_VENDOR_ADP2, PCI_PRODUCT_ADP2_2930U2 },
+ { PCI_VENDOR_ADP2, PCI_PRODUCT_ADP2_AIC7892 },
+ { PCI_VENDOR_ADP2, PCI_PRODUCT_ADP2_29160 },
+ { PCI_VENDOR_ADP2, PCI_PRODUCT_ADP2_19160B },
+ { PCI_VENDOR_ADP2, PCI_PRODUCT_ADP2_3950U2B },
+ { PCI_VENDOR_ADP2, PCI_PRODUCT_ADP2_3950U2D },
+ { PCI_VENDOR_ADP2, PCI_PRODUCT_ADP2_AIC7896 },
+ { PCI_VENDOR_ADP2, PCI_PRODUCT_ADP2_AIC7899B },
+ { PCI_VENDOR_ADP2, PCI_PRODUCT_ADP2_AIC7899D },
+ { PCI_VENDOR_ADP2, PCI_PRODUCT_ADP2_AIC7899F },
+ { PCI_VENDOR_ADP2, PCI_PRODUCT_ADP2_AIC7899 },
+ { PCI_VENDOR_ADP2, PCI_PRODUCT_ADP2_3960D },
+};
+
int
ahc_pci_probe(parent, match, aux)
struct device *parent;
void *match, *aux;
{
- struct pci_attach_args *pa = aux;
-
- switch (PCI_VENDOR(pa->pa_id)) {
- case PCI_VENDOR_ADP:
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_ADP_AIC7810:
- case PCI_PRODUCT_ADP_AIC7850:
- case PCI_PRODUCT_ADP_AIC7855:
- case PCI_PRODUCT_ADP_AIC5900:
- case PCI_PRODUCT_ADP_AIC5905:
- case PCI_PRODUCT_ADP_AIC7860:
- case PCI_PRODUCT_ADP_2940AU:
- case PCI_PRODUCT_ADP_AIC7870:
- case PCI_PRODUCT_ADP_2930CU:
- case PCI_PRODUCT_ADP_2940:
- case PCI_PRODUCT_ADP_3940:
- case PCI_PRODUCT_ADP_3985:
- case PCI_PRODUCT_ADP_2944:
- case PCI_PRODUCT_ADP_AIC7880:
- case PCI_PRODUCT_ADP_2940U:
- case PCI_PRODUCT_ADP_3940U:
- case PCI_PRODUCT_ADP_398XU:
- case PCI_PRODUCT_ADP_2944U:
- case PCI_PRODUCT_ADP_2940UWPro:
- case PCI_PRODUCT_ADP_7895:
- return (1);
- }
- break;
- case PCI_VENDOR_ADP2:
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_ADP2_AIC7890:
- case PCI_PRODUCT_ADP2_2940U2:
- case PCI_PRODUCT_ADP2_2930U2:
- case PCI_PRODUCT_ADP2_AIC7892:
- case PCI_PRODUCT_ADP2_29160:
- case PCI_PRODUCT_ADP2_19160B:
- case PCI_PRODUCT_ADP2_3950U2B:
- case PCI_PRODUCT_ADP2_3950U2D:
- case PCI_PRODUCT_ADP2_AIC7896:
- case PCI_PRODUCT_ADP2_AIC7899B:
- case PCI_PRODUCT_ADP2_AIC7899D:
- case PCI_PRODUCT_ADP2_AIC7899F:
- case PCI_PRODUCT_ADP2_AIC7899:
- case PCI_PRODUCT_ADP2_3960D:
- return (1);
- }
- break;
- }
- return (0);
+ return (pci_matchbyid((struct pci_attach_args *)aux, ahc_pci_devices,
+ sizeof(ahc_pci_devices)/sizeof(ahc_pci_devices[0])));
}
void
diff --git a/sys/dev/pci/autri.c b/sys/dev/pci/autri.c
index afbc451b6b7..38fa471d0fe 100644
--- a/sys/dev/pci/autri.c
+++ b/sys/dev/pci/autri.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: autri.c,v 1.9 2002/10/04 19:55:19 mickey Exp $ */
+/* $OpenBSD: autri.c,v 1.10 2002/11/19 18:40:17 jason Exp $ */
/*
* Copyright (c) 2001 SOMEYA Yoshihiko and KUROSAWA Takahiro.
@@ -469,6 +469,12 @@ autri_flags_codec(void *v)
/*
*
*/
+const struct pci_matchid autri_devices[] = {
+ { PCI_VENDOR_TRIDENT, PCI_PRODUCT_TRIDENT_4DWAVE_DX },
+ { PCI_VENDOR_TRIDENT, PCI_PRODUCT_TRIDENT_4DWAVE_NX },
+ { PCI_VENDOR_SIS, PCI_PRODUCT_SIS_7018 },
+ { PCI_VENDOR_ALI, PCI_PRODUCT_ALI_M5451 },
+};
int
autri_match(parent, match, aux)
@@ -476,31 +482,8 @@ autri_match(parent, match, aux)
void *match;
void *aux;
{
- struct pci_attach_args *pa = (struct pci_attach_args *) aux;
-
- switch (PCI_VENDOR(pa->pa_id)) {
- case PCI_VENDOR_TRIDENT:
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_TRIDENT_4DWAVE_DX:
- case PCI_PRODUCT_TRIDENT_4DWAVE_NX:
- return 1;
- }
- break;
- case PCI_VENDOR_SIS:
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_SIS_7018:
- return 1;
- }
- break;
- case PCI_VENDOR_ALI:
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_ALI_M5451:
- return 1;
- }
- break;
- }
-
- return 0;
+ return (pci_matchbyid((struct pci_attach_args *)aux, autri_devices,
+ sizeof(autri_devices)/sizeof(autri_devices[0])));
}
void
diff --git a/sys/dev/pci/auvia.c b/sys/dev/pci/auvia.c
index 8f4e4d882c7..8d7b02468b1 100644
--- a/sys/dev/pci/auvia.c
+++ b/sys/dev/pci/auvia.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: auvia.c,v 1.20 2002/06/03 16:19:22 mickey Exp $ */
+/* $OpenBSD: auvia.c,v 1.21 2002/11/19 18:40:17 jason Exp $ */
/* $NetBSD: auvia.c,v 1.7 2000/11/15 21:06:33 jdolecek Exp $ */
/*-
@@ -206,23 +206,16 @@ void auvia_reset_codec(void *);
int auvia_waitready_codec(struct auvia_softc *sc);
int auvia_waitvalid_codec(struct auvia_softc *sc);
+const struct pci_matchid auvia_devices[] = {
+ { PCI_VENDOR_VIATECH, PCI_PRODUCT_VIATECH_VT82C686A_AC97 },
+ { PCI_VENDOR_VIATECH, PCI_PRODUCT_VIATECH_VT8233_AC97 },
+};
int
auvia_match(struct device *parent, void *match, void *aux)
{
- struct pci_attach_args *pa = (struct pci_attach_args *) aux;
-
- if (PCI_VENDOR(pa->pa_id) != PCI_VENDOR_VIATECH)
- return 0;
-
- switch(PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_VIATECH_VT82C686A_AC97:
- return 1;
- case PCI_PRODUCT_VIATECH_VT8233_AC97:
- return 1;
- default:
- return 0;
- }
+ return (pci_matchbyid((struct pci_attach_args *)aux, auvia_devices,
+ sizeof(auvia_devices)/sizeof(auvia_devices[0])));
}
diff --git a/sys/dev/pci/bha_pci.c b/sys/dev/pci/bha_pci.c
index 1c498f7be95..06a44c5169f 100644
--- a/sys/dev/pci/bha_pci.c
+++ b/sys/dev/pci/bha_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: bha_pci.c,v 1.2 2002/03/14 01:26:58 millert Exp $ */
+/* $OpenBSD: bha_pci.c,v 1.3 2002/11/19 18:40:17 jason Exp $ */
/* $NetBSD: bha_pci.c,v 1.16 1998/08/15 10:10:53 mycroft Exp $ */
/*-
@@ -63,6 +63,11 @@ struct cfattach bha_pci_ca = {
sizeof(struct bha_softc), bha_pci_match, bha_pci_attach
};
+const struct pci_matchid bha_pci_devices[] = {
+ { PCI_VENDOR_BUSLOGIC, PCI_PRODUCT_BUSLOGIC_MULTIMASTER_NC },
+ { PCI_VENDOR_BUSLOGIC, PCI_PRODUCT_BUSLOGIC_MULTIMASTER },
+};
+
/*
* Check the slots looking for a board we recognise
* If we find one, note it's address (slot) and call
@@ -79,11 +84,8 @@ bha_pci_match(parent, match, aux)
bus_size_t iosize;
int rv;
- if (PCI_VENDOR(pa->pa_id) != PCI_VENDOR_BUSLOGIC)
- return (0);
-
- if (PCI_PRODUCT(pa->pa_id) != PCI_PRODUCT_BUSLOGIC_MULTIMASTER_NC &&
- PCI_PRODUCT(pa->pa_id) != PCI_PRODUCT_BUSLOGIC_MULTIMASTER)
+ if (pci_matchbyid((struct pci_attach_args *)aux, bha_pci_devices,
+ sizeof(bha_pci_devices)/sizeof(bha_pci_devices[0])) == 0)
return (0);
if (pci_mapreg_map(pa, PCI_CBIO, PCI_MAPREG_TYPE_IO, 0, &iot, &ioh,
diff --git a/sys/dev/pci/cmpci.c b/sys/dev/pci/cmpci.c
index 2c99279b111..ce745f89864 100644
--- a/sys/dev/pci/cmpci.c
+++ b/sys/dev/pci/cmpci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cmpci.c,v 1.8 2002/03/14 03:16:06 millert Exp $ */
+/* $OpenBSD: cmpci.c,v 1.9 2002/11/19 18:40:17 jason Exp $ */
/*
* Copyright (c) 2000 Takuya SHIOZAKI
@@ -289,6 +289,11 @@ cmpci_index_to_divider(index)
return cmpci_rate_table[index].divider;
}
+const struct pci_matchid cmpci_devices[] = {
+ { PCI_VENDOR_CMI, PCI_PRODUCT_CMI_CMI8338A },
+ { PCI_VENDOR_CMI, PCI_PRODUCT_CMI_CMI8338B },
+ { PCI_VENDOR_CMI, PCI_PRODUCT_CMI_CMI8738 },
+};
/*
* interface to configure the device.
@@ -299,15 +304,8 @@ cmpci_match(parent, match, aux)
void *match;
void *aux;
{
- struct pci_attach_args *pa = (struct pci_attach_args *)aux;
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_CMI &&
- (PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_CMI_CMI8338A ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_CMI_CMI8338B ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_CMI_CMI8738))
- return 1;
-
- return 0;
+ return (pci_matchbyid((struct pci_attach_args *)aux, cmpci_devices,
+ sizeof(cmpci_devices)/sizeof(cmpci_devices[0])));
}
void
diff --git a/sys/dev/pci/cs4280.c b/sys/dev/pci/cs4280.c
index 1f1cd7da894..904613ae5d0 100644
--- a/sys/dev/pci/cs4280.c
+++ b/sys/dev/pci/cs4280.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cs4280.c,v 1.15 2002/03/14 03:16:06 millert Exp $ */
+/* $OpenBSD: cs4280.c,v 1.16 2002/11/19 18:40:17 jason Exp $ */
/* $NetBSD: cs4280.c,v 1.5 2000/06/26 04:56:23 simonb Exp $ */
/*
@@ -291,6 +291,12 @@ struct audio_device cs4280_device = {
"cs4280"
};
+const struct pci_matchid cs4280_devices[] = {
+ { PCI_VENDOR_CIRRUS, PCI_PRODUCT_CIRRUS_CS4280 },
+ { PCI_VENDOR_CIRRUS, PCI_PRODUCT_CIRRUS_CS4610 },
+ { PCI_VENDOR_CIRRUS, PCI_PRODUCT_CIRRUS_CS4614 },
+ { PCI_VENDOR_CIRRUS, PCI_PRODUCT_CIRRUS_CS4615 },
+};
int
cs4280_match(parent, ma, aux)
@@ -298,17 +304,8 @@ cs4280_match(parent, ma, aux)
void *ma;
void *aux;
{
- struct pci_attach_args *pa = (struct pci_attach_args *)aux;
-
- if (PCI_VENDOR(pa->pa_id) != PCI_VENDOR_CIRRUS)
- return (0);
- if (PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_CIRRUS_CS4280 ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_CIRRUS_CS4610 ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_CIRRUS_CS4614 ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_CIRRUS_CS4615) {
- return (1);
- }
- return (0);
+ return (pci_matchbyid((struct pci_attach_args *)aux, cs4280_devices,
+ sizeof(cs4280_devices)/sizeof(cs4280_devices[0])));
}
int
diff --git a/sys/dev/pci/cy_pci.c b/sys/dev/pci/cy_pci.c
index 9db5c3ee8ac..ca1b3100de6 100644
--- a/sys/dev/pci/cy_pci.c
+++ b/sys/dev/pci/cy_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cy_pci.c,v 1.11 2002/09/15 21:30:25 art Exp $ */
+/* $OpenBSD: cy_pci.c,v 1.12 2002/11/19 18:40:17 jason Exp $ */
/*
* Copyright (c) 1996 Timo Rossi.
* All rights reserved.
@@ -70,33 +70,22 @@ struct cfattach cy_pci_ca = {
#define CY_PLX_9060_ICS_IENABLE 0x100
#define CY_PLX_9060_ICS_LOCAL_IENABLE 0x800
+const struct pci_matchid cy_pci_devices[] = {
+ { PCI_VENDOR_CYCLADES, PCI_PRODUCT_CYCLADES_CYCLOMY_1 },
+ { PCI_VENDOR_CYCLADES, PCI_PRODUCT_CYCLADES_CYCLOMY_2 },
+ { PCI_VENDOR_CYCLADES, PCI_PRODUCT_CYCLADES_CYCLOM4Y_1 },
+ { PCI_VENDOR_CYCLADES, PCI_PRODUCT_CYCLADES_CYCLOM4Y_2 },
+ { PCI_VENDOR_CYCLADES, PCI_PRODUCT_CYCLADES_CYCLOM8Y_1 },
+ { PCI_VENDOR_CYCLADES, PCI_PRODUCT_CYCLADES_CYCLOM8Y_2 },
+};
+
int
cy_pci_match(parent, match, aux)
struct device *parent;
void *match, *aux;
{
- struct pci_attach_args *pa = aux;
-
- if (PCI_VENDOR(pa->pa_id) != PCI_VENDOR_CYCLADES)
- return (0);
-
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_CYCLADES_CYCLOMY_1:
- case PCI_PRODUCT_CYCLADES_CYCLOMY_2:
- case PCI_PRODUCT_CYCLADES_CYCLOM4Y_1:
- case PCI_PRODUCT_CYCLADES_CYCLOM4Y_2:
- case PCI_PRODUCT_CYCLADES_CYCLOM8Y_1:
- case PCI_PRODUCT_CYCLADES_CYCLOM8Y_2:
- break;
- default:
- return (0);
- }
-
-#ifdef CY_DEBUG
- printf("cy: Found Cyclades PCI device, id = 0x%x\n", pa->pa_id);
-#endif
-
- return (1);
+ return (pci_matchbyid((struct pci_attach_args *)aux, cy_pci_devices,
+ sizeof(cy_pci_devices)/sizeof(cy_pci_devices[0])));
}
void
diff --git a/sys/dev/pci/cz.c b/sys/dev/pci/cz.c
index 3643c48cfda..abac3bf2ac6 100644
--- a/sys/dev/pci/cz.c
+++ b/sys/dev/pci/cz.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cz.c,v 1.5 2002/01/30 20:45:34 nordin Exp $ */
+/* $OpenBSD: cz.c,v 1.6 2002/11/19 18:40:17 jason Exp $ */
/* $NetBSD: cz.c,v 1.15 2001/01/20 19:10:36 thorpej Exp $ */
/*-
@@ -275,13 +275,9 @@ cz_match(parent, match, aux)
{
struct pci_attach_args *pa = aux;
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_CYCLADES) {
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_CYCLADES_CYCLOMZ_2:
- return (1);
- }
- }
-
+ if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_CYCLADES &&
+ PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_CYCLADES_CYCLOMZ_2)
+ return (1);
return (0);
}
diff --git a/sys/dev/pci/eap.c b/sys/dev/pci/eap.c
index 8224729c71d..7d7970d8950 100644
--- a/sys/dev/pci/eap.c
+++ b/sys/dev/pci/eap.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: eap.c,v 1.16 2002/01/20 19:56:53 ericj Exp $ */
+/* $OpenBSD: eap.c,v 1.17 2002/11/19 18:40:17 jason Exp $ */
/* $NetBSD: eap.c,v 1.46 2001/09/03 15:07:37 reinoud Exp $ */
/*
@@ -252,29 +252,18 @@ struct audio_device eap_device = {
"eap"
};
+const struct pci_matchid eap_devices[] = {
+ { PCI_VENDOR_CREATIVELABS, PCI_PRODUCT_CREATIVELABS_EV1938 },
+ { PCI_VENDOR_ENSONIQ, PCI_PRODUCT_ENSONIQ_AUDIOPCI },
+ { PCI_VENDOR_ENSONIQ, PCI_PRODUCT_ENSONIQ_AUDIOPCI97 },
+ { PCI_VENDOR_ENSONIQ, PCI_PRODUCT_ENSONIQ_CT5880 },
+};
+
int
eap_match(struct device *parent, void *match, void *aux)
{
- struct pci_attach_args *pa = (struct pci_attach_args *) aux;
-
- switch (PCI_VENDOR(pa->pa_id)) {
- case PCI_VENDOR_CREATIVELABS:
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_CREATIVELABS_EV1938:
- return (1);
- }
- break;
- case PCI_VENDOR_ENSONIQ:
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_ENSONIQ_AUDIOPCI:
- case PCI_PRODUCT_ENSONIQ_AUDIOPCI97:
- case PCI_PRODUCT_ENSONIQ_CT5880:
- return (1);
- }
- break;
- }
-
- return (0);
+ return (pci_matchbyid((struct pci_attach_args *)aux, eap_devices,
+ sizeof(eap_devices)/sizeof(eap_devices[0])));
}
void
diff --git a/sys/dev/pci/esa.c b/sys/dev/pci/esa.c
index 0785f7028f9..16fd07940b1 100644
--- a/sys/dev/pci/esa.c
+++ b/sys/dev/pci/esa.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: esa.c,v 1.4 2002/10/04 20:01:19 mickey Exp $ */
+/* $OpenBSD: esa.c,v 1.5 2002/11/19 18:40:17 jason Exp $ */
/* $NetBSD: esa.c,v 1.12 2002/03/24 14:17:35 jmcneill Exp $ */
/*
@@ -992,23 +992,17 @@ esa_freemem(struct esa_softc *sc, struct esa_dma *p)
/*
* Supporting Subroutines
*/
+const struct pci_matchid esa_devices[] = {
+ { PCI_VENDOR_ESSTECH, PCI_PRODUCT_ESSTECH_ES1989 },
+ { PCI_VENDOR_ESSTECH, PCI_PRODUCT_ESSTECH_MAESTRO3 },
+ { PCI_VENDOR_ESSTECH, PCI_PRODUCT_ESSTECH_MAESTRO3_2 },
+};
int
esa_match(struct device *dev, void *match, void *aux)
{
- struct pci_attach_args *pa = (struct pci_attach_args *)aux;
-
- switch(PCI_VENDOR(pa->pa_id)) {
- case PCI_VENDOR_ESSTECH:
- switch(PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_ESSTECH_ES1989:
- case PCI_PRODUCT_ESSTECH_MAESTRO3:
- case PCI_PRODUCT_ESSTECH_MAESTRO3_2:
- return (1);
- }
- }
-
- return (0);
+ return (pci_matchbyid((struct pci_attach_args *)aux, esa_devices,
+ sizeof(esa_devices)/sizeof(esa_devices[0])));
}
void
diff --git a/sys/dev/pci/fms.c b/sys/dev/pci/fms.c
index 11871443a38..10d3bc3b270 100644
--- a/sys/dev/pci/fms.c
+++ b/sys/dev/pci/fms.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: fms.c,v 1.13 2002/10/13 18:26:12 krw Exp $ */
+/* $OpenBSD: fms.c,v 1.14 2002/11/19 18:40:17 jason Exp $ */
/* $NetBSD: fms.c,v 1.5.4.1 2000/06/30 16:27:50 simonb Exp $ */
/*-
@@ -166,12 +166,10 @@ fms_match(parent, match, aux)
{
struct pci_attach_args *pa = (struct pci_attach_args *) aux;
- if (PCI_VENDOR(pa->pa_id) != PCI_VENDOR_FORTEMEDIA)
- return 0;
- if (PCI_PRODUCT(pa->pa_id) != PCI_PRODUCT_FORTEMEDIA_FM801)
- return 0;
-
- return 1;
+ if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_FORTEMEDIA &&
+ PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_FORTEMEDIA_FM801)
+ return (1);
+ return (0);
}
void
diff --git a/sys/dev/pci/hifn7751.c b/sys/dev/pci/hifn7751.c
index f7ba7580adf..5be93e94619 100644
--- a/sys/dev/pci/hifn7751.c
+++ b/sys/dev/pci/hifn7751.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: hifn7751.c,v 1.132 2002/08/01 18:29:59 jason Exp $ */
+/* $OpenBSD: hifn7751.c,v 1.133 2002/11/19 18:40:17 jason Exp $ */
/*
* Invertex AEON / Hifn 7751 driver
@@ -116,26 +116,22 @@ u_int32_t hifn_read_4(struct hifn_softc *, int, bus_size_t);
struct hifn_stats hifnstats;
+const struct pci_matchid hifn_devices[] = {
+ { PCI_VENDOR_INVERTEX, PCI_PRODUCT_INVERTEX_AEON },
+ { PCI_VENDOR_HIFN, PCI_PRODUCT_HIFN_7751 },
+ { PCI_VENDOR_HIFN, PCI_PRODUCT_HIFN_7811 },
+ { PCI_VENDOR_HIFN, PCI_PRODUCT_HIFN_7951 },
+ { PCI_VENDOR_NETSEC, PCI_PRODUCT_NETSEC_7751 },
+};
+
int
hifn_probe(parent, match, aux)
struct device *parent;
void *match;
void *aux;
{
- struct pci_attach_args *pa = (struct pci_attach_args *) aux;
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_INVERTEX &&
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_INVERTEX_AEON)
- return (1);
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_HIFN &&
- (PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_HIFN_7751 ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_HIFN_7951 ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_HIFN_7811))
- return (1);
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_NETSEC &&
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_NETSEC_7751)
- return (1);
- return (0);
+ return (pci_matchbyid((struct pci_attach_args *)aux, hifn_devices,
+ sizeof(hifn_devices)/sizeof(hifn_devices[0])));
}
void
diff --git a/sys/dev/pci/i82365_pci.c b/sys/dev/pci/i82365_pci.c
index 491758add78..96aa21d3b60 100644
--- a/sys/dev/pci/i82365_pci.c
+++ b/sys/dev/pci/i82365_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: i82365_pci.c,v 1.6 2002/03/14 01:26:58 millert Exp $ */
+/* $OpenBSD: i82365_pci.c,v 1.7 2002/11/19 18:40:17 jason Exp $ */
/* $NetBSD: i82365_pci.c,v 1.11 2000/02/24 03:42:44 itohy Exp $ */
/*
@@ -91,19 +91,10 @@ pcic_pci_match(parent, match, aux)
{
struct pci_attach_args *pa = (struct pci_attach_args *) aux;
- switch (PCI_VENDOR(pa->pa_id)) {
- case PCI_VENDOR_CIRRUS:
- switch(PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_CIRRUS_CL_PD6729:
- break;
- default:
- return (0);
- }
- break;
- default:
- return (0);
- }
- return (1);
+ if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_CIRRUS &&
+ PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_CIRRUS_CL_PD6729)
+ return (1);
+ return (0);
}
void pcic_isa_config_interrupts(struct device *);
diff --git a/sys/dev/pci/if_an_pci.c b/sys/dev/pci/if_an_pci.c
index 58c8cbdd140..e61a22ac7f3 100644
--- a/sys/dev/pci/if_an_pci.c
+++ b/sys/dev/pci/if_an_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_an_pci.c,v 1.8 2002/05/22 15:30:36 mickey Exp $ */
+/* $OpenBSD: if_an_pci.c,v 1.9 2002/11/19 18:40:17 jason Exp $ */
/*
* Copyright (c) 1997, 1998, 1999
@@ -87,22 +87,21 @@ struct cfattach an_pci_ca = {
sizeof (struct an_softc), an_pci_match, an_pci_attach
};
+const struct pci_matchid an_pci_devices[] = {
+ { PCI_VENDOR_AIRONET, PCI_PRODUCT_AIRONET_PCI352 },
+ { PCI_VENDOR_AIRONET, PCI_PRODUCT_AIRONET_PC4500 },
+ { PCI_VENDOR_AIRONET, PCI_PRODUCT_AIRONET_PC4800 },
+ { PCI_VENDOR_AIRONET, PCI_PRODUCT_AIRONET_PC4800_1 },
+};
+
int
an_pci_match(parent, match, aux)
struct device *parent;
void *match;
void *aux;
{
- struct pci_attach_args *pa = aux;
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_AIRONET &&
- (PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_AIRONET_PCI352 ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_AIRONET_PC4500 ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_AIRONET_PC4800 ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_AIRONET_PC4800_1))
- return(1);
-
- return(0);
+ return (pci_matchbyid((struct pci_attach_args *)aux, an_pci_devices,
+ sizeof(an_pci_devices)/sizeof(an_pci_devices[0])));
}
void
diff --git a/sys/dev/pci/if_ep_pci.c b/sys/dev/pci/if_ep_pci.c
index 6e778e51824..d84f236f330 100644
--- a/sys/dev/pci/if_ep_pci.c
+++ b/sys/dev/pci/if_ep_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_ep_pci.c,v 1.21 2002/03/14 01:26:58 millert Exp $ */
+/* $OpenBSD: if_ep_pci.c,v 1.22 2002/11/19 18:40:17 jason Exp $ */
/* $NetBSD: if_ep_pci.c,v 1.13 1996/10/21 22:56:38 thorpej Exp $ */
/*
@@ -89,27 +89,20 @@ struct cfattach ep_pci_ca = {
sizeof(struct ep_softc), ep_pci_match, ep_pci_attach
};
+const struct pci_matchid ep_pci_devices[] = {
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C590 },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C595MII },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C595T4 },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C595TX },
+};
+
int
ep_pci_match(parent, match, aux)
struct device *parent;
void *match, *aux;
{
- struct pci_attach_args *pa = (struct pci_attach_args *) aux;
-
- if (PCI_VENDOR(pa->pa_id) != PCI_VENDOR_3COM)
- return 0;
-
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_3COM_3C590:
- case PCI_PRODUCT_3COM_3C595MII:
- case PCI_PRODUCT_3COM_3C595T4:
- case PCI_PRODUCT_3COM_3C595TX:
- break;
- default:
- return 0;
- }
-
- return 1;
+ return (pci_matchbyid((struct pci_attach_args *)aux, ep_pci_devices,
+ sizeof(ep_pci_devices)/sizeof(ep_pci_devices[0])));
}
void
diff --git a/sys/dev/pci/if_fpa.c b/sys/dev/pci/if_fpa.c
index e39af4ed7f1..58f007e5ca6 100644
--- a/sys/dev/pci/if_fpa.c
+++ b/sys/dev/pci/if_fpa.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_fpa.c,v 1.20 2002/06/09 03:14:18 todd Exp $ */
+/* $OpenBSD: if_fpa.c,v 1.21 2002/11/19 18:40:17 jason Exp $ */
/* $NetBSD: if_fpa.c,v 1.15 1996/10/21 22:56:40 thorpej Exp $ */
/*-
@@ -94,11 +94,10 @@ pdq_pci_match(parent, match, aux)
{
struct pci_attach_args *pa = (struct pci_attach_args *)aux;
- if (PCI_VENDOR(pa->pa_id) != PCI_VENDOR_DEC)
- return (0);
- if (PCI_PRODUCT(pa->pa_id) != PCI_PRODUCT_DEC_DEFPA)
- return (0);
- return (1);
+ if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_DEC &&
+ PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_DEC_DEFPA)
+ return (1);
+ return (0);
}
void
diff --git a/sys/dev/pci/if_fxp_pci.c b/sys/dev/pci/if_fxp_pci.c
index 1519ebb3800..238113c052a 100644
--- a/sys/dev/pci/if_fxp_pci.c
+++ b/sys/dev/pci/if_fxp_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_fxp_pci.c,v 1.15 2002/10/04 20:47:25 jason Exp $ */
+/* $OpenBSD: if_fxp_pci.c,v 1.16 2002/11/19 18:40:17 jason Exp $ */
/*
* Copyright (c) 1995, David Greenman
@@ -86,6 +86,20 @@ struct cfattach fxp_pci_ca = {
sizeof(struct fxp_softc), fxp_pci_match, fxp_pci_attach
};
+const struct pci_matchid fxp_pci_devices[] = {
+ { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82557 },
+ { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82559 },
+ { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82559ER },
+ { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82562 },
+ { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_PRO_100_VE_0 },
+ { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_PRO_100_VE_1 },
+ { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_PRO_100_VE_2 },
+ { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_PRO_100_VM_0 },
+ { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_PRO_100_VM_1 },
+ { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_PRO_100_VM_2 },
+ { PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_PRO_100_VM_3 },
+};
+
/*
* Check if a device is an 82557.
*/
@@ -95,27 +109,8 @@ fxp_pci_match(parent, match, aux)
void *match;
void *aux;
{
- struct pci_attach_args *pa = aux;
-
- if (PCI_VENDOR(pa->pa_id) != PCI_VENDOR_INTEL)
- return (0);
-
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_INTEL_82557:
- case PCI_PRODUCT_INTEL_82559:
- case PCI_PRODUCT_INTEL_82559ER:
- case PCI_PRODUCT_INTEL_82562:
- case PCI_PRODUCT_INTEL_PRO_100_VE_0:
- case PCI_PRODUCT_INTEL_PRO_100_VE_1:
- case PCI_PRODUCT_INTEL_PRO_100_VE_2:
- case PCI_PRODUCT_INTEL_PRO_100_VM_0:
- case PCI_PRODUCT_INTEL_PRO_100_VM_1:
- case PCI_PRODUCT_INTEL_PRO_100_VM_2:
- case PCI_PRODUCT_INTEL_PRO_100_VM_3:
- return (1);
- }
-
- return (0);
+ return (pci_matchbyid((struct pci_attach_args *)aux, fxp_pci_devices,
+ sizeof(fxp_pci_devices)/sizeof(fxp_pci_devices[0])));
}
void
diff --git a/sys/dev/pci/if_gem_pci.c b/sys/dev/pci/if_gem_pci.c
index bf178532c69..e4961306027 100644
--- a/sys/dev/pci/if_gem_pci.c
+++ b/sys/dev/pci/if_gem_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_gem_pci.c,v 1.10 2002/07/26 20:36:41 drahn Exp $ */
+/* $OpenBSD: if_gem_pci.c,v 1.11 2002/11/19 18:40:17 jason Exp $ */
/* $NetBSD: if_gem_pci.c,v 1.1 2001/09/16 00:11:42 eeh Exp $ */
/*
@@ -95,26 +95,21 @@ struct cfattach gem_pci_ca = {
* Attach routines need to be split out to different bus-specific files.
*/
+const struct pci_matchid gem_pci_devices[] = {
+ { PCI_VENDOR_SUN, PCI_PRODUCT_SUN_ERINETWORK },
+ { PCI_VENDOR_SUN, PCI_PRODUCT_SUN_GEMNETWORK },
+ { PCI_VENDOR_APPLE, PCI_PRODUCT_APPLE_GMAC },
+ { PCI_VENDOR_APPLE, PCI_PRODUCT_APPLE_GMAC2 },
+ { PCI_VENDOR_APPLE, PCI_PRODUCT_APPLE_GMAC3 },
+
int
gem_match_pci(parent, cf, aux)
struct device *parent;
void *cf;
void *aux;
{
- struct pci_attach_args *pa = aux;
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_SUN &&
- (PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_SUN_ERINETWORK ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_SUN_GEMNETWORK))
- return (1);
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_APPLE &&
- (PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_APPLE_GMAC ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_APPLE_GMAC2 ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_APPLE_GMAC3))
- return (1);
-
- return (0);
+ return (pci_matchbyid((struct pci_attach_args *)aux, gem_pci_devices,
+ sizeof(gem_pci_devices)/sizeof(gem_pci_devices[0])));
}
void
diff --git a/sys/dev/pci/if_rl_pci.c b/sys/dev/pci/if_rl_pci.c
index 6e0631b9d7e..41f895e90ac 100644
--- a/sys/dev/pci/if_rl_pci.c
+++ b/sys/dev/pci/if_rl_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_rl_pci.c,v 1.7 2002/03/14 01:26:59 millert Exp $ */
+/* $OpenBSD: if_rl_pci.c,v 1.8 2002/11/19 18:40:17 jason Exp $ */
/*
* Copyright (c) 1997, 1998
@@ -90,15 +90,14 @@ struct cfattach rl_pci_ca = {
sizeof(struct rl_softc), rl_pci_match, rl_pci_attach,
};
-struct rl_type rl_pci_devs[] = {
- { PCI_VENDOR_ACCTON, PCI_PRODUCT_ACCTON_5030 },
- { PCI_VENDOR_ADDTRON, PCI_PRODUCT_ADDTRON_8139 },
- { PCI_VENDOR_DELTA, PCI_PRODUCT_DELTA_8139 },
- { PCI_VENDOR_DLINK, PCI_PRODUCT_DLINK_530TXPLUS },
- { PCI_VENDOR_NORTEL, PCI_PRODUCT_NORTEL_BS21 },
- { PCI_VENDOR_REALTEK, PCI_PRODUCT_REALTEK_RT8129 },
- { PCI_VENDOR_REALTEK, PCI_PRODUCT_REALTEK_RT8139 },
- { 0, 0 }
+const struct pci_matchid rl_pci_devices[] = {
+ { PCI_VENDOR_ACCTON, PCI_PRODUCT_ACCTON_5030 },
+ { PCI_VENDOR_ADDTRON, PCI_PRODUCT_ADDTRON_8139 },
+ { PCI_VENDOR_DELTA, PCI_PRODUCT_DELTA_8139 },
+ { PCI_VENDOR_DLINK, PCI_PRODUCT_DLINK_530TXPLUS },
+ { PCI_VENDOR_NORTEL, PCI_PRODUCT_NORTEL_BS21 },
+ { PCI_VENDOR_REALTEK, PCI_PRODUCT_REALTEK_RT8129 },
+ { PCI_VENDOR_REALTEK, PCI_PRODUCT_REALTEK_RT8139 },
};
int
@@ -107,15 +106,8 @@ rl_pci_match(parent, match, aux)
void *match;
void *aux;
{
- struct pci_attach_args *pa = (struct pci_attach_args *)aux;
- struct rl_type *t;
-
- for (t = rl_pci_devs; t->rl_vid != 0; t++) {
- if ((PCI_VENDOR(pa->pa_id) == t->rl_vid) &&
- (PCI_PRODUCT(pa->pa_id) == t->rl_did))
- return (1);
- }
- return (0);
+ return (pci_matchbyid((struct pci_attach_args *)aux, rl_pci_devices,
+ sizeof(rl_pci_devices)/sizeof(rl_pci_devices[0])));
}
void
diff --git a/sys/dev/pci/if_sf.c b/sys/dev/pci/if_sf.c
index 0a6995a1c33..45a2dd2e275 100644
--- a/sys/dev/pci/if_sf.c
+++ b/sys/dev/pci/if_sf.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_sf.c,v 1.17 2002/03/14 01:26:59 millert Exp $ */
+/* $OpenBSD: if_sf.c,v 1.18 2002/11/19 18:40:17 jason Exp $ */
/*
* Copyright (c) 1997, 1998, 1999
* Bill Paul <wpaul@ctr.columbia.edu>. All rights reserved.
@@ -588,13 +588,9 @@ int sf_probe(parent, match, aux)
{
struct pci_attach_args *pa = (struct pci_attach_args *)aux;
- if (PCI_VENDOR(pa->pa_id) != PCI_VENDOR_ADP)
- return(0);
-
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_ADP_AIC6915:
+ if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_ADP &&
+ PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_ADP_AIC6915)
return(1);
- }
return(0);
}
diff --git a/sys/dev/pci/if_sis.c b/sys/dev/pci/if_sis.c
index abab8794068..abe52794e9d 100644
--- a/sys/dev/pci/if_sis.c
+++ b/sys/dev/pci/if_sis.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_sis.c,v 1.27 2002/07/31 16:58:20 jason Exp $ */
+/* $OpenBSD: if_sis.c,v 1.28 2002/11/19 18:40:17 jason Exp $ */
/*
* Copyright (c) 1997, 1998, 1999
* Bill Paul <wpaul@ctr.columbia.edu>. All rights reserved.
@@ -604,6 +604,12 @@ void sis_reset(sc)
return;
}
+const struct pci_matchid sis_devices[] = {
+ { PCI_VENDOR_SIS, PCI_PRODUCT_SIS_900 },
+ { PCI_VENDOR_SIS, PCI_PRODUCT_SIS_7016 },
+ { PCI_VENDOR_NS, PCI_PRODUCT_NS_DP83815 },
+};
+
/*
* Probe for an SiS chip. Check the PCI vendor and device
* IDs against our list and return a device name if we find a match.
@@ -613,21 +619,8 @@ int sis_probe(parent, match, aux)
void *match;
void *aux;
{
- struct pci_attach_args *pa = (struct pci_attach_args *)aux;
-
- if (PCI_VENDOR(pa->pa_id) != PCI_VENDOR_SIS &&
- PCI_VENDOR(pa->pa_id) != PCI_VENDOR_NS)
- return(0);
-
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_SIS_900:
- case PCI_PRODUCT_SIS_7016:
- case PCI_PRODUCT_NS_DP83815:
- return(1);
- }
-
- return(0);
-
+ return (pci_matchbyid((struct pci_attach_args *)aux, sis_devices,
+ sizeof(sis_devices)/sizeof(sis_devices[0])));
}
/*
diff --git a/sys/dev/pci/if_ste.c b/sys/dev/pci/if_ste.c
index 5ac41f28971..7ceb645127d 100644
--- a/sys/dev/pci/if_ste.c
+++ b/sys/dev/pci/if_ste.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_ste.c,v 1.16 2002/03/14 01:26:59 millert Exp $ */
+/* $OpenBSD: if_ste.c,v 1.17 2002/11/19 18:40:17 jason Exp $ */
/*
* Copyright (c) 1997, 1998, 1999
* Bill Paul <wpaul@ctr.columbia.edu>. All rights reserved.
@@ -827,6 +827,10 @@ void ste_stats_update(xsc)
return;
}
+const struct pci_matchid ste_devices[] = {
+ { PCI_VENDOR_SUNDANCE, PCI_PRODUCT_SUNDANCE_ST201 },
+ { PCI_VENDOR_DLINK, PCI_PRODUCT_DLINK_550TX },
+};
/*
* Probe for a Sundance ST201 chip. Check the PCI vendor and device
@@ -836,17 +840,8 @@ int ste_probe(parent, match, aux)
struct device *parent;
void *match, *aux;
{
- struct pci_attach_args *pa = (struct pci_attach_args *)aux;
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_SUNDANCE &&
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_SUNDANCE_ST201)
- return(1);
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_DLINK &&
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_DLINK_550TX)
- return(1);
-
- return(0);
+ return (pci_matchbyid((struct pci_attach_args *)aux, ste_devices,
+ sizeof(ste_devices)/sizeof(ste_devices[0])));
}
/*
diff --git a/sys/dev/pci/if_ti.c b/sys/dev/pci/if_ti.c
index cba863a0a43..8aca9b39d64 100644
--- a/sys/dev/pci/if_ti.c
+++ b/sys/dev/pci/if_ti.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_ti.c,v 1.38 2002/10/03 23:50:07 jason Exp $ */
+/* $OpenBSD: if_ti.c,v 1.39 2002/11/19 18:40:17 jason Exp $ */
/*
* Copyright (c) 1997, 1998, 1999
@@ -1422,6 +1422,16 @@ int ti_gibinit(sc)
return(0);
}
+const struct pci_matchid ti_devices[] = {
+ { PCI_VENDOR_NETGEAR, PCI_PRODUCT_NETGEAR_GA620 },
+ { PCI_VENDOR_NETGEAR, PCI_PRODUCT_NETGEAR_GA620T },
+ { PCI_VENDOR_ALTEON, PCI_PRODUCT_ALTEON_ACENIC },
+ { PCI_VENDOR_ALTEON, PCI_PRODUCT_ALTEON_ACENICT },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C985 },
+ { PCI_VENDOR_SGI, PCI_PRODUCT_SGI_TIGON },
+ { PCI_VENDOR_DEC, PCI_PRODUCT_DEC_PN9000SX },
+};
+
/*
* Probe for a Tigon chip. Check the PCI vendor and device IDs
* against our list and return its name if we find a match.
@@ -1432,32 +1442,8 @@ ti_probe(parent, match, aux)
void *match;
void *aux;
{
- struct pci_attach_args *pa = (struct pci_attach_args *)aux;
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_NETGEAR &&
- (PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_NETGEAR_GA620 ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_NETGEAR_GA620T))
- return (1);
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_ALTEON &&
- (PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_ALTEON_ACENIC ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_ALTEON_ACENICT))
- return (1);
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_3COM &&
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_3COM_3C985)
- return (1);
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_SGI &&
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_SGI_TIGON)
- return (1);
-
- /* This is really a Farallon board, they used the wrong vendorid */
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_DEC &&
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_DEC_PN9000SX)
- return (1);
-
- return (0);
+ return (pci_matchbyid((struct pci_attach_args *)aux, ti_devices,
+ sizeof(ti_devices)/sizeof(ti_devices[0])));
}
diff --git a/sys/dev/pci/if_tx.c b/sys/dev/pci/if_tx.c
index f766b3ae2d5..508d8403c62 100644
--- a/sys/dev/pci/if_tx.c
+++ b/sys/dev/pci/if_tx.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_tx.c,v 1.24 2002/11/14 07:35:18 kjc Exp $ */
+/* $OpenBSD: if_tx.c,v 1.25 2002/11/19 18:40:17 jason Exp $ */
/* $FreeBSD: src/sys/pci/if_tx.c,v 1.45 2001/02/07 20:11:02 semenu Exp $ */
/*-
@@ -205,13 +205,11 @@ epic_openbsd_probe(
void *aux )
{
struct pci_attach_args *pa = aux;
- if( PCI_VENDOR(pa->pa_id) != SMC_VENDORID )
- return 0;
-
- if( PCI_PRODUCT(pa->pa_id) == SMC_DEVICEID_83C170 )
- return 1;
- return 0;
+ if (PCI_VENDOR(pa->pa_id) == SMC_VENDORID &&
+ PCI_PRODUCT(pa->pa_id) == SMC_DEVICEID_83C170)
+ return (1);
+ return (0);
}
void
diff --git a/sys/dev/pci/if_txp.c b/sys/dev/pci/if_txp.c
index 1243c0ac935..94fcd01fefb 100644
--- a/sys/dev/pci/if_txp.c
+++ b/sys/dev/pci/if_txp.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_txp.c,v 1.66 2002/07/11 20:27:04 jason Exp $ */
+/* $OpenBSD: if_txp.c,v 1.67 2002/11/19 18:40:17 jason Exp $ */
/*
* Copyright (c) 2001
@@ -144,27 +144,22 @@ struct cfdriver txp_cd = {
0, "txp", DV_IFNET
};
+const struct pci_matchid txp_devices[] = {
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3CR990TX95 },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3CR990TX97 },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3CR990SVR95 },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3CR990SVR97 },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C990BTXM },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C990BSVR },
+};
+
int
txp_probe(parent, match, aux)
struct device *parent;
void *match, *aux;
{
- struct pci_attach_args *pa = (struct pci_attach_args *)aux;
-
- if (PCI_VENDOR(pa->pa_id) != PCI_VENDOR_3COM)
- return (0);
-
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_3COM_3CR990TX95:
- case PCI_PRODUCT_3COM_3CR990TX97:
- case PCI_PRODUCT_3COM_3CR990SVR95:
- case PCI_PRODUCT_3COM_3CR990SVR97:
- case PCI_PRODUCT_3COM_3C990BTXM:
- case PCI_PRODUCT_3COM_3C990BSVR:
- return (1);
- }
-
- return (0);
+ return (pci_matchbyid((struct pci_attach_args *)aux, txp_devices,
+ sizeof(txp_devices)/sizeof(txp_devices[0])));
}
void
diff --git a/sys/dev/pci/if_vr.c b/sys/dev/pci/if_vr.c
index b6415657b0b..80fd9e1ed27 100644
--- a/sys/dev/pci/if_vr.c
+++ b/sys/dev/pci/if_vr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_vr.c,v 1.26 2002/05/14 16:54:45 millert Exp $ */
+/* $OpenBSD: if_vr.c,v 1.27 2002/11/19 18:40:17 jason Exp $ */
/*
* Copyright (c) 1997, 1998
@@ -555,6 +555,14 @@ vr_reset(sc)
return;
}
+const struct pci_matchid vr_devices[] = {
+ { PCI_VENDOR_VIATECH, PCI_PRODUCT_VIATECH_RHINE },
+ { PCI_VENDOR_VIATECH, PCI_PRODUCT_VIATECH_RHINEII },
+ { PCI_VENDOR_VIATECH, PCI_PRODUCT_VIATECH_RHINEII_2 },
+ { PCI_VENDOR_DELTA, PCI_PRODUCT_DELTA_RHINEII },
+ { PCI_VENDOR_ADDTRON, PCI_PRODUCT_ADDTRON_RHINEII },
+};
+
/*
* Probe for a VIA Rhine chip.
*/
@@ -563,26 +571,8 @@ vr_probe(parent, match, aux)
struct device *parent;
void *match, *aux;
{
- struct pci_attach_args *pa = (struct pci_attach_args *)aux;
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_VIATECH) {
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_VIATECH_RHINE:
- case PCI_PRODUCT_VIATECH_RHINEII:
- case PCI_PRODUCT_VIATECH_RHINEII_2:
- return (1);
- }
- }
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_DELTA &&
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_DELTA_RHINEII)
- return (1);
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_ADDTRON &&
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_ADDTRON_RHINEII)
- return (1);
-
- return (0);
+ return (pci_matchbyid((struct pci_attach_args *)aux, vr_devices,
+ sizeof(vr_devices)/sizeof(vr_devices[0])));
}
/*
diff --git a/sys/dev/pci/if_wb.c b/sys/dev/pci/if_wb.c
index 4f5d67211e9..1f4d8b53fbf 100644
--- a/sys/dev/pci/if_wb.c
+++ b/sys/dev/pci/if_wb.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_wb.c,v 1.18 2002/07/05 13:48:11 aaron Exp $ */
+/* $OpenBSD: if_wb.c,v 1.19 2002/11/19 18:40:17 jason Exp $ */
/*
* Copyright (c) 1997, 1998
@@ -708,6 +708,11 @@ wb_fixmedia(sc)
ifmedia_set(&mii->mii_media, media);
}
+const struct pci_matchid wb_devices[] = {
+ { PCI_VENDOR_WINBOND, PCI_PRODUCT_WINBOND_W89C840F },
+ { PCI_VENDOR_COMPEX, PCI_PRODUCT_COMPEX_RL100ATX },
+};
+
/*
* Probe for a Winbond chip. Check the PCI vendor and device
* IDs against our list and return a device name if we find a match.
@@ -717,23 +722,8 @@ wb_probe(parent, match, aux)
struct device *parent;
void *match, *aux;
{
- struct pci_attach_args *pa = (struct pci_attach_args *)aux;
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_WINBOND) {
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_WINBOND_W89C840F:
- return (1);
- }
- }
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_COMPEX) {
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_COMPEX_RL100ATX:
- return (1);
- }
- }
-
- return (0);
+ return (pci_matchbyid((struct pci_attach_args *)aux, wb_devices,
+ sizeof(wb_devices)/sizeof(wb_devices[0])));
}
/*
diff --git a/sys/dev/pci/if_xl_pci.c b/sys/dev/pci/if_xl_pci.c
index 037be8c2ece..715fe998379 100644
--- a/sys/dev/pci/if_xl_pci.c
+++ b/sys/dev/pci/if_xl_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_xl_pci.c,v 1.12 2002/06/15 05:14:41 aaron Exp $ */
+/* $OpenBSD: if_xl_pci.c,v 1.13 2002/11/19 18:40:17 jason Exp $ */
/*
* Copyright (c) 1997, 1998, 1999
@@ -99,42 +99,37 @@ struct cfattach xl_pci_ca = {
sizeof(struct xl_softc), xl_pci_match, xl_pci_attach,
};
+const struct pci_matchid xl_pci_devices[] = {
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3CSOHO100TX },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C900TPO },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C900COMBO },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C900B },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C900BCOMBO },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C900BTPC },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C900BFL },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C905TX },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C905T4 },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C905BTX },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C905BT4 },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C905BCOMBO },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C905BFX },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C980TX },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C980CTX },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C905CTX },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C450 },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C555 },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C556 },
+ { PCI_VENDOR_3COM, PCI_PRODUCT_3COM_3C556B },
+};
+
int
xl_pci_match(parent, match, aux)
struct device *parent;
void *match;
void *aux;
{
- struct pci_attach_args *pa = (struct pci_attach_args *) aux;
-
- if (PCI_VENDOR(pa->pa_id) != PCI_VENDOR_3COM)
- return (0);
-
- switch (PCI_PRODUCT(pa->pa_id)) {
- case PCI_PRODUCT_3COM_3CSOHO100TX:
- case PCI_PRODUCT_3COM_3C900TPO:
- case PCI_PRODUCT_3COM_3C900COMBO:
- case PCI_PRODUCT_3COM_3C900B:
- case PCI_PRODUCT_3COM_3C900BCOMBO:
- case PCI_PRODUCT_3COM_3C900BTPC:
- case PCI_PRODUCT_3COM_3C900BFL:
- case PCI_PRODUCT_3COM_3C905TX:
- case PCI_PRODUCT_3COM_3C905T4:
- case PCI_PRODUCT_3COM_3C905BTX:
- case PCI_PRODUCT_3COM_3C905BT4:
- case PCI_PRODUCT_3COM_3C905BCOMBO:
- case PCI_PRODUCT_3COM_3C905BFX:
- case PCI_PRODUCT_3COM_3C980TX:
- case PCI_PRODUCT_3COM_3C980CTX:
- case PCI_PRODUCT_3COM_3C905CTX:
- case PCI_PRODUCT_3COM_3C450:
- case PCI_PRODUCT_3COM_3C555:
- case PCI_PRODUCT_3COM_3C556:
- case PCI_PRODUCT_3COM_3C556B:
- return (1);
- }
-
- return (0);
+ return (pci_matchbyid((struct pci_attach_args *)aux, xl_pci_devices,
+ sizeof(xl_pci_devices)/sizeof(xl_pci_devices[0])));
}
void
diff --git a/sys/dev/pci/pci.c b/sys/dev/pci/pci.c
index 2cc0be21242..3fc327d3787 100644
--- a/sys/dev/pci/pci.c
+++ b/sys/dev/pci/pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pci.c,v 1.29 2002/04/04 17:11:46 jason Exp $ */
+/* $OpenBSD: pci.c,v 1.30 2002/11/19 18:40:17 jason Exp $ */
/* $NetBSD: pci.c,v 1.31 1997/06/06 23:48:04 thorpej Exp $ */
/*
@@ -387,6 +387,20 @@ pci_get_capability(pc, tag, capid, offset, value)
return (0);
}
+int
+pci_matchbyid(struct pci_attach_args *pa, const struct pci_matchid *ids,
+ int nent)
+{
+ const struct pci_matchid *pm;
+ int i;
+
+ for (i = 0, pm = ids; i < nent; i++, pm++)
+ if (PCI_VENDOR(pa->pa_id) == pm->pm_vid &&
+ PCI_PRODUCT(pa->pa_id) == pm->pm_pid)
+ return (1);
+ return (0);
+}
+
#ifdef USER_PCICONF
/*
* This is the user interface to PCI configuration space.
diff --git a/sys/dev/pci/pcivar.h b/sys/dev/pci/pcivar.h
index dc68945d121..b3682aa6f1b 100644
--- a/sys/dev/pci/pcivar.h
+++ b/sys/dev/pci/pcivar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: pcivar.h,v 1.25 2002/07/12 20:17:03 mickey Exp $ */
+/* $OpenBSD: pcivar.h,v 1.26 2002/11/19 18:40:17 jason Exp $ */
/* $NetBSD: pcivar.h,v 1.23 1997/06/06 23:48:05 thorpej Exp $ */
/*
@@ -182,6 +182,13 @@ int pci_mem_find(pci_chipset_tag_t, pcitag_t, int, bus_addr_t *,
int pci_get_capability(pci_chipset_tag_t, pcitag_t, int,
int *, pcireg_t *);
+struct pci_matchid {
+ pci_vendor_id_t pm_vid;
+ pci_product_id_t pm_pid;
+};
+
+int pci_matchbyid(struct pci_attach_args *, const struct pci_matchid *, int);
+
/*
* Helper functions for autoconfiguration.
*/
diff --git a/sys/dev/pci/ubsec.c b/sys/dev/pci/ubsec.c
index d35d4ef0c99..187ed180ea9 100644
--- a/sys/dev/pci/ubsec.c
+++ b/sys/dev/pci/ubsec.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ubsec.c,v 1.118 2002/10/12 01:09:44 krw Exp $ */
+/* $OpenBSD: ubsec.c,v 1.119 2002/11/19 18:40:17 jason Exp $ */
/*
* Copyright (c) 2000 Jason L. Wright (jason@thought.net)
@@ -132,30 +132,26 @@ void ubsec_dump_ctx2(struct ubsec_ctx_keyop *);
struct ubsec_stats ubsecstats;
+const struct pci_matchid ubsec_devices[] = {
+ { PCI_VENDOR_BLUESTEEL, PCI_PRODUCT_BLUESTEEL_5501 },
+ { PCI_VENDOR_BLUESTEEL, PCI_PRODUCT_BLUESTEEL_5601 },
+ { PCI_VENDOR_BROADCOM, PCI_PRODUCT_BROADCOM_5801 },
+ { PCI_VENDOR_BROADCOM, PCI_PRODUCT_BROADCOM_5802 },
+ { PCI_VENDOR_BROADCOM, PCI_PRODUCT_BROADCOM_5805 },
+ { PCI_VENDOR_BROADCOM, PCI_PRODUCT_BROADCOM_5820 },
+ { PCI_VENDOR_BROADCOM, PCI_PRODUCT_BROADCOM_5821 },
+ { PCI_VENDOR_BROADCOM, PCI_PRODUCT_BROADCOM_5822 },
+ { PCI_VENDOR_SUN, PCI_PRODUCT_SUN_SCA1K },
+};
+
int
ubsec_probe(parent, match, aux)
struct device *parent;
void *match;
void *aux;
{
- struct pci_attach_args *pa = (struct pci_attach_args *)aux;
-
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_BLUESTEEL &&
- (PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_BLUESTEEL_5501 ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_BLUESTEEL_5601))
- return (1);
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_BROADCOM &&
- (PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_BROADCOM_5801 ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_BROADCOM_5802 ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_BROADCOM_5805 ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_BROADCOM_5820 ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_BROADCOM_5821 ||
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_BROADCOM_5822))
- return (1);
- if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_SUN &&
- PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_SUN_SCA1K)
- return (1);
- return (0);
+ return (pci_matchbyid((struct pci_attach_args *)aux, ubsec_devices,
+ sizeof(ubsec_devices)/sizeof(ubsec_devices[0])));
}
void