diff options
author | Michael Shalayeff <mickey@cvs.openbsd.org> | 2003-12-09 14:35:04 +0000 |
---|---|---|
committer | Michael Shalayeff <mickey@cvs.openbsd.org> | 2003-12-09 14:35:04 +0000 |
commit | be058ad9795d4adc89b9e288e485a2420ff7324d (patch) | |
tree | c4fa37f216172b32b4329340794b89a684c214fa /sys/arch | |
parent | 59cbc6f71f2bcad8ca376c739a1a19c467cccb70 (diff) |
on pci systems bootdevice is specified by the hpa only
and thus just scan the bars for the matching hpa for each pci device
Diffstat (limited to 'sys/arch')
-rw-r--r-- | sys/arch/hppa/hppa/autoconf.c | 53 |
1 files changed, 52 insertions, 1 deletions
diff --git a/sys/arch/hppa/hppa/autoconf.c b/sys/arch/hppa/hppa/autoconf.c index 769af32f061..9e50642f9e6 100644 --- a/sys/arch/hppa/hppa/autoconf.c +++ b/sys/arch/hppa/hppa/autoconf.c @@ -1,4 +1,4 @@ -/* $OpenBSD: autoconf.c,v 1.36 2003/10/15 17:42:09 mickey Exp $ */ +/* $OpenBSD: autoconf.c,v 1.37 2003/12/09 14:35:03 mickey Exp $ */ /* * Copyright (c) 1998-2003 Michael Shalayeff @@ -41,6 +41,8 @@ * @(#)autoconf.c 8.4 (Berkeley) 10/1/93 */ +#include "pci.h" + #include <sys/param.h> #include <sys/systm.h> #include <sys/buf.h> @@ -57,6 +59,11 @@ #include <hppa/dev/cpudevs.h> +#if NPCI > 0 +#include <dev/pci/pcivar.h> +#include <dev/pci/pcireg.h> +#endif + void setroot(void); void swapconf(void); void dumpconf(void); @@ -357,6 +364,24 @@ gotdisk: return (dv); } +void +print_devpath(const char *label, struct pz_device *pz) +{ + int i; + + printf("%s: ", label); + + for (i = 0; i < 6 && pz->pz_bc[i] >= 0; i++) + printf("%s%d", i? "/" : "", pz->pz_bc[i]); + + printf("%s%d.%d", i? "." : "", pz->pz_mod, pz->pz_layers[0]); + for (i = 1; i < 6 && pz->pz_layers[i]; i++) + printf(".%d", pz->pz_layers[i]); + + printf(" class=%d flags=%b hpa=%p spa=%p io=%p\n", pz->pz_class, + pz->pz_flags, PZF_BITS, pz->pz_hpa, pz->pz_spa, pz->pz_iodc_io); +} + /* * Attempt to find the device from which we were booted. * If we can do so, and not instructed not to do so, @@ -386,6 +411,8 @@ setroot(void) #endif part = 0; + print_devpath("boot path", &PAGE0->mem_boot); + /* * If 'swap generic' and we couldn't determine boot device, * ask the user. @@ -731,6 +758,9 @@ hppa_mod_info(type, sv) void device_register(struct device *dev, void *aux) { +#if NPCI > 0 + extern struct cfdriver pci_cd; +#endif struct confargs *ca = aux; char *basename; static struct device *elder = NULL; @@ -738,6 +768,27 @@ device_register(struct device *dev, void *aux) if (bootdv != NULL) return; /* We already have a winner */ +#if NPCI > 0 + if (dev->dv_parent && + dev->dv_parent->dv_cfdata->cf_driver == &pci_cd) { + struct pci_attach_args *pa = aux; + pcireg_t addr; + int reg; + + for (reg = PCI_MAPREG_START; reg < PCI_MAPREG_END; reg += 4) { + addr = pci_conf_read(pa->pa_pc, pa->pa_tag, reg); + if (PCI_MAPREG_TYPE(addr) == PCI_MAPREG_TYPE_IO) + addr = PCI_MAPREG_IO_ADDR(addr); + else + addr = PCI_MAPREG_MEM_ADDR(addr); + + if (addr == (pcireg_t)PAGE0->mem_boot.pz_hpa) { + elder = dev; + break; + } + } + } else +#endif if (ca->ca_hpa == (hppa_hpa_t)PAGE0->mem_boot.pz_hpa) { /* * If hpa matches, the only thing we know is that the |