From 052b317b866076458c3a1e17f0f20ee9c7411f0b Mon Sep 17 00:00:00 2001 From: Brad Smith Date: Mon, 20 Oct 2008 19:43:40 +0000 Subject: - Remove sys/cdefs.h header. - Make use of pci_matchbyid(). - Replace magic number with PCI_MAPREG_START for the PCI BAR. - Remove redundant code to enable PCI bus mastering which is already dealt with by pci_mapreg_map(). ok mikeb@ --- sys/dev/pci/auacer.c | 26 +++++++++----------------- 1 file changed, 9 insertions(+), 17 deletions(-) (limited to 'sys/dev') diff --git a/sys/dev/pci/auacer.c b/sys/dev/pci/auacer.c index b48cf9171b9..1b7be25098e 100644 --- a/sys/dev/pci/auacer.c +++ b/sys/dev/pci/auacer.c @@ -1,4 +1,4 @@ -/* $OpenBSD: auacer.c,v 1.1 2008/08/28 10:21:23 mikeb Exp $ */ +/* $OpenBSD: auacer.c,v 1.2 2008/10/20 19:43:39 brad Exp $ */ /* $NetBSD: auacer.c,v 1.3 2004/11/10 04:20:26 kent Exp $ */ /*- @@ -39,9 +39,6 @@ * the ALSA intel8x0.c driver (which handles M5455 as well). */ - -#include - #include #include #include @@ -75,6 +72,10 @@ struct auacer_dma { #define DMAADDR(p) ((p)->map->dm_segs[0].ds_addr) #define KERNADDR(p) ((void *)((p)->addr)) +const struct pci_matchid auacer_pci_devices[] = { + { PCI_VENDOR_ALI, PCI_PRODUCT_ALI_M5455 } +}; + struct auacer_cdata { struct auacer_dmalist ic_dmalist_pcmo[ALI_DMALIST_MAX]; }; @@ -229,12 +230,8 @@ void auacer_reset_codec(void *); int auacer_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_ALI && - PCI_PRODUCT(pa->pa_id) == PCI_PRODUCT_ALI_M5455) - return 1; - return 0; + return (pci_matchbyid((struct pci_attach_args *)aux, auacer_pci_devices, + sizeof(auacer_pci_devices)/sizeof(auacer_pci_devices[0]))); } void @@ -247,8 +244,8 @@ auacer_attach(struct device *parent, struct device *self, void *aux) pcireg_t v; const char *intrstr; - if (pci_mapreg_map(pa, 0x10, PCI_MAPREG_TYPE_IO, 0, &sc->iot, - &sc->aud_ioh, NULL, &aud_size, 0)) { + if (pci_mapreg_map(pa, PCI_MAPREG_START, PCI_MAPREG_TYPE_IO, 0, + &sc->iot, &sc->aud_ioh, NULL, &aud_size, 0)) { printf(": can't map i/o space\n"); return; } @@ -259,11 +256,6 @@ auacer_attach(struct device *parent, struct device *self, void *aux) sc->sc_dmamap_flags = BUS_DMA_COHERENT; /* XXX remove */ - /* enable bus mastering */ - v = pci_conf_read(pa->pa_pc, pa->pa_tag, PCI_COMMAND_STATUS_REG); - pci_conf_write(pa->pa_pc, pa->pa_tag, PCI_COMMAND_STATUS_REG, - v | PCI_COMMAND_MASTER_ENABLE); - /* Map and establish the interrupt. */ if (pci_intr_map(pa, &ih)) { printf("%s: can't map interrupt\n", sc->sc_dev.dv_xname); -- cgit v1.2.3