#include <sys/param.h>
#include <sys/systm.h>
#include <sys/device.h>
#include <sys/rwlock.h>
#include <machine/bus.h>
#include <dev/pci/pcivar.h>
#include <dev/pci/pcireg.h>
#include <dev/pci/pcidevs.h>
#include <dev/pci/agpvar.h>
#include "agp.h"
int pchbmatch(struct device *, void *, void *);
void pchbattach(struct device *, struct device *, void *);
const struct cfattach pchb_ca = {
sizeof(struct device), pchbmatch, pchbattach
};
struct cfdriver pchb_cd = {
NULL, "pchb", DV_DULL
};
int
pchbmatch(struct device *parent, void *cf, void *aux)
{
struct pci_attach_args *pa = aux;
switch (PCI_VENDOR(pa->pa_id)) {
case PCI_VENDOR_APPLE:
switch (PCI_PRODUCT(pa->pa_id)) {
case PCI_PRODUCT_APPLE_BANDIT:
case PCI_PRODUCT_APPLE_UNINORTH:
case PCI_PRODUCT_APPLE_UNINORTHETH:
case PCI_PRODUCT_APPLE_UNINORTH_AGP:
case PCI_PRODUCT_APPLE_PANGEA:
case PCI_PRODUCT_APPLE_PANGEA_PCI:
case PCI_PRODUCT_APPLE_PANGEA_AGP:
case PCI_PRODUCT_APPLE_UNINORTH2:
case PCI_PRODUCT_APPLE_UNINORTH2ETH:
case PCI_PRODUCT_APPLE_UNINORTH2_AGP:
case PCI_PRODUCT_APPLE_UNINORTH_AGP3:
case PCI_PRODUCT_APPLE_UNINORTH5:
case PCI_PRODUCT_APPLE_UNINORTH6:
case PCI_PRODUCT_APPLE_SHASTA_HT:
case PCI_PRODUCT_APPLE_K2:
case PCI_PRODUCT_APPLE_INTREPID2_AGP:
case PCI_PRODUCT_APPLE_INTREPID2_PCI1:
case PCI_PRODUCT_APPLE_INTREPID2_PCI2:
case PCI_PRODUCT_APPLE_U3_AGP:
case PCI_PRODUCT_APPLE_U3L_AGP:
case PCI_PRODUCT_APPLE_K2_AGP:
return (1);
}
break;
case PCI_VENDOR_MOT:
switch (PCI_PRODUCT(pa->pa_id)) {
case PCI_PRODUCT_MOT_MPC106:
return (1);
}
break;
}
return (0);
}
void
pchbattach(struct device *parent, struct device *self, void *aux)
{
#if NAGP > 0
struct pci_attach_args *pa = aux;
#endif
printf("\n");
#if NAGP > 0
if (pci_get_capability(pa->pa_pc, pa->pa_tag, PCI_CAP_AGP,
NULL, NULL) != 0) {
struct agp_attach_args aa;
aa.aa_busname = "agp";
aa.aa_pa = pa;
config_found(self, &aa, agpdev_print);
}
#endif
}